



# A20

## User Manual

Revision 1.0

Feb. 18, 2013

## Declaration

THIS A20 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 DOCUMENTATION NEITHER STATES NOR IMPLIES WARRANTY OF ANY KIND, INCLUDING FITNESS FOR ANY PARTICULAR APPLICATION.

THIRD PARTY LICENCES MAY BE REQUIRED TO IMPLEMENT THE SOLUTION/PRODUCT. CUSTOMERS SHALL BE SOLELY RESPONSIBLE TO OBTAIN ALL APPROPRIATELY REQUIRED THIRD PARTY LICENCES. ALLWINNER SHALL NOT BE LIABLE FOR ANY LICENCE FEE OR ROYALTY DUE IN RESPECT OF ANY REQUIRED THIRD PARTY LICENCE. ALLWINNER SHALL HAVE NO WARRANTY, INDEMNITY OR OTHER OBLIGATIONS WITH RESPECT TO MATTERS COVERED UNDER ANY REQUIRED THIRD PARTY LICENCE.

## Revision History

| Revision | Date           | Author | Description     |
|----------|----------------|--------|-----------------|
| 1.0      | March 22, 2013 |        | Initial version |

# Table of Contents

|                                                       |     |
|-------------------------------------------------------|-----|
| Declaration .....                                     | 2   |
| Revision History.....                                 | 3   |
| Table of Contents.....                                | 4   |
| <br>                                                  |     |
| Chapter 1    System.....                              | 9   |
| 1.1.    Overview.....                                 | 10  |
| 1.2.    A20 Block Diagram.....                        | 17  |
| 1.3.    Memory Mapping.....                           | 18  |
| 1.4.    CPU Configuration.....                        | 22  |
| 1.4.1.    Overview .....                              | 22  |
| 1.4.2.    CPU Configuration Register List.....        | 23  |
| 1.4.3.    CPUCFG Register Description .....           | 24  |
| 1.5.    CCU .....                                     | 33  |
| 1.5.1.    Overview .....                              | 33  |
| 1.5.2.    Clock Tree Diagram .....                    | 34  |
| 1.5.3.    CCU Register List.....                      | 34  |
| 1.5.4.    CCU Register Description .....              | 37  |
| 1.6.    System Boot .....                             | 95  |
| 1.6.1.    Overview .....                              | 95  |
| 1.6.2.    System Boot Diagram .....                   | 96  |
| 1.7.    System Control .....                          | 97  |
| 1.7.1.    Overview .....                              | 97  |
| 1.7.2.    System Control Register List.....           | 98  |
| 1.7.3.    System Control Register .....               | 98  |
| 1.8.    PWM .....                                     | 102 |
| 1.8.1.    Overview .....                              | 102 |
| 1.8.2.    PWM Register List.....                      | 103 |
| 1.8.3.    PWM Register Description .....              | 103 |
| 1.9.    Timer.....                                    | 108 |
| 1.9.1.    Overview .....                              | 108 |
| 1.9.2.    Timer Register List .....                   | 109 |
| 1.9.3.    Timer Register Description .....            | 110 |
| 1.10.    High Speed Timer.....                        | 134 |
| 1.10.1.    Overview .....                             | 134 |
| 1.10.2.    High Speed Timer Register List .....       | 135 |
| 1.10.3.    High Speed Timer Controller Register ..... | 136 |
| 1.11.    GIC .....                                    | 147 |
| 1.11.1.    Interrupt Source.....                      | 147 |
| 1.12.    DMA .....                                    | 152 |
| 1.12.1.    Overview .....                             | 152 |
| 1.12.2.    DMA Register List .....                    | 153 |
| 1.12.3.    DMA Controller Register Description .....  | 154 |
| 1.13.    Audio Codec .....                            | 172 |
| 1.13.1.    Overview .....                             | 172 |
| 1.13.2.    Audio Codec Block Diagram.....             | 173 |
| 1.13.3.    Audio Codec Register List .....            | 173 |
| 1.13.4.    Audio Codec Register Description.....      | 174 |

|                  |                                            |            |
|------------------|--------------------------------------------|------------|
| 1.14.            | LRADC.....                                 | 191        |
| 1.14.1.          | Overview .....                             | 191        |
| 1.14.2.          | LRADC Block Diagram .....                  | 192        |
| 1.14.3.          | LRADC Register List.....                   | 192        |
| 1.14.4.          | LRADC Register Description .....           | 193        |
| 1.15.            | TP .....                                   | 200        |
| 1.15.1.          | Overview .....                             | 200        |
| 1.15.2.          | Typical Application Circuit .....          | 201        |
| 1.15.3.          | TP Clock Tree .....                        | 201        |
| 1.15.4.          | A/D Conversion Time .....                  | 201        |
| 1.15.5.          | Principle of Operation .....               | 203        |
| 1.15.6.          | TP Register List.....                      | 208        |
| 1.15.7.          | TP Register Description .....              | 209        |
| 1.16.            | Security System.....                       | 219        |
| 1.16.1.          | Overview .....                             | 219        |
| 1.16.2.          | Security System Block Diagram .....        | 220        |
| 1.16.3.          | Security System Register List.....         | 220        |
| 1.16.4.          | Security System Register Description ..... | 221        |
| 1.17.            | Security JTAG .....                        | 229        |
| 1.17.1.          | Overview .....                             | 229        |
| 1.17.2.          | Security JTAG Register List.....           | 230        |
| 1.17.3.          | Security JTAG Register Description .....   | 230        |
| 1.18.            | Security ID .....                          | 232        |
| 1.18.1.          | Overview .....                             | 232        |
| 1.18.2.          | SID Block Diagram.....                     | 233        |
| 1.18.3.          | Security System Register List.....         | 233        |
| 1.18.4.          | Security ID Register Description .....     | 234        |
| 1.19.            | Port Controller .....                      | 240        |
| 1.19.1.          | Port Description .....                     | 240        |
| 1.19.2.          | Port Configuration Table .....             | 241        |
| 1.19.3.          | Port Register List .....                   | 247        |
| 1.19.4.          | Port Register Description .....            | 248        |
| <b>Chapter 2</b> | <b>Memory.....</b>                         | <b>307</b> |
| 2.1.             | DRAM .....                                 | 308        |
| 2.1.1.           | Overview .....                             | 308        |
| 2.2.             | NAND Flash.....                            | 309        |
| 2.2.1.           | Overview .....                             | 309        |
| 2.2.2.           | Nand Flash Block Diagram .....             | 310        |
| 2.2.3.           | NFC Timing Diagram.....                    | 311        |
| 2.2.4.           | NFC Operation Guide .....                  | 316        |
| <b>Chapter 3</b> | <b>Graphic .....</b>                       | <b>319</b> |
| 3.1.             | Mixer Processor.....                       | 320        |
| 3.1.1.           | Overview .....                             | 320        |
| 3.1.2.           | Mixer Processor Block Diagram.....         | 321        |
| 3.1.3.           | MP Register List.....                      | 321        |
| 3.1.4.           | MP Register Description .....              | 323        |
| <b>Chapter 4</b> | <b>Image.....</b>                          | <b>363</b> |
| 4.1.             | CSI0.....                                  | 364        |
| 4.1.1.           | Overview .....                             | 364        |
| 4.1.2.           | CSI0 Block Diagram.....                    | 365        |
| 4.1.3.           | CSI0 Description .....                     | 365        |

|                                                |     |
|------------------------------------------------|-----|
| 4.1.4. CSI0 Register List .....                | 368 |
| 4.1.5. CSI0 Register Description.....          | 370 |
| 4.2. CSI1 .....                                | 398 |
| 4.2.1. Overview .....                          | 398 |
| 4.2.2. CSI1 Block Diagram.....                 | 399 |
| 4.2.3. CSI1 Description .....                  | 399 |
| 4.2.4. CSI1 Timing Diagram.....                | 399 |
| 4.2.5. CSI1 Register List .....                | 400 |
| 4.2.6. CSI1 Register Description.....          | 401 |
| <br>Chapter 5 Display .....                    | 413 |
| 5.1. TCON.....                                 | 415 |
| 5.1.1. Overview .....                          | 415 |
| 5.1.2. TCON Block Diagram.....                 | 416 |
| 5.1.3. TCON Register List .....                | 417 |
| 5.1.4. TCON Register Description.....          | 419 |
| 5.2. HDMI.....                                 | 445 |
| 5.2.1. Overview .....                          | 445 |
| 5.2.2. HDMI Block Diagram.....                 | 446 |
| 5.2.3. HDMI Control Register Description.....  | 446 |
| 5.2.4. HDMI Register Description.....          | 448 |
| 5.3. Display Engine Frontend .....             | 486 |
| 5.3.1. Overview .....                          | 486 |
| 5.3.2. DEFE Block Diagram .....                | 487 |
| 5.3.3. DEFE Register List.....                 | 487 |
| 5.3.4. DEFE Register Description .....         | 491 |
| 5.4. Display Engine Backend .....              | 537 |
| 5.4.1. Overview .....                          | 537 |
| 5.4.2. Display Engine Block Diagram.....       | 538 |
| 5.4.3. DEBE Register list.....                 | 538 |
| 5.4.4. DEBE Register Description .....         | 541 |
| 5.5. TV Encoder.....                           | 583 |
| 5.5.1. Overview .....                          | 583 |
| 5.5.2. TV Encoder Block Diagram.....           | 584 |
| 5.5.3. TV Encoder Register List.....           | 585 |
| 5.5.4. TV Encoder Register Description.....    | 586 |
| <br>Chapter 6 Interface .....                  | 612 |
| 6.1. SD3.0.....                                | 613 |
| 6.1.1. Overview .....                          | 613 |
| 6.1.2. SD3.0 Timing Diagram.....               | 613 |
| 6.2. TWI .....                                 | 614 |
| 6.2.1. Overview .....                          | 614 |
| 6.2.2. TWI Controller Timing Diagram.....      | 615 |
| 6.2.3. TWI Controller Register List.....       | 615 |
| 6.2.4. TWI Register Description .....          | 616 |
| 6.2.5. TWI Controller Special Requirement..... | 624 |
| 6.3. SPI .....                                 | 626 |
| 6.3.1. Overview .....                          | 626 |
| 6.3.2. SPI Timing Diagram .....                | 627 |
| 6.3.3. SPI Register List.....                  | 628 |
| 6.3.4. SPI Register Description .....          | 629 |
| 6.3.5. SPI Special Requirement .....           | 643 |
| 6.4. UART .....                                | 644 |

|         |                                                    |     |
|---------|----------------------------------------------------|-----|
| 6.4.1.  | Overview .....                                     | 644 |
| 6.4.2.  | UART Timing Diagram .....                          | 645 |
| 6.4.3.  | UART Register List.....                            | 645 |
| 6.4.4.  | UART Register Description .....                    | 646 |
| 6.4.5.  | UART Special Requirement .....                     | 664 |
| 6.5.    | PS2 .....                                          | 667 |
| 6.5.1.  | Overview .....                                     | 667 |
| 6.5.2.  | PS2 Block Diagram .....                            | 668 |
| 6.5.3.  | PS2 Timing Diagram .....                           | 668 |
| 6.5.4.  | PS2 Register List.....                             | 670 |
| 6.5.5.  | PS2 Register Description .....                     | 670 |
| 6.5.6.  | PS2 Special Requirements .....                     | 678 |
| 6.6.    | IR .....                                           | 679 |
| 6.6.1.  | Overview .....                                     | 679 |
| 6.6.2.  | IR Block Diagram .....                             | 680 |
| 6.6.3.  | IR Register List.....                              | 680 |
| 6.6.4.  | IR Register Description .....                      | 681 |
| 6.7.    | USB OTG.....                                       | 694 |
| 6.7.1.  | Overview .....                                     | 694 |
| 6.7.2.  | USB OTG Timing Diagram.....                        | 694 |
| 6.8.    | USB Host.....                                      | 695 |
| 6.8.1.  | Overview .....                                     | 695 |
| 6.8.2.  | USB Host Block Diagram.....                        | 696 |
| 6.8.3.  | USB Host Timing Diagram .....                      | 696 |
| 6.8.4.  | USB Host Register List .....                       | 696 |
| 6.8.5.  | EHCI Register Description .....                    | 697 |
| 6.8.6.  | OHCI Register List .....                           | 716 |
| 6.8.7.  | OHCI Register Description .....                    | 717 |
| 6.8.8.  | USB Host Special Requirement .....                 | 734 |
| 6.9.    | Digital Audio Interface .....                      | 735 |
| 6.9.1.  | Overview .....                                     | 735 |
| 6.9.2.  | Digital Audio Interface Block Diagram.....         | 736 |
| 6.9.3.  | Digital Audio Interface Timing Diagram.....        | 736 |
| 6.9.4.  | Digital Audio Interface Register List .....        | 738 |
| 6.9.5.  | Digital Audio Interface Register Description ..... | 738 |
| 6.9.6.  | Digital Audio Interface Special Requirement.....   | 755 |
| 6.10.   | AC97 Interface.....                                | 758 |
| 6.10.1. | Overview .....                                     | 758 |
| 6.10.2. | AC97 Block diagram .....                           | 759 |
| 6.10.3. | AC97 Interface Clock Tree.....                     | 760 |
| 6.10.4. | AC Link Frame Format.....                          | 760 |
| 6.10.5. | AC97 Interface Timing Diagram.....                 | 761 |
| 6.10.6. | AC97 Interface Register List.....                  | 765 |
| 6.10.7. | AC97 Interface Register Description .....          | 766 |
| 6.10.8. | AC97 Interface Special Requirement .....           | 776 |
| 6.11.   | EMAC .....                                         | 777 |
| 6.11.1. | Overview .....                                     | 777 |
| 6.11.2. | EMAC Block Diagram .....                           | 778 |
| 6.11.3. | EMAC Operation Diagram .....                       | 779 |
| 6.12.   | GMAC .....                                         | 782 |
| 6.12.1. | Overview .....                                     | 782 |
| 6.12.2. | GMAC Block Diagram.....                            | 783 |
| 6.13.   | Transport Stream.....                              | 784 |
| 6.13.1. | Overview .....                                     | 784 |

|                  |                                                 |     |
|------------------|-------------------------------------------------|-----|
| 6.13.2.          | Transport Stream Block Diagram.....             | 785 |
| 6.13.3.          | Transport Stream Controller Register List ..... | 785 |
| 6.13.4.          | Transport Stream Register Description.....      | 787 |
| 6.13.5.          | Transport Stream Clock Requirement .....        | 806 |
| 6.14.            | Smart Card Reader .....                         | 807 |
| 6.14.1.          | Overview .....                                  | 807 |
| 6.14.2.          | Smart Card Reader Block Diagram .....           | 808 |
| 6.14.3.          | Smart Card Reader Timing Diagram .....          | 808 |
| 6.14.4.          | Smart Card Reader Register List .....           | 808 |
| 6.14.5.          | Smart Card Reader Register Description .....    | 809 |
| 6.14.7.          | SCIO Pad Configuration .....                    | 821 |
| 6.15.            | SATA Host.....                                  | 822 |
| 6.15.1.          | Overview .....                                  | 822 |
| 6.15.2.          | SATA_AHCI Timing Diagram .....                  | 822 |
| 6.16.            | CAN .....                                       | 823 |
| 6.16.1.          | Overview .....                                  | 823 |
| 6.16.2.          | CAN System Block Diagram .....                  | 824 |
| 6.16.3.          | CAN Bit Time Configuration.....                 | 824 |
| 6.17.            | Keypad.....                                     | 825 |
| 6.17.1.          | Overview .....                                  | 825 |
| 6.17.2.          | Keypad Interface Register List.....             | 826 |
| 6.17.3.          | Keypad Interface Register Description .....     | 826 |
| 6.17.4.          | Keypad Interface Special Requirement .....      | 829 |
| Appendix A ..... |                                                 | 830 |

# Chapter 1 System

This part details the A20 system construction from following aspects:

- OVERVIEW
- A20 BLOCK DIAGRAM
- MEMORY MAPPING
- CPU CONFIGURATION
- CCU
- BOOT SYSTEM
- SYSTEM CONTROL
- PWM
- TIMER
- HIGH SPEED TIMER
- GIC
- DMA
- AUDIO CODEC
- LRADC
- TP
- SECURITY SYSTEM
- SECURITY JTAG
- SECURITY ID
- PORT CONTROLLER

## 1.1. Overview

Allwinner A20 processor is a dual-core ARM Cortex-A7 mobile application solution designed for tablet and smart TV applications.

A20 processor is based on a dual-core ARM Cortex-A7 CPU architecture, which is the most energy efficient application processor from ARM so far and incorporates all the features of Cortex-A15. It also integrates the powerful ARM Mali400 MP2 GPU, delivering a reliable system performance as well as good game compatibility. Besides, A20 supports 2160p video decoding and H.264 HP 1080p video encoding.

Additionally, A20 processor features a wide range of interfaces and connectivity, including 4-CH CVBS in, 4-CH CVBS out, HDMI with HDCP, VGA, LVDS/RGB LCD, SATA, USB, and GMAC, etc. More importantly, A20 processor is pin-compatible with its predecessor A10, which greatly simplifies the product design process and makes the upgrade of a design much easier.

The A20 features are listed below:

### Dual-Core CPU

- Dual Cortex-A7
  - ARMv7 ISA standard ARM instruction set
  - Thumb-2
  - Jazeller RCT
  - NEON Advanced SIMD
  - VFPv4 floating point
  - Hardware virtualization support
  - Large Physical Address Extensions(LPAE)
  - JTAG debug
  - One general timer for individual CPU
  - 32KB Instruction and 32KB Data L1 cache for individual CPU

### Graphic Engine

- 3D
  - Mali400 MP2 GPU
  - Support OpenGL ES 2.0 / OpenVG 1.1 standard
- 2D
  - Support BLT and ROP2/3/4
  - Support 90° /180° /270° rotation
  - Support mirror/ alpha (plane and pixel alpha) /color key

- Format conversion: ARGB 8888/4444/1555, RGB565, MONO 1/2/4/8bpp, Palette 1/2/4/8bpp (input only), YUV 444/422/420

## Memory

- Internal BRAM

- Support system boot from NAND Flash, SPI Nor Flash (SPI0), SD Card/TF card (SDC0/2)
- Support system code download through USB OTG (USB0)

- SDRAM

- Support DDR3/DDR3L/DDR2
- Support 32-bit bus width
- Support 2GB address space

- NAND Flash

- Comply to ONFI 2.3 and Toggle 1.0
- Support 64-bit ECC per 512 bytes or 1024 bytes
- Support 8bits data bus width
- Support 1.8V/3.3V signal voltage
- Support 1K/2K/4K/8K/16K page size
- Support up to 8 CE and 2 RB
- Support system boot from NAND flash
- Support SLC/MLC NAND and EF-NAND
- Support SDR/DDR NAND interface

- SD/MMC Interface

- Comply with eMMC standard specification V4.3
- Comply with SD physical layer specification V3.0
- Comply with SDIO card specification V2.0
- Support 1/4/8 bits bus width
- Support HS/DS/SDR12/SDR25 bus mode
- Support eMMC mandatory and alternative boot operations
- Support four independent SD/MMC/SDIO controllers
- Support SDSC/SDHC/SDXC/MMC/ RS-MMC card
- Support eMMC/iNand Flash
- Support 1GB/2GB/4GB/8GB/16GB/32GB/64GB /128GB SD/MMC card
- Support SDIO interrupt detection
- Support descriptor-based internal DMA controller for efficient scatter and gather operations

## System Resources

- **Timer**

- 6 timers: clock source can be switched over 24M/32K for all timers, and external signals can be used as clock source for Timer4/5
- Two 33-bit AVS counters
- Watchdog to generate reset signal or interrupt
- Real time counter for second, minute, hour, day, month, and year

- **High Speed Timer**

- 4 channels
- Clock source is fixed to AHB, and the pre-scale ranges from 1 to 16
- 56-bit counter that can be separated to 24-bit high register and 32-bit low register

- **DMA**

- 16 channels
- Support data width of 8/32 bits
- Support linear and IO address modes

- **CCU**

- 8PLLs, a main 24MHz oscillator, an on-chip RC oscillator and a 32768Hz oscillator (optional)

- **GIC**

- Support 16 SGIs, 16 PPIs, and 128 SPIs
- Support ARM architecture security extensions
- Support ARM architecture virtualization extensions
- Support uniprocessor and multiprocessor environments

## Video Engine (Phoenix 3.0)

- Video Decoding

- Support picture size up to 3840x2160
- Support decoding speed up to 1080p@60fps
- Supported formats: Mpeg1/2, Mpeg4 SP/ASP GMC, H.263 including Sorenson Spark, H.264 BP/MP/HP, VP6/8, AVS jizun, Jpeg/Mjpeg, etc.

- Video Encoding

- H.264 HP up to 1080p@30fps
- Jpeg baseline: picture size up to 4080x4080
- Alpha blending
- Thumb generation
- 4x2 scaling ratio from 1/16 to 64 arbitrary non-integer ratio

## Display Engine

- Four moveable and size-adjustable layers, each layer size up to 8192x8192 pixels
- Ultra-Scaling engine
  - 8-tap scale filter in horizontal and 4 tap in vertical
  - Source image size from 8x4 to 8192x8192 resolution and destination image size from 8x4 to 8192x8192 resolution
- Support multiple image input formats
  - mono 1/2/4/8 bpp
  - palette 1/2/4/8 bpp
  - 6/24/32 bpp color
  - YUV444/420/422/411
- Support alpha blending/color key/gamma/hardware cursor/sprite
- Output color correction: luminance/hue/saturation, etc
- Support de-interlace
- Video enhancement: lum peaking/DCTi/black and white level extension
- 3D input/output format conversion and display

## Video Output

- HDMI 1.4 transmitter with HDCP
- LVDS/Sync RGB/CPU LCD interface up to 1920x1200 resolution
- Support 4-channel CVBS, or 2-channel S-video, or 1-channel YPbPr/VGA (YPbPr/VGA up to 1080p)
- Support two-channel independent display

## Video Input

- Support TV decoder: 4-ch analog CVBS or 1-ch YPbPr(480i/576i/480p/576p) signal input
- Dual CMOS sensor parallel interfaces that support YUV format only
  - CSI0 up to 1080p@30fps
  - CSI1 up to 720p@30fps
- Support BT656 interface
- Support 24-bit YUV444/RGB interface

## Analog Audio Output

- Stereo audio DAC
- Stereo capless headphone drivers
  - Up to 100dB SNR during DAC playback
  - Support 8KHz~192KHz DAC sample rate
- One low-noise analog microphone bias
- Dedicated headphone outputs

- Two mixers to meet different requirements
  - Output mixer for LINEINL/R, FMINL/R, MIC1/2 and Stereo DAC output
  - ADC record mixer for LINEINL/R, FMINL/R, MIC1/2 and Stereo DAC output

## Analog Audio Input

- Support four analog audio inputs
  - Two microphone inputs
  - Differential or stereo line-in input
  - Stereo FM-in input
- Stereo audio ADC
  - 96dBA SNR
  - Support 8KHz ~ 48KHz ADC sample rate

## RTP

- 12-bit SAR ADC
- Dual touch detection
- Sampling frequency up to 2MHz

## Connectivity

### USB2.0 OTG

- Support High-Speed (HS, 480-Mbps), Full-Speed (FS, 12-Mbps), and Low-Speed (LS, 1.5-Mbps) in Host mode
- Support High-Speed (HS, 480-Mbps), Full-Speed (FS, 12-Mbps) in Device mode
- Support up to 5 user-configurable endpoints for Bulk , Isochronous, Control and Interrupt

### USB EHCI/OHCI

- Two EHCI/OHCI-compliant hosts

### EMAC

- Support 10/100Mbps MII data transfer rate

### GMAC

- Comply with the IEEE 802.3-2002 standard
- Programmable frame length to support Standard or Jumbo Ethernet frames with size up to 16KB
- Support 10/100/1000Mbps data transfer rates RGMII interface to communicate with an external Gigabit PHY
- Support 10/100Mbps MII PHY interface

### Digital Audio In/Out

- One I2S compliant audio interface, supporting 8-channel and 2-channel input

- One PCM, supporting linear sample(8-bit or 16-bit), 8-bit u-law and A-law companded sample
- One AC97 audio codec, supporting 2-channel and 6-channel audio data output

### **Transport Stream Controller**

- Support both SPI and SSI
- Speed up to 150Mbps for both SPI and SSI
- Support 32-channel PID filter
- Support hardware PCR packet detect

### **Open-Drain TWI**

- Up to 5 TWIs compliant with TWI protocol

### **Smart Card Reader**

- One smart card reader controller supporting ISO/IEC 7816-3 and EMV2000 specifications
- Support synchronous and any other non-ISO 7816 and non-EMV cards

### **SPI**

- Master/Slave configurable
- Up to 4 independent SPI controllers: SPI0 with one CS signal for system boot, SPI1/2/3 each with two CS signals

### **UART**

- Up to 8 UART controllers:UART0 with two wires for debug tools, UART1 with 8 wires, UART2/3 each with 4 wires, and others each with 2 wires

### **PS2**

- Two PS2 compliant to IBM PS2 and AT-compatible keyboard and mouse interface
- Dual-role controller: a PS2 host or a PS2 device

### **IR**

- Two IR controllers supporting CIR, MIR and FIR modes

### **SATA**

- One SATA Host controller
- Support SATA 1.5Gb/s and SATA 3.0Gb/s
- Comply with SATA spec 2.6
- Support external SATA(eSATA)

### **CAN**

- One CAN bus controller
- Support the CAN2.0 A/B protocol specification
- Programmable data rate up to 1Mbps

### Keypad

- One keypad matrix interface up to 8 rows and 8 columns
- Interrupt for key press or key release
- Internal debouncing filter to prevent switching noises

### LRADC

- 6-bit resolution
- Voltage input range between 0V to 2V

### PWM

- 2 PWM outputs
- Support cycle mode and pulse mode
- The pre-scale is from 1 to 64

## Security System

- Security System
  - Support AES, DES, 3DES, SHA-1, MD5
  - Support ECB/CBC/CNT modes for AES/DES/3DES
  - 128-bit, 192-bit and 256-bit key size for AES
  - 160-bit hardware PRNG with 192-bit seed
- Security JTAG

## Power Management

- Flexible PLL clock generator and OSC for 32KHz
- Flexible clock gate
- Support DVFS for CPU frequency and voltage adjustment
- Support standby mode (only DDR+RTC-Domain power exist)

## Package

- FBGA 441 balls, 0.80mm ball pitch, 19x19x1.4mm

## 1.2. A20 Block Diagram



## 1.3. Memory Mapping

| <b>Module</b>    | <b>Address</b>            | <b>Size(Bytes)</b> |
|------------------|---------------------------|--------------------|
| 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 B(Secure)   | 0x0002 0000---0x0002 FFFF | 64K                |
| SRAM Controller  | 0x01C0 0000---0x01C0 0FFF | 4K                 |
| DRAM Controller  | 0x01C0 1000---0x01C0 1FFF | 4K                 |
| DMA              | 0x01C0 2000---0x01C0 2FFF | 4K                 |
| NAND Flash       | 0x01C0 3000---0x01C0 3FFF | 4K                 |
| Transport Stream | 0x01C0 4000---0x01C0 4FFF | 4K                 |
| SPI 0            | 0x01C0 5000---0x01C0 5FFF | 4K                 |
| SPI 1            | 0x01C0 6000---0x01C0 6FFF | 4K                 |
| Memory Stick     | 0x01C0 7000---0x01C0 7FFF | 4K                 |
| TVD              | 0x01C0 8000---0x01C0 8FFF | 4K                 |
| CSI 0            | 0x01C0 9000---0x01C0 9FFF | 4K                 |
| TVE 0            | 0x01C0 A000---0x01C0 AFFF | 4K                 |
| EMAC             | 0x01C0 B000---0x01C0 BFFF | 4K                 |
| LCD 0            | 0x01C0 C000---0x01C0 CFFF | 4K                 |
| LCD 1            | 0x01C0 D000---0x01C0 DFFF | 4K                 |
| Video Engine     | 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                 |
| SD/MMC 3         | 0x01C1 2000---0x01C1 2FFF | 4K                 |

| <b>Module</b>   | <b>Address</b>            | <b>Size(Bytes)</b> |
|-----------------|---------------------------|--------------------|
| USB 0           | 0x01C1 3000---0x01C1 3FFF | 4K                 |
| USB 1           | 0x01C1 4000---0x01C1 4FFF | 4K                 |
| Security System | 0x01C1 5000---0x01C1 5FFF | 4K                 |
| HDMI            | 0x01C1 6000---0x01C1 6FFF | 4K                 |
| SPI 2           | 0x01C1 7000---0x01C1 7FFF | 4K                 |
| SATA            | 0x01C1 8000---0x01C1 8FFF | 4K                 |
| PATA            | 0x01C1 9000---0x01C1 9FFF | 4K                 |
| ACE             | 0x01C1 A000---0x01C1 AFFF | 4K                 |
| TVE 1           | 0x01C1 B000---0x01C1 BFFF | 4K                 |
| USB 2           | 0x01C1 C000---0x01C1 CFFF | 4K                 |
| CSI 1           | 0x01C1 D000---0x01C1 DFFF | 4K                 |
|                 | 0x01C1 E000---0x01C1 EFFF | 4K                 |
| SPI3            | 0x01C1 F000---0x01C1 FFFF | 4K                 |
| CCU             | 0x01C2 0000---0x01C2 03FF | 1K                 |
| Interrupt       | 0x01C2 0400---0x01C2 07FF | 1K                 |
| PIO             | 0x01C2 0800---0x01C2 0BFF | 1K                 |
| Timer           | 0x01C2 0C00---0x01C2 0FFF | 1K                 |
| SPDIF           | 0x01C2 1000---0x01C2 13FF | 1K                 |
| AC97            | 0x01C2 1400---0x01C2 17FF | 1K                 |
| IR0             | 0x01C2 1800---0x01C2 1BFF | 1K                 |
| IR 1            | 0x01C2 1C00---0x01C2 1FFF | 1K                 |
| IIS-1           | 0x01C2 2000---0x01C2 23FF | 1K                 |
| IIS-0           | 0x01C2 2400---0x01C2 27FF | 1K                 |
| LRADC 0/1       | 0x01C2 2800---0x01C2 2BFF | 1K                 |
| AD/DA           | 0x01C2 2C00---0x01C2 2FFF | 1K                 |
| Keypad          | 0x01C2 3000---0x01C2 33FF | 1K                 |
|                 | 0x01C2 3400---0x01C2 37FF | 1K                 |
| SID             | 0x01C2 3800---0x01C2 3BFF | 1K                 |
| SJTAG           | 0x01C2 3C00---0x01C2 3FFF | 1K                 |
|                 | 0x01C2 4000---0x01C2 43FF | 1K                 |
| IIS-2           | 0x01C2 4400---0x01C2 47FF | 1K                 |
|                 | 0x01C2 4800---0x01C2 4BFF | 1K                 |

| <b>Module</b>     | <b>Address</b>            | <b>Size(Bytes)</b> |
|-------------------|---------------------------|--------------------|
|                   | 0x01C2 4C00---0x01C2 4FFF | 1K                 |
| TP                | 0x01C2 5000---0x01C2 53FF | 1K                 |
| PMU               | 0x01C2 5400---0x01C2 57FF | 1K                 |
|                   | 0x01C2 5800---0x01C2 5BFF | 1K                 |
| CPU Configuration | 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                 |
| UART 4            | 0x01C2 9000---0x01C2 93FF | 1K                 |
| UART 5            | 0x01C2 9400---0x01C2 97FF | 1K                 |
| UART 6            | 0x01C2 9800---0x01C2 9BFF | 1K                 |
| UART 7            | 0x01C2 9C00---0x01C2 9FFF | 1K                 |
| PS2-0             | 0x01C2 A000---0x01C2 A3FF | 1K                 |
| PS2-1             | 0x01C2 A400---0x01C2 A7FF | 1K                 |
| /                 | 0x01C2 A800---0x01C2 ABFF | 1K                 |
| TWI 0             | 0x01C2 AC00---0x01C2 AFFF | 1K                 |
| TWI 1             | 0x01C2 B000---0x01C2 B3FF | 1K                 |
| TWI 2             | 0x01C2 B400---0x01C2 B7FF | 1K                 |
| TWI 3             | 0x01C2 B800---0x01C2 BBFF | 1K                 |
| CAN               | 0x01C2 BC00---0x01C2 BFFF | 1K                 |
| TWI 4             | 0x01C2 C000---0x01C2 C3FF | 1K                 |
| Smart Card Reader | 0x01C2 C400---0x01C2 C7FF | 1K                 |
| GPS               | 0x01C3 0000---0x01C3 FFFF | 64K                |

| <b>Module</b>          | <b>Address</b>            | <b>Size(Bytes)</b> |
|------------------------|---------------------------|--------------------|
| Mali400                | 0x01C4 0000---0x01C4 FFFF | 64K                |
| GMAC                   | 0x01C5 0000---0x01C5 FFFF | 64K                |
| HSTIMER                | 0x01C6 0000---0x01C6 0FFF | 4K                 |
| GIC Registers          | 0x01C8 0000---0x01C8 7FFF | 32K                |
| HDMI1                  | 0x01CE 0000---0x01CF FFFF | 128K               |
| CPUBIST                | 0x3F50 1000---0x3F50 1FFF | 4K                 |
| SRAM C                 | 0x01D0 0000---0x01DF FFFF | Module SRAM        |
| DE_FE0                 | 0x01E0 0000---0x01E1 FFFF | 128K               |
| DE_FE1                 | 0x01E2 0000---0x01E3 FFFF | 128K               |
| DE_BE0                 | 0x01E6 0000---0x01E7 FFFF | 128K               |
| DE_BE1                 | 0x01E4 0000---0x01E5 FFFF | 128K               |
| MP                     | 0x01E8 0000---0x01E9 FFFF | 128K               |
| AVG                    | 0x01EA 0000---0x01EB FFFF | 128K               |
| CoreSight Debug Module | 0x3F50 0000---0x3F50 FFFF | 64K                |
| DDR-II/DDR-III         | 0x4000 0000---0xBFFF FFFF | 2G                 |
| BROM                   | 0xFFFF 0000—0xFFFF 7FFF   | 32K                |

## 1.4. CPU Configuration

### 1.4.1. Overview

The CPU configuration module features:

- Software reset control for each individual CPU
- CPU configuration for each individual CPU
- Three 64-bit idle counters and two 64-bit common counters

### 1.4.2. CPU Configuration Register List

| Module Name       | Base Address |
|-------------------|--------------|
| CPU Configuration | 0x01C25C00   |

| Register Name         | Offset | Description                     |
|-----------------------|--------|---------------------------------|
| CPU0_RST_CTRL         | 0x0040 | CPU0 Reset Control              |
| CPU0_CTRL_REG         | 0x0044 | CPU0 Control Register           |
| CPU0_STATUS_REG       | 0x0048 | CPU0 Status Register            |
| CPU1_RST_CTRL         | 0x0080 | CPU1 Reset Control              |
| CPU1_CTRL_REG         | 0x0084 | CPU1 Control Register           |
| CPU1_STATUS_REG       | 0x0088 | CPU1 Status Register            |
| GENER_CTRL_REG        | 0x0184 | General Control Register        |
| EVENT_IN              | 0x0190 | Event Input Register            |
| PRIVATE_REG           | 0x01A4 | Private Register                |
| IDLE_CNT0_LOW_REG     | 0x0200 | Idle Counter 0 Low Register     |
| IDLE_CNT0_HIGH_REG    | 0x0204 | Idle Counter 0 High Register    |
| IDLE_CNT0_CTRL_REG    | 0x0208 | Idle Counter 0 Control Register |
| IDLE_CNT1_LOW_REG     | 0x0210 | Idle Counter 1 Low Register     |
| IDLE_CNT1_HIGH_REG    | 0x0214 | Idle Counter 1 High Register    |
| IDLE_CNT1_CTRL_REG    | 0x0218 | Idle Counter 1 Control Register |
| OSC24M_CNT64_CTRL_REG | 0x0280 | 64-bit Counter Control Register |
| OSC24M_CNT64_LOW_REG  | 0x0284 | 64-bit Counter Low Register     |
| OSC24M_CNT64_HIGH_REG | 0x0288 | 64-bit Counter High Register    |
| LOSC_CNT64_CTRL_REG   | 0x0290 | 64-bit Counter Control Register |
| LOSC_CNT64_LOW_REG    | 0x0294 | 64-bit Counter Low Register     |
| LOSC_CNT64_HIGH_REG   | 0x0298 | 64-bit Counter High Register    |

### 1.4.3. CPUCFG Register Description

#### 1.4.3.1. CPU0 RESET CONTROL(DEFAULT: 0X00000003)

| Offset: 0x40 |                |             | Register Name: CPU0_RST_CTRL                                                                                                                                                                                                                                                           |
|--------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                            |
| 31:2         | /              | /           | /.                                                                                                                                                                                                                                                                                     |
| 1            | R/W            | 0x1         | CPU0_CORE_RST.<br>These are the primary reset signals which initialize the processor logic in the processor power domains, not including the debug, breakpoint and watchpoint logic.<br>0: assert<br>1: de-assert.                                                                     |
| 0            | R/W            | 0x1         | CPU0_RESET.<br>CPU0 Reset Assert.<br>These power-on reset signals initialize all the processor logic, including CPU Debug, and breakpoint and watch point logic in the processor power domains. They do not reset debug logic in the debug power domain.<br>0: assert<br>1: de-assert. |

#### 1.4.3.2. CPU0 CONTROL REGISTER(DEFAULT :0X00000000)

| Offset: 0x44 |                |             | Register Name: CPU0_CTRL_REG                                                                           |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                            |
| 31:1         | /              | /           | /                                                                                                      |
| 0            | R/W            | 0x0         | CPU0_CP15_WRITE_DISABLE.<br>Disable write access to certain CP15 registers.<br>0: enable<br>1: disable |

#### 1.4.3.3. CPU0 STATUS REGISTER(DEFAULT : 0X00000000)

| Offset: 0x48 |                |             | Register Name: CPU0_STATUS                                                                                                                                           |
|--------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                          |
| 31:3         | /              | /           | /.                                                                                                                                                                   |
| 2            | R              | 0x0         | <p>STANDBYWFI.</p> <p>Indicates if the processor is in WFI standby mode:</p> <p>0: Processor not in WFI standby mode.</p> <p>1: Processor in WFI standby mode</p>    |
| 1            | R              | 0x0         | <p>STANDBYWFE.</p> <p>Indicates if the processor is in the WFE standby mode:</p> <p>0: Processor not in WFE standby mode</p> <p>1: Processor in WFE standby mode</p> |
| 0            | R              | 0x0         | <p>SMP_AMP</p> <p>0: AMP mode</p> <p>1: SMP mode</p>                                                                                                                 |

#### 1.4.3.4. CPU1 RESET CONTROL(DEFAULT: 0X00000000)

| Offset: 0x80 |                |             | Register Name: CPU1_RST_CTRL                                                                                                                                                                                                                                                                                  |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                   |
| 31:2         | /              | /           | /.                                                                                                                                                                                                                                                                                                            |
| 1            | R/W            | 0x0         | <p>CPU1_CORE_RST.</p> <p>These are the primary reset signals which initialize the processor logic in the processor power domains, not including the debug, breakpoint and watchpoint logic.</p> <p>0: assert</p> <p>1: de-assert.</p>                                                                         |
| 0            | R/W            | 0x0         | <p>CPU1_RESET.</p> <p>CPU1 Reset Assert.</p> <p>These power-on reset signals initialize all the processor logic, including CPU Debug, and breakpoint and watch point logic in the processor power domains. They do not reset debug logic in the debug power domain.</p> <p>0: assert</p> <p>1: de-assert.</p> |

#### 1.4.3.5. CPU1 CONTROL REGISTER(DEFAULT :0X00000000)

| Offset: 0x84 |                |             | Register Name: CPU1_CTRL_REG                                                                           |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                            |
| 31:1         | /              | /           | /                                                                                                      |
| 0            | R/W            | 0x0         | CPU1_CP15_WRITE_DISABLE.<br>Disable write access to certain CP15 registers.<br>0: enable<br>1: disable |

#### 1.4.3.6. CPU1 STATUS REGISTER(DEFAULT : 0X00000000)

| Offset: 0x88 |                |             | Register Name: CPU1_STATUS                                                                                                                        |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                       |
| 31:3         | /              | /           | /.                                                                                                                                                |
| 2            | R              | 0x0         | STANDBYWFI.<br>Indicates if the processor is in WFI standby mode:<br>0: Processor not in WFI standby mode.<br>1: Processor in WFI standby mode    |
| 1            | R              | 0x0         | STANDBYWFE.<br>Indicates if the processor is in the WFE standby mode:<br>0: Processor not in WFE standby mode<br>1: Processor in WFE standby mode |
| 0            | R              | 0x0         | SMP_AMP<br>0: AMP mode<br>1: SMP mode                                                                                                             |

#### 1.4.3.7. GENERAL CONTROL REGISTER(DEFAULT :0X00000020)

| Offset: 0x184 |                |             | Register Name: GENER_CTRL_REG |
|---------------|----------------|-------------|-------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                   |
| 31:9          | /              | /           | /.                            |
| 8             | R/W            | 0x0         | CFGSDISABLE.                  |

| Offset: 0x184 |                |             | Register Name: GENER_CTRL_REG                                                                                                                                   |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                     |
|               |                |             | Disables write access to some secure GIC registers.                                                                                                             |
| 7:6           | /              | /           | /                                                                                                                                                               |
| 5             | R/W            | 0x1         | L2_RST.<br>L2 Reset.(SCU global reset)<br>0: Apply reset to shared L2 memory system controller.<br>1: Do not apply reset to shared L2 memory system controller. |
| 4             | R/W            | 0x0         | L2_RST_DISABLE.<br>Disable automatic L2 cache invalidate at reset:<br>0: L2 cache is reset by hardware.<br>1: L2 cache is not reset by hardware.                |
| 3:2           | /              | /           | /                                                                                                                                                               |
| 1:0           | R/W            | 0x0         | L1_RST_DISABLE.<br>L1 Reset Disable[1:0].<br>0: L1 cache is reset by hardware.<br>1: L1 cache is not reset by hardware.                                         |

#### 1.4.3.8. EVENT INPUT REGISTER(DEFAULT : 0X00000000)

| Offset: 0x190 |                |             | Register Name: EVENT_IN                                                 |
|---------------|----------------|-------------|-------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                             |
| 31:1          | /              | /           | /.                                                                      |
| 0             | R/W            | 0x0         | EVENT_IN.<br>Event input that can wake-up CPU0/1 from WFE standby mode. |

#### 1.4.3.9. PRIVATE REGISTER (DEFAULT: 0X00000000)

| Offset: 0x1A4 |                |             | Register Name: PRIVATE_REG |
|---------------|----------------|-------------|----------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                |
| 31:0          | R/W            | 0x0         |                            |

#### 1.4.3.10. IDLE COUNTER 0 LOW REGISTER (DEFAULT: 0X00000000)

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

#### 1.4.3.11. IDLE COUNTER 0 HIGH REGISTER (DEFAULT: 0X00000000)

| Offset: 0x204 |                |             | Register Name: IDLE_CNT0_HIGH_REG                                                                                                             |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                   |
| 31:0          | R/W            | 0x0         | <p>IDLE_CNT0_HI.<br/>Idle Counter 0 [63:32].<br/>Any write to this register will clear this register and the idle counter 0 low register.</p> |

#### 1.4.3.12. IDLE COUNTER 0 CONTROL REGISTER (DEFAULT: 0X00000000)

| Offset: 0x208 |                |             | Register Name: IDLE_CNT0_CTRL_REG                                                                                                                                                         |
|---------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                               |
| 31:3          | /              | /           | /                                                                                                                                                                                         |
| 2             | R/W            | 0x0         | <p>IDLE_CNT_EN.<br/>Idle counter enable.<br/>0: disable<br/>1: enable.<br/>Note: Idle Counter 0 is used for CPU0</p>                                                                      |
| 1             | R/W            | 0x0         | <p>IDLE_RL_EN.<br/>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.</p> |
| 0             | R/W            | 0x0         | IDLE_CNT_CLR_EN.                                                                                                                                                                          |

| Offset: 0x208 |                |             | Register Name: IDLE_CNT0_CTRL_REG                                                                                                                     |
|---------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                           |
|               |                |             | 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. |

#### 1.4.3.13. IDLE COUNTER 1 LOW REGISTER (DEFAULT: 0X00000000)

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

#### 1.4.3.14. IDLE COUNTER 1 HIGH REGISTER (DEFAULT: 0X00000000)

| Offset: 0x214 |                |             | Register Name: IDLE_CNT1_HIGH_REG                                                                                                   |
|---------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                         |
| 31:0          | R/W            | 0x0         | IDLE_CNT1_HI.<br>Idle Counter 1[63:32].<br>Any write to this register will clear this register and the idle counter 1 low register. |

#### 1.4.3.15. IDLE COUNTER 1 CONTROL REGISTER (DEFAULT: 0X00000000)

| Offset: 0x218 |                |             | Register Name: IDLE_CNT1_CTRL_REG    |
|---------------|----------------|-------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                          |
| 31:3          | /              | /           | /                                    |
| 2             | R/W            | 0x0         | IDLE_CNT_EN.<br>Idle counter enable. |

| Offset: 0x218 |                |             | Register Name: IDLE_CNT1_CTRL_REG                                                                                                                                                |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                      |
|               |                |             | 0: disable<br>1: enable.<br>Note: Idle Counter 1 is used for CPU1                                                                                                                |
| 1             | R/W            | 0x0         | IDLE_RL_EN.<br>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         | IDLE_CNT_CLR_EN.<br>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.        |

#### 1.4.3.16. OSC24M 64-BIT COUNTER CONTROL REGISTER (DEFAULT: 0X00000000)

| Offset: 0x280 |                |             | Register Name: OSC24M_CNT64_CTRL_REG                                                                                                                                                  |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                           |
| 31:5          | /              | /           | /.                                                                                                                                                                                    |
| 4             | R/W            | 0x0         | CNT64_SYNCH<br>Wite 1 then write 0 (a high pulse) to force the 64-bit system counter synchronize the OSC24M 64-bit counter.                                                           |
| 3             | /              | /           | /                                                                                                                                                                                     |
| 2             | R/W            | 0x0         | CNT64_CLK_SRC_SEL.<br>64-bit Counter Clock Source Select.<br>0: OSC24M<br>1: /                                                                                                        |
| 1             | R/W            | 0x0         | CNT64_RL_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         | CNT64_CLR_EN.<br>64-bit Counter Clear Enable.<br>0: no effect, 1: to clear the 64-bit Counter Low/Hi registers and                                                                    |

| Offset: 0x280 |                |             | Register Name: OSC24M_CNT64_CTRL_REG                    |
|---------------|----------------|-------------|---------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                             |
|               |                |             | it will change to zero after the registers are cleared. |

Note: This 64-bit counter will start to count as soon as the System Power On finishes.

#### 1.4.3.17. OSC24M 64-BIT COUNTER LOW REGISTER (DEFAULT: 0X00000000)

| Offset: 0x284 |                |             | Register Name: OSC24M_CNT64_LOW_REG |
|---------------|----------------|-------------|-------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                         |
| 31:0          | R/W            | 0x0         | CNT64_LO.<br>64-bit Counter [31:0]. |

#### 1.4.3.18. OSC24M 64-BIT COUNTER HIGH REGISTER (DEFAULT: 0X00000000)

| Offset: 0x288 |                |             | Register Name: OSC24M_CNT64_HIGH_REG |
|---------------|----------------|-------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                          |
| 31:0          | R/W            | 0x0         | CNT64_HI.<br>64-bit Counter [63:32]. |

#### 1.4.3.19. LOSC 64-BIT COUNTER CONTROL REGISTER (DEFAULT: 0X00000000)

| Offset: 0x290 |                |             | Register Name: LOSC_CNT64_CTRL_REG                                                                                                                                           |
|---------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                  |
| 31:3          | /              | /           | /.                                                                                                                                                                           |
| 2             | R/W            | 0x0         | CNT64_CLK_SRC_SEL.<br>64-bit Counter Clock Source Select.<br>0: LOSC<br>1: /                                                                                                 |
| 1             | R/W            | 0x0         | CNT64_RL_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 |

| Offset: 0x290 |                |             | Register Name: LOSC_CNT64_CTRL_REG                                                                                                                                         |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                |
|               |                |             | latched.                                                                                                                                                                   |
| 0             | R/W            | 0x0         | CNT64_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. |

Note: This 64-bit counter will start to count as soon as the System Power On finished.

#### 1.4.3.20. LOSC 64-BIT COUNTER LOW REGISTER (DEFAULT: 0X00000000)

| Offset: 0x294 |            |             | Register Name: LOSC_CNT64_LOW_REG   |
|---------------|------------|-------------|-------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                         |
| 31:0          | R/W        | 0x0         | CNT64_LO.<br>64-bit Counter [31:0]. |

#### 1.4.3.21. LOSC 64-BIT COUNTER HIGH REGISTER (DEFAULT: 0X00000000)

| Offset: 0x298 |            |             | Register Name: LOSC_CNT64_HIGH_REG   |
|---------------|------------|-------------|--------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                          |
| 31:0          | R/W        | 0x0         | CNT64_HI.<br>64-bit Counter [63:32]. |

## 1.5. CCU

### 1.5.1. Overview

The CCU (Clock Control Unit) is made up of 7 PLLs, a main oscillator, an on-chip RC oscillator and a 32768Hz low-power oscillator.

A20 integrates two crystal oscillators: The 24MHz crystal is mandatory, which is used to provide clock source for the PLL and the main digital blocks, and the 32768Hz oscillator, which is only used to provide a low power, accurate reference for the RTC.

A20 also provides following clock domain to allow for user interfaces of high performance and low power consumption.

| Clock Domain | Module               | Speed Range              | Description                        |
|--------------|----------------------|--------------------------|------------------------------------|
| OSC24M       | Most Clock Generator | 24MHz                    | Root clock for most blocks         |
| RC_osc       | Timer,Key            | 32KHz                    | Source for the RTC/Timer           |
| 32K768Hz     | Timer,Key            | 32768Hz                  | Low-power source for the RTC/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<br>/22.5792MHz | Sourced from the PLL               |

The CCU features:

- 8 PLLs, a main oscillator, an on-chip RC oscillator and a 32768Hz low-power oscillator
- PLL1 is the main clock of CPU0/1
- Clock configuration for corresponding module
- Software-controlled clock gating
- 2 clock output channels

### 1.5.2. Clock Tree Diagram



### 1.5.3. CCU Register List

| Module Name | Base Address |
|-------------|--------------|
| CCU         | 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  |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                        |
|----------------------|---------------|-------------------------------------------|
| PLL3_CFG_REG         | 0x0010        | PLL3 CONTROL                              |
| PLL4_CFG_REG         | 0x0018        | PLL4 CONTROL                              |
| PLL5_CFG_REG         | 0x0020        | PLL5 CONTROL                              |
| PLL5_TUN_REG         | 0x0024        | PLL5 TUNING                               |
| PLL6_CFG_REG         | 0x0028        | PLL6 CONTROL                              |
| PLL6_TUN_REG         | 0x002C        | PLL6 TUNING                               |
| PLL7_CFG_REG         | 0x0030        | PLL7 CONTROL                              |
| /                    | 0x0034        | /                                         |
| PLL1_TUN2_REG        | 0x0038        | PLL1 TUNING2                              |
| PLL5_TUN2_REG        | 0x003C        | PLL5 TUNING2                              |
| PLL8_CFG_REG         | 0x0040        | PLL8 CONTROL                              |
| 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 DIVIDOR                        |
| 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 CLOCK CONFIGURATION REGISTER         |
| MS_SCLK_CFG_REG      | 0x0084        | MEMORY STICK CLOCK CONFIGURATION REGISTER |
| SD0_CLK_REG          | 0x0088        | SD0 CLOCK REGISTER                        |
| SD1_CLK_REG          | 0x008C        | SD1 CLOCK REGISTER                        |
| SD2_CLK_REG          | 0x0090        | SD2 CLOCK REGISTER                        |
| SD3_CLK_REG          | 0x0094        | SD3 CLOCK REGISTER                        |
| TS_CLK_REG           | 0x0098        | TRANSPORT STREAM CLOCK REGISTER           |
| SS_CLK_REG           | 0x009C        | SECURITY SYSTEM CLOCK REGISTER            |
| SPI0_CLK_REG         | 0x00A0        | SPI0 CLOCK REGISTER                       |
| SPI1_CLK_REG         | 0x00A4        | SPI1 CLOCK REGISTER                       |
| SPI2_CLK_REG         | 0x00A8        | SPI2 CLOCK REGISTER                       |
| IR0_CLK_REG          | 0x00B0        | IR0 CLOCK REGISTER                        |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                                    |
|----------------------|---------------|-------------------------------------------------------|
| IR1_CLK_REG          | 0x00B4        | IR1 CLOCK REGISTER                                    |
| IIS0_CLK_REG         | 0x00B8        | IIS0 CLOCK REGISTER                                   |
| AC97_CLK_REG         | 0x00BC        | AC97 CLOCK REGISTER                                   |
| SPDIF_CLK_REG        | 0x00C0        | SPDIF CLOCK REGISTER                                  |
| KEYPAD_CLK_REG       | 0x00C4        | KEYPAD CLOCK REGISTER                                 |
| SATA_CLK_REG         | 0x00C8        | SATA CLOCK REGISTER                                   |
| USB_CLK_REG          | 0x00CC        | USB CLOCK REGISTER                                    |
| SPI3_CLK_REG         | 0x00D4        | SPI 3 CLOCK REGISTER                                  |
| IIS1_CLK_REG         | 0x00D8        | IIS 1 CLOCK REGISTER                                  |
| IIS2_CLK_REG         | 0x00DC        | IIS 2 CLOCK REGISTER                                  |
| DRAM_CLK_REG         | 0x0100        | DRAM CLOCK REGISTER                                   |
| BE0_SCLK_CFG_REG     | 0x0104        | DISPLAY ENGINE BACKEND CLOCK CONFIGURATION REGISTER   |
| BE1_SCLK_CFG_REG     | 0x0108        | DISPLAY ENGINE BACKEND 0 CLOCK CONFIGURATION REGISTER |
| FE0_CLK_REG          | 0x010C        | DISPLAY ENGINE FRONTEND CLOCK CONFIGURATION REGISTER  |
| FE1_CLK_REG          | 0x0110        | DISPLAY ENGINE FRONTEND1 CLOCK CONFIGURATION REGISTER |
| MP_CLK_REG           | 0x0114        | MIXER PROCESSOR CLOCK REGISTER                        |
| LCD0_CH0_CLK_REG     | 0x0118        | LCD0 CHANNEL 0 CLOCK REGISTER                         |
| LCD1_CH0_CLK_REG     | 0x011C        | LCD1 CHANNEL0 CLOCK REGISTER                          |
| CSI_SCLK_REG         | 0x0120        | CSI SPECIAL CLOCK REGISTER                            |
| TVD_CLK_REG          | 0x0128        | TVD CLOCK REGISTER                                    |
| LCD0_CH1_CLK_REG     | 0x012C        | LCD0 CHANNEL 1 CLOCK REGISTER                         |
| LCD1_CH1_CLK_REG     | 0x0130        | LCD1 CHANNEL 1 CLOCK REGISTER                         |
| CSI0_CLK_REG         | 0x0134        | CSI0 CLOCK REGISTER                                   |
| CSI1_CLK_REG         | 0x0138        | CSI1 CLOCK REGISTER                                   |
| VE_CLK_REG           | 0x013C        | VIDEO ENGINE CLOCK REGISTER                           |
| AUDIO_CODEC_CLK_REG  | 0x0140        | AUDIO CODEC CLOCK REGISTER                            |
| AVS_CLK_REG          | 0x0144        | AVS CLOCK REGISTER                                    |
| ACE_CLK_REG          | 0x0148        | ACE CLOCK REGISTER                                    |
| LVDS_CLK_REG         | 0x014C        | LVDS CLOCK REGISTER                                   |

| Register Name        | Offset | Description                       |
|----------------------|--------|-----------------------------------|
| HDMI_CLK_REG.        | 0x0150 | HDMI CLOCK REGISTER               |
| MALI400_CLK_REG      | 0x0154 | MALI 400 CLOCK REGISTER           |
| MBUS_SCLK_CFG_REG    | 0x015C | MBUS CLOCK CONFIGURATION REGISTER |
| GMAC_CLK_REG         | 0x0164 | GMAC CLOCK REGISTER               |
| HDMI1_RST_REG        | 0x0170 | HDMI1 RESET REGISTER              |
| HDMI1_CTRL_REG       | 0x0174 | HDMI1 CONTROL REGISTER            |
| HDMI1_SLOW_CLK_REG   | 0x0178 | HDMI1 SLOW CLOCK REGISTER         |
| HDMI1_REPEAT_CLK_REG | 0x017C | HDMI1 REPEAT CLOCK REGISTER       |
| CLK_OUTA_REG         | 0x01F0 | CLK OUTA                          |
| CLK_OUTB_REG         | 0x01F4 | CLK OUTB                          |

## 1.5.4. CCU Register Description

### 1.5.4.1. PLL1-CORE(DEFAULT: 0X21005000)

| Offset: 0x00 |                |             | Register Name: PLL1_CFG_REG                                                                                                                                                                                                                            |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                            |
| 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<br>must be in the range of 240MHz~2GHz if the bypass is<br>disabled.<br>Its default is 384MHz. |
| 30           | /              | /           | /                                                                                                                                                                                                                                                      |
| 29:26        | /-             | /           | /                                                                                                                                                                                                                                                      |
| 25           | R/W            | 0x0         | EXG_MODE.<br>Exchange mode.                                                                                                                                                                                                                            |
| 24:20        | /              | /           | /                                                                                                                                                                                                                                                      |

| Offset: 0x00 |                |             | Register Name: PLL1_CFG_REG                                                                                      |
|--------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                      |
| 19: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=1;<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         | SIG_DELT_PAT_IN.<br>Sigma-delta pattern input.                                                                   |
| 2            | R/W            | 0x0         | SIG_DELT_PAT_EN.<br>Sigma-delta pattern enable.                                                                  |
| 1:0          | R/W            | 0x0         | PLL1_FACTOR_M.<br>PLL1 Factor M. (M=Factor + 1 )<br>The range is from 1 to 4.                                    |

#### 1.5.4.2. PLL1-TUNING(DEFAULT: 0X0A101000)

| Offset: 0x04 |                |             | Register Name: PLL1_TUN_REG |
|--------------|----------------|-------------|-----------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                 |
| 31:0         | /              | /           | /                           |

### 1.5.4.3. PLL2-AUDIO(DEFAULT: 0X08100010)

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

| Offset: 0x08 |                |             | Register Name: PLL2_CFG_REG |
|--------------|----------------|-------------|-----------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                 |
|              |                |             | 11111: 0x1F                 |

#### 1.5.4.4. PLL2-TUNING(DEFAULT: 0X00000000)

| Offset: 0x0C |                |             | Register Name: PLL2_TUN_REG                                                                      |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                      |
| 31           | R/W            | 0x0         | SIG_DELT_PAT_EN.<br>Sigma-delta pattern enable.                                                  |
| 30:29        | R/W            | 0x0         | SPR_FREQ_MODE.<br>Spread Frequency Mode.<br>00: DC=0<br>01: DC=1<br>10: Triangular<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.                                                                        |

#### 1.5.4.5. PLL3-VIDEO 0(DEFAULT: 0X0010D063)

| Offset: 0x10 |                |             | Register Name: PLL3_CFG_REG |
|--------------|----------------|-------------|-----------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                 |
| 31           | R/W            | 0x0         | PLL3_Enable.                |

| Offset: 0x10 |                |             | Register Name: PLL3_CFG_REG                                                                                                                                                        |
|--------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                        |
|              |                |             | 0: Disable, 1: Enable.<br>In the integer mode, The PLL3 output=3MHz*M.<br>In the fractional mode, the PLL3 output is selected by bit 14.<br>The PLL3 output range is 27MHz~381MHz. |
| 30:27        | /              | /           | /                                                                                                                                                                                  |
| 26:24        | /              | /           | /                                                                                                                                                                                  |
| 23:21        | /              | /           | /                                                                                                                                                                                  |
| 20:16        | /              | /           | /                                                                                                                                                                                  |
| 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         | /              | /           | /                                                                                                                                                                                  |
| 7            | /              | /           | /                                                                                                                                                                                  |
| 6:0          | R/W            | 0x63        | PLL3_FACTOR_M.<br>PLL3 Factor M.<br>The range is from 9 to 127.                                                                                                                    |

#### 1.5.4.6. PLL4-VE(DEFAULT: 0X21009911)

| Offset: 0x18 |                |             | Register Name: PLL4_CFG_REG                                                                                                                                         |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                         |
| 31           | R/W            | 0x0         | PLL4_Enable.<br>0: Disable, 1: Enable.<br>The output = 24MHz*N*K<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_BYPASS_EN.<br>PLL4 Output Bypass Enable.                                                                                                                       |

| Offset: 0x18 |                |             | Register Name: PLL4_CFG_REG                                                                                        |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                        |
|              |                |             | 0: Disable, 1: Enable.<br>If the bypass is enabled, the PLL4 output is 24MHz.                                      |
| 29:25        | /              | /           | /                                                                                                                  |
| 24:20        | /              | /           | /                                                                                                                  |
| 19:16        | /              | /           | /                                                                                                                  |
| 15           | /              | /           | /<br>0: narrow, 1: wide.                                                                                           |
| 14:13        | /              | /           | /                                                                                                                  |
| 12:8         | R/W            | 0x19        | 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            | 0x1         | PLL4_FACTOR_K.<br>PLL4 Factor K.(K=Factor + 1 )<br>The range is from 1 to 4.                                       |
| 3:2          | /              | /           | /                                                                                                                  |
| 1:0          | R/W            | 0x1         | /                                                                                                                  |

#### 1.5.4.7. PLL5-DDR(DEFAULT: 0X11049280)

| Offset: 0x20 |                |             | Register Name: PLL5_CFG_REG                                                                                                            |
|--------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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. |

| Offset: 0x20 |                |             | Register Name: PLL5_CFG_REG                                                                                                        |
|--------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                        |
|              |                |             | 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           | /              | /           | /                                                                                                                                  |
| 29           | R/W            | 0x0         | DDR_CLK_OUT_EN.<br>DDR clock output en.                                                                                            |
| 28:25        | /              | /           | /                                                                                                                                  |
| 24:20        | /              | /           | /                                                                                                                                  |
| 19           | /              | /           | /                                                                                                                                  |
| 18           | /              | /           | /                                                                                                                                  |
| 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        | /              | /           | /                                                                                                                                  |
| 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            | R/W            | /           | /                                                                                                                                  |
| 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.                                                     |

#### 1.5.4.8. PLL5-TUNING(DEFAULT: 0X14888000)

| Offset: 0x24 |                |             | Register Name: PLL5_TUN_REG |
|--------------|----------------|-------------|-----------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                 |
| 31:29        | /              | /           | /                           |
| 28           | /              | /           | /                           |
| 27           | /              | /           | /                           |
| 26:24        | /              | /           | /                           |
| 23           | /              | /           | /                           |
| 22:16        | /              | /           | /                           |
| 15           | /              | /           | /.<br>/.                    |
| 14:8         | /              | /           | /                           |
| 7            | /              | /           | /                           |
| 6:0          | /              | /           | /                           |

#### 1.5.4.9. PLL6-SATA(DEFAULT: 0X21009911)

| Offset: 0x28 |                |                 | Register Name: PLL6_CFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31           | R/W            | 0x0             | <p>PLL6_Enable.<br/>0: Disable, 1: Enable.<br/>There are two outputs:<br/>For SATA, the output = <math>(24\text{MHz} \times N \times K) / M / 6</math><br/>If the SATA is on, the clock output should be equal to 100MHz;<br/>For other module, the clock output = <math>(24\text{MHz} \times N \times K) / 2</math><br/><math>PLL6 \times 2 = 24\text{MHz} \times N \times K</math><br/>Note: the output <math>24\text{MHz} \times N \times K</math> clock must be in the range of 240MHz~2GHz if the bypass is disabled.</p> |
| 30           | R/W            | 0x0             | <p>PLL6_BYPASS_EN.<br/>PLL6 Output Bypass Enable.<br/>0: Disable, 1: Enable.<br/>If the bypass is enabled, the PLL6 output is 24MHz.</p>                                                                                                                                                                                                                                                                                                                                                                                       |

|       |     |      |                                                                                                                   |
|-------|-----|------|-------------------------------------------------------------------------------------------------------------------|
| 29:25 | /   | /    | /                                                                                                                 |
| 24:20 | /   | /    | /                                                                                                                 |
| 19:16 | /   | /    | /                                                                                                                 |
| 15    | /   | /    | /                                                                                                                 |
| 14    | R/W | 0x0  | SATA_CLK_EN.<br>Sata clock output enable.<br>0:Disable;1:enable.                                                  |
| 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   | /   | /    | /                                                                                                                 |
| 5:4   | R/W | 0x1  | 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.                                    |

#### 1.5.4.10. PLL6-TUNING

| Offset: 0x2C |                |             | Register Name: PLL6_TUN_REG |
|--------------|----------------|-------------|-----------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                 |
| 31:0         | /              | /           | /                           |

#### 1.5.4.11. PLL7-VIDEO 1(DEFAULT: 0X0010D063)

| Offset: 0x30 |                |             | Register Name: PLL7_CFG_REG                                                                                                                                                                      |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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:27        | /              | /           | /.                                                                                                                                                                                               |
| 26:24        | /              | /           | /                                                                                                                                                                                                |
| 23:21        | /              | /           | /.                                                                                                                                                                                               |
| 20: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           | /              | /           | /.                                                                                                                                                                                               |
| 12:8         | /              | /           | /                                                                                                                                                                                                |
| 7            | /              | /           | /.                                                                                                                                                                                               |
| 6:0          | R/W            | 0x63        | PLL7_FACTOR_M.<br>PLL7 Factor M.<br>The range is from 9 to 127.                                                                                                                                  |

#### 1.5.4.12. PLL1-TUNING2(DEFAULT: 0X00000000)

| Offset: 0x38 |                |             | Register Name: PLL1_TUN2_REG                    |
|--------------|----------------|-------------|-------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                     |
| 31           | R/W            | 0x0         | SIG_DELT_PAT_EN.<br>Sigma-delta pattern enable. |
| 30:29        | R/W            | 0x0         | SPR_FREQ_MODE.<br>Spread Frequency Mode.        |

| Offset: 0x38 |                |             | Register Name: PLL1_TUN2_REG                                                |
|--------------|----------------|-------------|-----------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                 |
|              |                |             | 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.                                                   |

#### 1.5.4.13. PLL5-TUNING2(DEFAULT: 0X00000000)

| Offset: 0x3C |                |             | Register Name: PLL5_TUN2_REG                                                                     |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                      |
| 31           | R/W            | 0x0         | SIG_DELT_PAT_EN.<br>Sigma-delta pattern enable.                                                  |
| 30:29        | R/W            | 0x0         | SPR_FREQ_MODE.<br>Spread Frequency Mode.<br>00: DC=0<br>01: DC=1<br>10: Triangular<br>11: awmode |
| 28:20        | R/W            | 0x0         | WAVE_STEP.<br>Wave step.                                                                         |
| 19           | /              | /           | /                                                                                                |
| 18:17        | R/W            | 0x0         | FREQ.                                                                                            |

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

#### 1.5.4.14. PLL8-GPU(DEFAULT: 0X21009911)

| Offset: 0x40 |                |             | Register Name: PLL8_CFG_REG                                                                                                                                            |
|--------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                            |
| 31           | R/W            | 0x0         | PLL8_Enable.<br>0: Disable, 1: Enable.<br>The output = 24MHz*N*K<br>Note: the output 24MHz*N*K clock<br>must be in the range of 240MHz~2GHz if the bypass is disabled. |
| 30           | R/W            | 0x0         | PLL8_BYPASS_EN.<br>PLL8 Output Bypass Enable.<br>0: Disable, 1: Enable.<br>If the bypass is enabled, the PLL8 output is 24MHz.                                         |
| 29:25        | /              | /           | /                                                                                                                                                                      |
| 24:20        | /              | /           | /                                                                                                                                                                      |
| 19:16        | /              | /           | /                                                                                                                                                                      |
| 15           | /              | /           | /                                                                                                                                                                      |
| 14:13        | /              | /           | /                                                                                                                                                                      |
| 12:8         | R/W            | 0x19        | PLL8_FACTOR_N.<br>PLL8 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          | /              | /           | /                                                                                                                                                                      |

| Offset: 0x40 |                |             | Register Name: PLL8_CFG_REG                                                  |
|--------------|----------------|-------------|------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                  |
| 5:4          | R/W            | 0x1         | PLL8_FACTOR_K.<br>PLL8 Factor K.(K=Factor + 1 )<br>The range is from 1 to 4. |
| 3:2          | /              | /           | /                                                                            |
| 1:0          | R/W            | 0x1         | /                                                                            |

#### 1.5.4.15. OSC24M (DEFAULT: 0X00138013)

| Offset: 0x50 |                |             | Register Name: OSC24M_CFG_REG                                                                                  |
|--------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                    |
| 31:24        | R/W            | 0x0         | KEY_FIELD.<br>Key Field for LDO Enable bit.<br>If the key field value is 0xA7, the bit[23:16] can be modified. |
| 23:21        | /              | /           | /                                                                                                              |
| 20:18        | /              | /           | /                                                                                                              |
| 17           | /              | /           | /                                                                                                              |
| 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:5         | /              | /           | /                                                                                                              |
| 4            | /              | /           | /                                                                                                              |
| 3:2          | /              | /           | /                                                                                                              |
| 1            | R/W            | 0x1         | OSC24M_GSM.<br>OSC24M GSM.                                                                                     |
| 0            | R/W            | 0x1         | OSC24M_EN.<br>OSC24M Enable.<br>0: Disable, 1: Enable.                                                         |

#### 1.5.4.16. CPU/AHB/APB0 CLOCK RATIO(DEFAULT: 0X00010010)

| Offset: 0x54 |                |             | Register Name: CPU_AHB_APB0_CFG_REG                                                                                                                                                                               |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                       |
| 31           | R/W            | 0x0         | DVFS_START.<br>DVFS start. Set 1 to this bit will start the DVFS.<br>It will be cleared automatically after the DVFS is finished.                                                                                 |
| 30:18        | /              | /           | /                                                                                                                                                                                                                 |
| 17:16        | R/W            | 0x1         | CPU_CLK_SRC_SEL.<br>CPU0/1 Clock Source Select.<br>00: LOSC<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:13        | /              | /           | /                                                                                                                                                                                                                 |
| 12:11        | R/W            | 0x0         |                                                                                                                                                                                                                   |
| 10           | /              | /           | /                                                                                                                                                                                                                 |
| 9:8          | R/W            | 0x0         | APB0_CLK_RATIO.<br>APB0 Clock divide ratio. APB0 clock source is AHB 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: PLL6/2<br>10: PLL6<br>11: /                                                                                                                                                    |
| 5:4          | R/W            | 0x1         | AHB_CLK_DIV_RATIO.<br>AHB Clock divide ratio.<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                                                                                                             |

| Offset: 0x54 |                |             | Register Name: CPU_AHB_APB0_CFG_REG                                                                                     |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                             |
| 3:2          | /              | /           | ATB_APB_CLK_DIV.<br>00: /1<br>01: /2<br>1x: /4<br>Note: System ATB/APB clock source is CPU clock source.                |
| 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 |

#### 1.5.4.17. APB1 CLOCK DIVIDE RATIO(DEFAULT: 0X00000000)

| Offset: 0x58 |                |             | Register Name: APB1_CLK_DIV_REG                                                                                                                                                                                                                      |
|--------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                          |
| 31:26        | /              | /           | /                                                                                                                                                                                                                                                    |
| 25:24        | R/W            | 0x0         | APB1_CLK_SRC_SEL.<br>APB1 Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: LOSC<br>11: /<br>This clock is used for some special module apbclk(twi,uart,ps2, can, scr). Because these modules need special clock rate even if the apbclk changed. |
| 23:18        | /              | /           | /                                                                                                                                                                                                                                                    |
| 17:16        | R/W            | 0x0         | CLK_RAT_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         | /              | /           | /                                                                                                                                                                                                                                                    |

| Offset: 0x58 |                |             | Register Name: APB1_CLK_DIV_REG                                                                                 |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                     |
| 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. |

#### 1.5.4.18. AHB MODULE CLOCK GATING REGISTER 0(DEFAULT: 0X00000000)

| Offset: 0x60 |                |             | Register Name: AHB_GATING_REG0                                       |
|--------------|----------------|-------------|----------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                          |
| 31:29        | /              | /           | /                                                                    |
| 28           | R/W            | 0x0         | STIMER_AHB_GATING<br>Gating AHB Clock for Sync timer(0:mask, 1:pass) |
| 27:26        | /              | /           | /                                                                    |
| 25           | R/W            | 0x0         | Gating AHB Clock for SATA(0: mask, 1: pass).                         |
| 24           | /              | /           | /                                                                    |
| 23           | R/W            | 0x0         | Gating AHB Clock for SPI3(0: mask, 1: pass).                         |
| 22           | R/W            | 0x0         | Gating AHB Clock for SPI2(0: mask, 1: pass).                         |
| 21           | R/W            | 0x0         | Gating AHB Clock for SPI1(0: mask, 1: pass).                         |
| 20           | R/W            | 0x0         | Gating AHB Clock for SPI0(0: mask, 1: pass).                         |
| 19           | /              | /           | /                                                                    |
| 18           | R/W            | 0x0         | Gating AHB Clock for TS(0: mask, 1: pass).                           |
| 17           | R/W            | 0x0         | Gating AHB Clock for EMAC(0: mask, 1: pass).                         |
| 16           | R/W            | 0x0         | Gating AHB Clock for ACE(0: mask, 1: pass).                          |
| 15           | /              | /           | /                                                                    |
| 14           | R/W            | 0x0         | Gating AHB Clock for SDRAM(0: mask, 1: pass).                        |
| 13           | R/W            | 0x0         | Gating AHB Clock for NAND(0: mask, 1: pass).                         |
| 12           | R/W            | 0x0         | Gating AHB Clock for MS(0: mask, 1: pass).                           |
| 11           | R/W            | 0x0         | Gating AHB Clock for SD/MMC3(0: mask, 1: pass).                      |
| 10           | R/W            | 0x0         | Gating AHB Clock for SD/MMC2(0: mask, 1: pass).                      |
| 9            | R/W            | 0x0         | Gating AHB Clock for SD/MMC1(0: mask, 1: pass).                      |

| Offset: 0x60 |                |             | Register Name: AHB_GATING_REG0                     |
|--------------|----------------|-------------|----------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                        |
| 8            | R/W            | 0x0         | Gating AHB Clock for SD/MMC0(0: mask, 1: pass).    |
| 7            | R/W            | 0x0         | Gating AHB Clock for BIST(0: mask, 1: pass).       |
| 6            | R/W            | 0x0         | Gating AHB Clock for DMA(0: mask, 1: pass).        |
| 5            | R/W            | 0x0         | Gating AHB Clock for SS(0: mask, 1: pass).         |
| 4            | R/W            | 0x0         | Gating AHB Clock for USB OHCI1(0: mask, 1: pass).  |
| 3            | R/W            | 0x0         | Gating AHB Clock for USB EHCI1 (0: mask, 1: pass). |
| 2            | R/W            | 0x0         | Gating AHB Clock for USB OHCI0(0: mask, 1: pass).  |
| 1            | R/W            | 0x0         | Gating AHB Clock for USB EHCI0 (0: mask, 1: pass). |
| 0            | R/W            | 0x0         | Gating AHB Clock for USB0(0: mask, 1: pass).       |

#### 1.5.4.19. AHB MODULE CLOCK GATING REGISTER 1(DEFAULT: 0X00000000)

| Offset: 0x64 |                |             | Register Name: AHB_GATING_REG1                              |
|--------------|----------------|-------------|-------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                 |
| 31:21        | /              | /           | /.                                                          |
| 20           | R/W            | 0x0         | Gating AHB Clock for Mali-400(0: mask, 1: pass).            |
| 19           | /              | /           | /                                                           |
| 18           | R/W            | 0x0         | Gating AHB Clock for MP(0: mask, 1: pass).                  |
| 17           | R/W            | 0x0         | GMAC_AHB_GATING<br>Gating AHB Clock for GMAC(0:mask,1:pass) |
| 16           | /              | /           | /                                                           |
| 15           | R/W            | 0x0         | Gating AHB Clock for DE-FE1(0: mask, 1: pass).              |
| 14           | R/W            | 0x0         | Gating AHB Clock for DE-FE0(0: mask, 1: pass).              |
| 13           | R/W            | 0x0         | Gating AHB Clock for DE-BE1(0: mask, 1: pass).              |
| 12           | R/W            | 0x0         | Gating AHB Clock for DE-BE0(0: mask, 1: pass).              |
| 11           | R/W            | 0x0         | Gating AHB Clock for HDMI(0: mask, 1: pass).                |
| 10           | R/W            | 0x0         | Gating AHB Clock for HDMI1(0: mask, 1: pass).               |
| 9            | R/W            | 0x0         | Gating AHB Clock for CSI1(0: mask, 1: pass).                |
| 8            | R/W            | 0x0         | Gating AHB Clock for CSI0(0: mask, 1: pass).                |
| 7:6          | /              | /           |                                                             |

| Offset: 0x64 |                |             | Register Name: AHB_GATING_REG1                |
|--------------|----------------|-------------|-----------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                   |
| 5            | R/W            | 0x0         | Gating AHB Clock for LCD1(0: mask, 1: pass).  |
| 4            | R/W            | 0x0         | Gating AHB Clock for LCD0(0: mask, 1: pass).  |
| 3            | R/W            | 0x0         | Gating AHB Clock for TVE 1(0: mask, 1: pass). |
| 2            | R/W            | 0x0         | Gating AHB Clock for TVE 0(0: mask, 1: pass). |
| 1            | R/W            | 0x0         | Gating AHB Clock for TVD(0: mask, 1: pass).   |
| 0            | R/W            | 0x0         | Gating AHB Clock for VE(0: mask, 1: pass).    |

#### 1.5.4.20. APB0 MODULE CLOCK GATING(DEFAULT: 0X00000000)

| Offset: 0x68 |                |                 | Register Name: APB0_GATING_REG                                       |
|--------------|----------------|-----------------|----------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/He<br>x | Description                                                          |
| 31:11        | /              | /               | /.                                                                   |
| 10           | R/W            | 0x0             | KEYPAD_APB_GATING.<br>Gating APB Clock for Keypad(0: mask, 1: pass). |
| 9            | /              | /               | /                                                                    |
| 8            | R/W            | 0x0             | IIS2_APB_GATING.<br>Gating APB Clock for IIS2(0: mask, 1: pass).     |
| 7            | R/W            | 0x0             | IR1_APB_GATING.<br>Gating APB Clock for IR1(0: mask, 1: pass).       |
| 6            | R/W            | 0x0             | IR0_APB_GATING.<br>Gating APB Clock for IR0(0: mask, 1: pass).       |
| 5            | R/W            | 0x0             | PIO_APB_GATING.<br>Gating APB Clock for PIO(0: mask, 1: pass).       |
| 4            | R/W            | 0x0             | IIS1_APB_GATING.<br>Gating APB Clock for IIS1(0: mask, 1: pass).     |
| 3            | R/W            | 0x0             | IIS0_APB_GATING.<br>Gating APB Clock for IIS0(0: mask, 1: pass).     |
| 2            | R/W            | 0x0             | AC97_APB_GATING.<br>Gating APB Clock for AC97(0: mask, 1: pass).     |
| 1            | R/W            | 0x0             | SPDIF_APB_GATING.<br>Gating APB Clock for SPDIF(0: mask, 1: pass).   |

| Offset: 0x68 |                |             | Register Name: APB0_GATING_REG                                           |
|--------------|----------------|-------------|--------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                              |
| 0            | R/W            | 0x0         | CODEC_APB_GATING.<br>Gating APB Clock for Audio CODEC(0: mask, 1: pass). |

#### 1.5.4.21. APB1 MODULE CLOCK GATING(DEFAULT: 0X00000000)

| Offset: 0x6C |                |             | Register Name: APB1_GATING_REG                                     |
|--------------|----------------|-------------|--------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                        |
| 31:24        | /              | /           | /.                                                                 |
| 23           | R/W            | 0x0         | UART7_APB_GATING.<br>Gating APB Clock for UART7(0: mask, 1: pass). |
| 22           | R/W            | 0x0         | UART6_APB_GATING.<br>Gating APB Clock for UART6(0: mask, 1: pass). |
| 21           | R/W            | 0x0         | UART5_APB_GATING.<br>Gating APB Clock for UART5(0: mask, 1: pass). |
| 20           | R/W            | 0x0         | UART4_APB_GATING.<br>Gating APB Clock for UART4(0: mask, 1: pass). |
| 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.<br>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           | R/W            | 0x0         | TWI4_APB_GATING.<br>Gating APB Clock for TWI4(0: mask, 1: pass).   |
| 14:8         | /              | /           | /                                                                  |
| 7            | R/W            | 0x0         | PS21_APB_GATING.<br>Gating APB Clock for PS2-1(0: mask, 1: pass).  |
| 6            | R/W            | 0x0         | PS20_APB_GATING.<br>Gating APB Clock for PS2-0(0: mask, 1: pass).  |

| Offset: 0x6C |                |             | Register Name: APB1_GATING_REG                                   |
|--------------|----------------|-------------|------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                      |
| 5            | R/W            | 0x0         | SCR_APB_GATING.<br>Gating APB Clock for SCR(0: mask, 1: pass).   |
| 4            | R/W            | 0x0         | CAN_APB_GATING.<br>Gating APB Clock for CAN(0: mask, 1: pass).   |
| 3            | R/W            | 0x0         | TWI3_APB_GATING.<br>Gating APB Clock for TWI3(0: mask, 1: pass). |
| 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). |

#### 1.5.4.22. NAND CLOCK(DEFAULT: 0X00000000)

| Offset: 0x80 |                |             | Register Name: NAND_SCLK_CFG_REG                                                                                                                        |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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)                                                                                                          |

| Offset: 0x80 |                |             | Register Name: NAND_SCLK_CFG_REG                                                                                     |
|--------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                          |
|              |                |             | 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 practice, the module clock frequency is always switched off.

#### 1.5.4.23. MS CLOCK(DEFAULT: 0X00000000)

| Offset: 0x84 |                |             | Register Name: MS_SCLK_CFG_REG                                                                                                                          |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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                                                                                                                                         |

| Offset: 0x84 |                |             | Register Name: MS_SCLK_CFG_REG                                                                    |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                       |
|              |                |             | Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16. |

#### 1.5.4.24. SD/MMC 0 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x88 |                |             | Register Name: SD0_CLK_REG                                                                                                                              |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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           | /              | /           | /                                                                                                                                                       |
| 22:20        | R/W            | 0x0         | CLK_PHASE_CTR.<br>Sample Clock Phase Control.<br>The sample clock phase delay is based on the number of source clock that is from 0 to 7.               |
| 19: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:11        | /              | /           | /                                                                                                                                                       |
| 10:8         | R/W            | 0x0         | OUTPUT_CLK_PHASE_CTR.<br>Output Clock Phase Control.                                                                                                    |

| Offset: 0x88 |                |             | Register Name: SD0_CLK_REG                                                                                            |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                           |
|              |                |             | The output clock phase delay is based on the number of source clock that is from 0 to 7.                              |
| 7: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. |

#### 1.5.4.25. SD/MMC 1 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x8C |                |             | Register Name: SD1_CLK_REG                                                                                                                              |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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           | /              | /           | /                                                                                                                                                       |
| 22:20        | R/W            | 0x0         | CLK_PHASE_CTR.<br>Sample Clock Phase Control.<br>The sample clock phase delay is based on the number of source clock that is from 0 to 7.               |
| 19: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                                      |

| Offset: 0x8C |                |             | Register Name: SD1_CLK_REG                                                                                                                       |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                      |
|              |                |             | 1/2/4/8.                                                                                                                                         |
| 15:11        | /              | /           | /                                                                                                                                                |
| 10:8         | R/W            | 0x0         | OUTPUT_CLK_PHASE_CTR.<br>Output Clock Phase Control.<br>The output clock phase delay is based on the number of source clock that is from 0 to 7. |
| 7: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.                            |

#### 1.5.4.26. SD/MMC 2 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x90 |                |             | Register Name: SD2_CLK_REG                                                                                                                              |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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           | /              | /           | /                                                                                                                                                       |
| 22:20        | R/W            | 0x0         | CLK_PHASE_CTR.<br>Sample Clock Phase Control.<br>The sample clock phase delay is based on the number of source clock that is from 0 to 7.               |

| Offset: 0x90 |                |             | Register Name: SD2_CLK_REG                                                                                                                       |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                      |
| 19: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:11        | /              | /           | /                                                                                                                                                |
| 10:8         | R/W            | 0x0         | OUTPUT_CLK_PHASE_CTR.<br>Output Clock Phase Control.<br>The output clock phase delay is based on the number of source clock that is from 0 to 7. |
| 7: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.                            |

#### 1.5.4.27. SD/MMC 3 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x94 |                |                 | Register Name: SD3_CLK_REG                                                                                                                              |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/He<br>x | 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           | /              | /               | /                                                                                                                                                       |

| Offset: 0x94 |                |             | Register Name: SD3_CLK_REG                                                                                                                       |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                      |
| 22:20        | R/W            | 0x0         | CLK_PHASE_CTR.<br>Sample Clock Phase Control.<br>The sample clock phase delay is based on the number of source clock that is from 0 to 7.        |
| 19: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:11        | /              | /           | /                                                                                                                                                |
| 10:8         | R/W            | 0x0         | OUTPUT_CLK_PHASE_CTR.<br>Output Clock Phase Control.<br>The output clock phase delay is based on the number of source clock that is from 0 to 7. |
| 7: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.                            |

#### 1.5.4.28. TS CLOCK(DEFAULT: 0X00000000)

| Offset: 0x98 |                |             | Register Name: TS_CLK_REG                                                                                                                               |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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                                                                                                       |

| Offset: 0x98 |                |             | Register Name: TS_CLK_REG                                                                                                   |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                 |
|              |                |             | 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.       |

#### 1.5.4.29. SS CLOCK(DEFAULT: 0X00000000)

| Offset: 0x9C |                |             | Register Name: SS_CLK_REG                                                                                                                               |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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)                                                                                                          |

| Offset: 0x9C |                |             | Register Name: SS_CLK_REG                                                                                             |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                           |
|              |                |             | 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. |

#### 1.5.4.30. SPI0 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xA0 |                |             | Register Name: SPI0_CLK_REG                                                                                                                             |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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)                                                                                                              |

| Offset: 0xA0 |                |             | Register Name: SPI0_CLK_REG                                             |
|--------------|----------------|-------------|-------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                             |
|              |                |             | The pre-divided clock is divided by (m+1). The divider is from 1 to 16. |

#### 1.5.4.31. SPI1 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xA4 |                |             | Register Name: SPI1_CLK_REG                                                                                                                             |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                             |
|              |                |             | 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. |
| 31           | R/W            | 0x0         |                                                                                                                                                         |
|              |                |             | /                                                                                                                                                       |
| 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.                                   |

#### 1.5.4.32. SPI2 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xA8 | Register Name: SPI2_CLK_REG |
|--------------|-----------------------------|
|--------------|-----------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                                      |
|------------|------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.                                   |

#### 1.5.4.33. IR 0 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xB0 |                        |                    | Register Name: IR0_CLK_REG                                                                                                                              |
|--------------|------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>   | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                                      |
| 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.                                                                                                                                            |

| Offset: 0xB0 |                |             | Register Name: IR0_CLK_REG                                                                                                  |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                 |
|              |                |             | Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: LOSC.                                                      |
| 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.       |

#### 1.5.4.34. IR 1 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xB4 |                |             | Register Name: IR1_CLK_REG                                                                                                                              |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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<br>11: LOSC.                                                                  |
| 23:18        | /              | /           | /                                                                                                                                                       |

| Offset: 0xB4 |                |             | Register Name: IR1_CLK_REG                                                                                                |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 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.     |

#### 1.5.4.35. IIS0 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xB8 |                |             | Register Name: IIS0_CLK_REG                                                                   |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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 |
| 30:18        | /              | /           | /                                                                                             |
| 17:16        | R/W            | 0x0         | CLK_SRC_SEL.<br>00: PLL2 (8x)<br>01: PLL2(4X)<br>10: PLL2(2X)<br>11: PLL2(1X)                 |
| 15:0         | /              | /           | /.                                                                                            |

#### 1.5.4.36. AC97 CLOCK(DEFAULT: 0X00030000)

| Offset: 0xBC |                |             | Register Name: AC97_CLK_REG |
|--------------|----------------|-------------|-----------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                 |
| 31           | R/W            | 0x0         | SCLK_GATING.                |

| Offset: 0xBC |                |             | Register Name: AC97_CLK_REG                                                   |
|--------------|----------------|-------------|-------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                   |
|              |                |             | Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON |
| 30:18        | /              | /           | /                                                                             |
| 17:16        | R/W            | 0x3         | CLK_SRC_SEL.<br>00: PLL2 (8x)<br>01: PLL2(4X)<br>10: PLL2(2X)<br>11: PLL2(1X) |
| 15:0         | /              | /           | /.                                                                            |

#### 1.5.4.37. KEYPAD CLOCK(DEFAULT: 0X0000001F)

| Offset: 0xC4 |                |             | Register Name: KEYPAD_CLK_REG                                                                                                                           |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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<br>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         | /              | /           | /.                                                                                                                                                      |

| Offset: 0xC4 |                |             | Register Name: KEYPAD_CLK_REG                                                                                     |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                       |
| 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. |

#### 1.5.4.38. SATA CLOCK(DEFAULT: 0X00000000)

| Offset: 0xC8 |                |             | Register Name: SATA_CLK_REG                                                             |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                             |
| 31           | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON               |
| 30:25        | /              | /           | /                                                                                       |
| 24           | R/W            | 0x0         | CLK_SRC_GATING.<br>Clock Source Select<br>0: PLL6 for SATA(100MHz)<br>1: External Clock |
| 23:0         | /              | /           | /                                                                                       |

#### 1.5.4.39. USB CLOCK(DEFAULT: 0X00000000)

| Offset: 0xCC |                |             | Register Name: USB_CLK_REG                                                                        |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                       |
| 31:9         | /              | /           | /                                                                                                 |
| 8            | R/W            | 0x0         | SCLK_GATING_USBPHY.<br>Gating Special Clock for USB PHY0/1/2<br>0: Clock is OFF<br>1: Clock is ON |
| 7            | R/W            | 0x0         | SCLK_GATING_OHCI1.<br>Gating Special Clock for OHCI1                                              |

| Offset: 0xCC |                |             | Register Name: USB_CLK_REG                                                                |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                               |
|              |                |             | 0: Clock is OFF<br>1: Clock is ON                                                         |
| 6            | R/W            | 0x0         | SCLK_GATING_OHCI0.<br>Gating Special Clock for OHCI0<br>0: Clock is OFF<br>1: Clock is ON |
| 5:3          | /              | /           | /.                                                                                        |
| 2            | R/W            | 0x0         | USBPHY2_RST.<br>USB PHY2 Reset Control<br>0: Reset valid<br>1: Reset invalid              |
| 1            | R/W            | 0x0         | USBPHY1_RST.<br>USB PHY1 Reset Control<br>0: Reset valid<br>1: Reset invalid              |
| 0            | R/W            | 0x0         | USBPHY0_RST.<br>USB PHY0 Reset Control<br>0: Reset valid<br>1: Reset invalid              |

#### 1.5.4.40. SPI3 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xD4 |                |             | Register Name: SPI3_CLK_REG                                                                                                                             |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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                                                                                                                     |

| Offset: 0xD4 |                |             | Register Name: SPI3_CLK_REG                                                                                                 |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                 |
|              |                |             | 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.       |

#### 1.5.4.41. IIS1 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xD8 |                |             | Register Name: IIS1_CLK_REG                                                                   |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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 |
| 30:18        | /              | /           | /                                                                                             |
| 17:16        | R/W            | 0x0         | CLK_SRC_SEL.<br>00: PLL2 (8x)<br>01: PLL2(4X)<br>10: PLL2(2X)<br>11: PLL2(1X)                 |
| 15:0         | /              | /           | /.                                                                                            |

#### 1.5.4.42. IIS2 CLOCK(DEFAULT: 0X00000000)

| Offset: 0xDC |                |             | Register Name: IIS2_CLK_REG                                                                   |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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 |
| 30:18        | /              | /           | /                                                                                             |
| 17:16        | R/W            | 0x0         | CLK_SRC_SEL.<br>00: PLL2 (8x)<br>01: PLL2(4X)<br>10: PLL2(2X)<br>11: PLL2(1X)                 |
| 15:0         | /              | /           | /.                                                                                            |

#### 1.5.4.43. DRAM CLK(DEFAULT: 0X00000000)

| Offset: 0x100 |                |             | Register Name: DRAM_CLK_REG                                          |
|---------------|----------------|-------------|----------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                          |
| 31:30         | /              | /           | /                                                                    |
| 29            | R/W            | 0x0         | ACE_DCLK_GATING.<br>Gating DRAM Clock for ACE(0: mask, 1: pass).     |
| 28            | R/W            | 0x0         | DE_MP_DCLK_GATING.<br>Gating DRAM Clock for DE_MP(0: mask, 1: pass). |
| 27            | R/W            | 0x0         | BE1_DCLK_GATING.<br>Gating DRAM Clock for DE_BE1(0: mask, 1: pass).  |
| 26            | R/W            | 0x0         | BE0_DCLK_GATING.<br>Gating DRAM Clock for DE_BE0(0: mask, 1: pass).  |
| 25            | R/W            | 0x0         | FE0_DCLK_GATING.<br>Gating DRAM Clock for DE_FE1(0: mask, 1: pass).  |
| 24            | R/W            | 0x0         | FE1_DCLK_GATING.<br>Gating DRAM Clock for DE_FE0(0: mask, 1: pass).  |
| 23:16         | /              | /           | /                                                                    |

| Offset: 0x100 |                |             | Register Name: DRAM_CLK_REG                                         |
|---------------|----------------|-------------|---------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                         |
| 15            | R/W            | 0x0         | DCLK_OUT_EN.<br>DRAM Clock Output Enable(0: disable, 1: enable)     |
| 14:7          | /              | /           | /                                                                   |
| 6             | R/W            | 0x0         | TVE1_DCLK_GATING.<br>Gating DRAM Clock for TVE 1(0: mask, 1: pass). |
| 5             | R/W            | 0x0         | TVE0_DCLK_GATING.<br>Gating DRAM Clock for TVE 0(0: mask, 1: pass). |
| 4             | R/W            | 0x0         | TVD_DCLK_GATING.<br>Gating DRAM Clock for TVD(0: mask, 1: pass).    |
| 3             | R/W            | 0x0         | TS_DCLK_GATING.<br>Gating DRAM Clock for TS(0: mask, 1: pass).      |
| 2             | R/W            | 0x0         | CSI1_DCLK_GATING.<br>Gating DRAM Clock for CSI1(0: mask, 1: pass).  |
| 1             | R/W            | 0x0         | CSI0_DCLK_GATING.<br>Gating DRAM Clock for CSI0(0: mask, 1: pass).  |
| 0             | R/W            | 0x0         | VE_DCLK_GATING.<br>Gating DRAM Clock for VE(0: mask, 1: pass).      |

#### 1.5.4.44. DE-BE 0 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x104 |                |             | Register Name: BE0_SCLK_CFG_REG                                                                                           |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30            | R/W            | 0x0         | BE0_RST.<br>0: reset valid, 1: reset invalid.                                                                             |
| 29:26         | /              | /           | /                                                                                                                         |
| 25:24         | R/W            | 0x0         | CLK_SRC_SEL.<br>Clock Source Select                                                                                       |

| Offset: 0x104 |                |             | Register Name: BE0_SCLK_CFG_REG                                                                                       |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                           |
|               |                |             | 00: PLL3<br>01: PLL7<br>10: PLL5<br>11: /.                                                                            |
| 23: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. |

#### 1.5.4.45. DE-BE 1 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x108 |                |             | Register Name: BE1_CLK_REG                                                                                                |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30            | R/W            | 0x0         | BE1_RST.<br>DE-BE1 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: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              |

| Offset: 0x108 |                |             | Register Name: BE1_CLK_REG |
|---------------|----------------|-------------|----------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                |
|               |                |             | 1 to 16.                   |

#### 1.5.4.46. DE-FE 0 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x10C |                |             | Register Name: FE0_CLK_REG                                                                                                |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30            | R/W            | 0x0         | FE0_RST.<br>DE-FE0 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: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.     |

#### 1.5.4.47. DE-FE 1 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x110 |                |             | Register Name: FE1_CLK_REG |
|---------------|----------------|-------------|----------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                |

| Offset: 0x110 |                |             | Register Name: FE1_CLK_REG                                                                                                |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30            | R/W            | 0x0         | FE1_RST.<br>DE-FE1 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: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.     |

#### 1.5.4.48. DE-MP CLOCK(DEFAULT: 0X00000000)

| Offset: 0x114 |                |             | Register Name: MP_CLK_REG                                                                                                 |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30            | R/W            | 0x0         | MP_RST.<br>DE-MP Reset.<br>0: reset valid, 1: reset invalid.                                                              |

| Offset: 0x114 |                |             | Register Name: MP_CLK_REG                                                                                             |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                           |
| 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: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. |

#### 1.5.4.49. LCD 0 CH0 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x118 |                |             | Register Name: LCD0_CH0_CLK_REG                                                                                |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                    |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source |
| 30            | R/W            | 0x0         | LCD0_RST.<br>LCD0 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(1X)<br>01: PLL7(1X)<br>10: PLL3(2X)<br>11: PLL6*2              |
| 23:0          | /              | /           | /                                                                                                              |

#### 1.5.4.50. LCD 1 CH0 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x11C |                |             | Register Name: LCD1_CH0_CLK_REG                                                                                |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                    |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source |
| 30            | R/W            | 0x0         | LCD1_RST.<br>LCD1 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(1X)<br>01: PLL7(1X)<br>10: PLL3(2X)<br>11: PLL7(2X)            |
| 23:0          | /              | /           | /                                                                                                              |

#### 1.5.4.51. CSI SPECIAL CLOCK REGITSTER(DEFAULT: 0X00000000)

| Offset: 0x120 |                |             | Register Name: CSI_SCLK_REG                                                                                               |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30:26         | /              | /           | /                                                                                                                         |
| 25:24         | R/W            | 0x0         | SCLK2_SRC_SEL.<br>Special Clock 2 Source Select                                                                           |

| Offset: 0x120 |                |             | Register Name: CSI_SCLK_REG                                                                                           |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                           |
|               |                |             | 00: PLL3(1X)<br>01: PLL4<br>10: PLL5<br>11: PLL6                                                                      |
| 23: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. |

#### 1.5.4.52. TVD CLOCK(DEFAULT: 0X00000000)

| Offset: 0x128 |                |             | Register Name: TVD_CLK_REG                                                                                                                                                                    |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/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 = Clock Source/ CLK_DIV_RATIO1_M.<br>Gating Special Clock 1 should be ON at the same time. |
| 30:20         | /              | /           | /                                                                                                                                                                                             |
| 19:16         | R/W            | 0x0         | CLK_DIV_RATIO2_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                                                                        |
| 15            | R/W            | 0x0         | SCLK1_GATING.<br>Gating Special Clock 1<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock =<br>Clock Source/ CLK_DIV_RATIO1_M/CLK_DIV_RATIO2_M.                                      |
| 14:9          | /              | /           | /                                                                                                                                                                                             |
| 8             | R/W            | 0x0         | CLK1_SRC_SEL.<br>Clock Source Select<br>0: PLL3<br>1: PLL7                                                                                                                                    |
| 7:4           | /              | /           | /                                                                                                                                                                                             |
| 3:0           | R/W            | 0x0         | CLK_DIV_RATIO1_M.<br>Clock divide ratio (m)                                                                                                                                                   |

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

#### 1.5.4.53. LCD 0 CH1 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x12C |                |             | Register Name: LCD0_CH1_CLK_REG                                                                                                         |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/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_SEL.<br>Special Clock 2 Source Select<br>00: PLL3(1X)<br>01: PLL7(1X)<br>10: PLL3(2X)<br>11: PLL7(2X)                             |
| 23:16         | /              | /           | /                                                                                                                                       |
| 15            | R/W            | 0x0         | 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            | 0           | SCLK1_SRC_SEL.<br>Special Clock 1 Source Select.<br>0: Special Clock 2<br>1: Speical 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.                   |

#### 1.5.4.54. LCD 1 CH1 CLOCK(DEFAULT: 0X00000000)

| Offset: 0x130 |                |             | Register Name: LCD1_CH1_CLK_REG                                                                                                         |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/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:16         | /              | /           | /                                                                                                                                       |
| 15            | R/W            | 0x0         | 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: Speical 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.                   |

#### 1.5.4.55. CSI 0 CLOCK(DEFAULT: 0X00000000)

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

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                                   |
|------------|------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                | CSI0_RST.<br>CSI0 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:5       | /                      | /                  | /                                                                                                                                                    |
| 4:0        | /                      | /                  | 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.                                |

#### 1.5.4.56. CSI 1 CLOCK(DEFAULT: 0X00000000)

| <b>Offset: 0x138</b> |                        |                    | <b>Register Name: CSI1_CLK_REG</b>                                                                                        |
|----------------------|------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                        |
| 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. |

| Offset: 0x138 |                |             | Register Name: CSI1_CLK_REG                                                                                                          |
|---------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                          |
| 30            | R/W            | 0x0         | CSI1_RST.<br>CSI1 Reset.<br>0: reset valid, 1: reset invalid.                                                                        |
| 29:27         | /              | /           | /                                                                                                                                    |
| 26:24         | R/W            | 0x0         | 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: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.                |

#### 1.5.4.57. VE CLOCK(DEFAULT: 0X00000000)

| Offset: 0x13C |                |             | Register Name: VE_CLK_REG                                                                                                                                  |
|---------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating the Special clock for VE(0: mask, 1: pass).<br>Its clock source is the PLL4 output.<br>This special clock = Clock Source/Divider N. |
| 30:19         | /              | /           | /.                                                                                                                                                         |
| 18:16         | R/W            | 0x0         | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (N)<br>The select clock source is pre-divided by n+1. The divider is from 1 to 8.                               |
| 15:1          | /              | /           | /                                                                                                                                                          |

| Offset: 0x13C |                |             | Register Name: VE_CLK_REG                                 |
|---------------|----------------|-------------|-----------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                               |
| 0             | R/W            | 0x0         | VE_RST.<br>VE Reset.<br>0: reset valid, 1: reset invalid. |

#### 1.5.4.58. AUDIO CODEC CLOCK(DEFAULT: 0X00000000)

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

#### 1.5.4.59. AVS CLOCK(DEFAULT: 0X00000000)

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

#### 1.5.4.60. ACE CLOCK(DEFAULT: 0X00000000)

| Offset: 0x148 | Register Name: ACE_CLK_REG |
|---------------|----------------------------|
|---------------|----------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                            |
|------------|------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 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 M. |
| 30:25      | /                      | /                  | /                                                                                                                                             |
| 24         | R/W                    | 0x0                | CLK_SRC_SEL.<br>Clock Source Select<br>0: PLL4<br>1: PLL5                                                                                     |
| 23:17      | /                      | /                  | /                                                                                                                                             |
| 16         | R/W                    | 0x0                | ACE_RST.<br>ACE Reset.<br>0: reset valid, 1: reset invalid                                                                                    |
| 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.                         |

#### 1.5.4.61. LVDS CLOCK(DEFAULT: 0X00000000)

| <b>Offset: 0x14C</b> |                        |                    | <b>Register Name:LVDS_CLK_REG</b>                             |
|----------------------|------------------------|--------------------|---------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                            |
| 31:1                 | /                      | /                  | /.                                                            |
| 0                    | R/W                    | 0x0                | LVDS_RST.<br>LVDS reset.<br>0: reset valid, 1: reset invalid. |

#### 1.5.4.62. HDMI CLOCK(DEFAULT: 0X00000000)

| <b>Offset: 0x150</b> | <b>Register Name: HDMI_CLK_REG.</b> |
|----------------------|-------------------------------------|
|----------------------|-------------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                        |
|------------|------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 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: PLL7(1X)<br>10: PLL3(2X)<br>11: PLL7(2X)                       |
| 23: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.     |

#### 1.5.4.63. MALI400 CLOCK(DEFAULT: 0X00000000)

| <b>Offset: 0x154</b> |                   |                    | <b>Register Name: MALI400_CLK_REG</b>                                                                                                         |
|----------------------|-------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                            |
| 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:<br>27            | /                 | /                  | /                                                                                                                                             |
| 26:<br>24            | R/W               | 0x0                | CLK_SRC_SEL.<br>Clock Source Select<br>000: PLL3                                                                                              |

| Offset: 0x154 |            |             | Register Name: MALI400_CLK_REG                                                                                               |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                  |
|               |            |             | 001: PLL4<br>010: PLL5<br>011: PLL7<br>100: PLL8<br>101: /<br>110: /<br>111: /                                               |
| 23:<br>4      | /          | /           | /                                                                                                                            |
| 3:0           | R/W        | 0x0         | <b>CLK_DIV_RATIO_M.</b><br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16. |

#### 1.5.4.64. MBUS CLOCK CONTROL(DEFAULT: 0X00000000)

| Offset: 0x15C |                |             | Register Name: MBUS_SCLK_CFG_REG                                                                                                          |
|---------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                               |
| 31            | R/W            | 0x0         | <b>MBUS_SCLK_GATING.</b><br>Gating Clock for MBUS<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         | <b>MBUS_SCLK_SRC</b><br>Clock Source Select<br>00: OSC24M<br>01: PLL6*2<br>10: PLL5<br>11: Reserved                                       |
| 23:18         | /              | /           | /                                                                                                                                         |
| 17:16         | R/W            | 0x0         | <b>MBUS_SCLK_RATIO_N</b><br>Clock Pre-divide Ratio (N)<br>The select clock source is pre-divided by $2^N$ . The divider is                |

| Offset: 0x15C |                |             | Register Name: MBUS_SCLK_CFG_REG                                                                                   |
|---------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                        |
|               |                |             | 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. |

#### 1.5.4.65. GMAC CLOCK REGISTER (DEFAULT: 0X00000000)

| Offset: 0x164 |                |             | Register Name: GMAC_CLK_REG                                                                                                                                                                                          |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                          |
| 31:10         | /              | /           | /                                                                                                                                                                                                                    |
| 9:8           | R/W            | 0           | TXC_DIV_CFG<br>Clock pre-divide ratio(n)<br>External transmit clock (125MHz) is pre-divided by as follows for RGMII.<br>00:/1, generate 125MHz;<br>01:/5,generate 25 MHz;<br>10:/50,generate 2.5 MHz<br>11: Reserved |
| 7:5           | R/W            | 0           | GRXDC<br>Configure GMAC Receive Clock Delay Chian.<br>000:<br>001:<br>...<br>111:                                                                                                                                    |
| 4             | R/W            | 0           | GRXIE<br>Enable GMAC Receive Clock Invertor.<br>0: Disable;<br>1: Enable;                                                                                                                                            |
| 3             | R/W            | 0           | GTXIE<br>Enable GMAC Transmit Clock Invertor.                                                                                                                                                                        |

| Offset: 0x164 |                |             | Register Name: GMAC_CLK_REG                                                                                                                                                                         |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                         |
|               |                |             | 0: Disable;<br>1: Enable;                                                                                                                                                                           |
| 2             | R/W            | 0           | GPIT<br>GMAC PHY Interface Type<br>0: MII;<br>1: RGMII;                                                                                                                                             |
| 1:0           | R/W            | 0           | GTCS<br>GMAC Transmit Clock Source<br>00: Transmit clock source for MII;<br>01: External transmit clock source(125MHz) for RGMII;<br>10: Internal transmit clock source for RGMII;<br>11: Reserved; |

#### 1.5.4.66. HDMI1 RESET REGISTER (DEFAULT: 0X00000000)

| Offset: 0x170 |                |             | Register Name: HDMI1_RST_REG                                    |
|---------------|----------------|-------------|-----------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                     |
| 31:3          | /              | /           | /                                                               |
| 2             | R/W            | 0x0         | AUDIO_DMA_RST<br>Audio_dma reset.<br>0: assert.<br>1:de-assert. |
| 1             | R/W            | 0x0         | SYSRST.<br>HDMI1 system reset<br>0: assert.<br>1:de-assert.     |
| 0             | R/W            | 0x0         | HRST<br>hreset<br>0: assert.<br>1:de-assert.                    |

#### 1.5.4.67. HDMI1 CONTROL REGISTER (DEFAULT: 0X00000000)

| Offset: 0x174 |                |             | Register Name: HDMI1_CTRL_REG |
|---------------|----------------|-------------|-------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                   |
| 31:0          | R/W            | 0x0         | HDMI1 System Control Register |

#### 1.5.4.68. HDMI1 SLOW CLOCK REGISTER (DEFAULT: 0X00000000)

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

#### 1.5.4.69. HDMI1 REPEAT CLOCK REGISTER (DEFAULT: 0X00000000)

| Offset: 0x17C |                |             | Register Name: HDMI1_REPEAT_CLK_REG                                                                                       |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 31            | R/W            | 0x0         | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>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: PLL7(1X)<br>10:/<br>11:/                                       |

| Offset: 0x17C |                |             | Register Name: HDMI1_REPEAT_CLK_REG                                                                                   |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                           |
| 23: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. |

#### 1.5.4.70. CLK\_OUTA\_REG (DEFAULT: 0X00000000)

| Offset: 0x1F0 |                |             | Register Name: CLK_OUTA_REG                                                                                                  |
|---------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                  |
| 31            | R/W            | 0x0         | CLK_OUT_EN<br>Clock Output Enable<br>0: disable<br>1: Clock Output Enable<br>OutputA = Clock Source / DIVIDOR-N / DIVIDOR-M. |
| 30:26         | /              | /           | /                                                                                                                            |
| 25:24         | R/W            | 0x0         | CLK_OUT_SRC_SEL<br>00: OSC24MHz/750=32KHz<br>01: Losc<br>10: OSC24MHz<br>11: /                                               |
| 23:22         | /              | /           | /                                                                                                                            |
| 21:20         | R/W            | 0x0         | DIVIDOR_N<br>Clock Output Divide Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                            |
| 19:13         | /              | /           | /                                                                                                                            |
| 12:8          | R/W            | 0x0         | DIVIDOR_M<br>Clock Output Divide Factor M<br>00000: /1                                                                       |

| Offset: 0x1F0 |                |             | Register Name: CLK_OUTA_REG                   |
|---------------|----------------|-------------|-----------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                   |
|               |                |             | 00001: /2<br>00010: /3<br>.....<br>11111: /32 |
| 7:0           | /              | /           | /                                             |

#### 1.5.4.71. CLK\_OUTB\_REG (DEFAULT: 0X00000000)

| Offset: 0x1F4 |                |             | Register Name: CLK_OUTB_REG                                                                                                  |
|---------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                  |
| 31            | R/W            | 0x0         | CLK_OUT_EN<br>Clock Output Enable<br>0: disable<br>1: Clock Output Enable<br>OutputB = Clock Source / DIVIDOR-N / DIVIDOR-M. |
| 30:26         | /              | /           | /                                                                                                                            |
| 25:24         | R/W            | 0x0         | CLK_OUT_SRC_SEL<br>00: OSC24MHz/750=32KHz<br>01: Losc<br>10: OSC24MHz<br>11: /                                               |
| 23:22         | /              | /           | /                                                                                                                            |
| 21:20         | R/W            | 0x0         | DIVIDOR_N<br>Clock Output Divide Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                            |
| 19:13         | /              | /           | /                                                                                                                            |
| 12:8          | R/W            | 0x0         | DIVIDOR_M<br>Clock Output Divide Factor M<br>00000: /1                                                                       |

| Offset: 0x1F4 |                |             | Register Name: CLK_OUTB_REG                   |
|---------------|----------------|-------------|-----------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                   |
|               |                |             | 00001: /2<br>00010: /3<br>.....<br>11111: /32 |
| 7:0           | /              | /           | /                                             |

## 1.6. System Boot

### 1.6.1. Overview

A20 supports system boot from NAND Flash, SPI NOR Flash (SPI0), SD card (SDC 0/2), and USB.

After power on, the system will try to boot from SDC0, NAND Flash, SDC2, SPI0, and USB successively, but if the Boot Select Pin, or BSP, an external pin that is used to select system boot method, is checked to be in low level state, the system will directly boot from USB. In normal state, this pin is pulled up by an internal 50K resistor.

## 1.6.2. System Boot Diagram



## 1.7. System Control

### 1.7.1. Overview

The chip embeds a high-speed SRAM. This internal SRAM is split into five areas, and its memory mapping can be seen below:

| Area          | Address                | Size(Bytes) |
|---------------|------------------------|-------------|
| A1            | 0x00000000--0x00003FFF | 16K         |
| A2            | 0x00004000--0x00007FFF | 16K         |
| A3            | 0x00008000--0x0000B3FF | 13K         |
| A4            | 0x0000B400--0x0000BFFF | 3K          |
| C1            | 0x01D00000-0x01D7FFFF  | VE          |
| NAND          |                        | 2K          |
| D( USB )      | 0x00010000—0x00010FFF  | 4K          |
| B(Secure RAM) | 0x00020000--0x0002FFFF | 64K         |
| CPU0 I-Cache  |                        | 32K         |
| CPU0 D-Cache  |                        | 32K         |
| CPU1 I-Cache  |                        | 32K         |
| CPU1 D-Cache  |                        | 32K         |
| CPU L2 Cache  |                        | 256K        |
| Total         |                        | 502K        |

## 1.7.2. System Control Register List

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

| Register Name      | Offset | Description                    |
|--------------------|--------|--------------------------------|
| SRAM_CTRL_REG0     | 0x0    | SRAM Control Register 0        |
| SRAM_CTRL_REG1     | 0x4    | SRAM Control Register 1        |
| VER_REG            | 0x24   | Version Register               |
| NMI_IRQ_CTRL_REG   | 0x30   | NMI Interrupt Control Register |
| NMI_IRQ_PEND_REG   | 0x34   | NMI Interrupt Pending Register |
| NMI_IRQ_ENABLE_REG | 0x38   | NMI Interrupt Enable Register  |

## 1.7.3. System Control Register

### 1.7.3.1. SRAM CONTROL REGISTER 0(DEFAULT: 0X7FFFFFFF)

| Offset: 0x0 |                |             | Register Name: SRAM_CTRL_REG0                                                                     |
|-------------|----------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | 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 |

### 1.7.3.2. SRAM CONTROL REGISTER 1(DEFAULT: 0X00001300)

| Offset: 0x4 | Register Name: SRAM_CTRL_REG1 |
|-------------|-------------------------------|
|-------------|-------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                  |
|------------|------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31         | R/W                    | 0x0                | BIST_NDMA_CTRL_SEL.<br>Bist and Normal DMA control select.<br>0: N-DMA, 1: Bist.                                    |
| 30: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:10      | /                      | /                  | /                                                                                                                   |
| 9:8        | R/W                    | 0x3                | SRAM_C2_MAP.<br>SRAM C2 map config.<br>0: map to CPU/BIST<br>1: map to AE<br>2: map to CE<br>3: map to ACE          |
| 7: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: /<br>11: / |
| 3:1        | /                      | /                  | /.                                                                                                                  |
| 0          | R/W                    | 0x0                | SRAMD_MAP.<br>SRAM D Area Config.<br>0: map to CPU/DMA<br>1: map to USB0                                            |

### 1.7.3.3. VERSION REGISTER(DEFAULT: 0X00000000)

| <b>Offset: 0x24</b> |                        | <b>Register Name: VER_REG</b> |                    |
|---------------------|------------------------|-------------------------------|--------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/He<br/>x</b>       | <b>Description</b> |
| 31:16               | R                      | 0x0                           | KEY_FIELD.         |

| Offset: 0x24 |                |                 | Register Name: VER_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/He<br>x | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|              |                |                 | The bit[31:16] will be 0x1651 if bit15 is set, otherwise it will be 0.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15           | R/W            | 0x0             | <p>VER_R_EN.</p> <p>Version Reg Bit[31:16] Read Option Enable.</p> <p>0: Disable, 1: Enable.</p>                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14:9         | /              | /               | /.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8            | R              | x               | <p>BOOT_SEL_PAD_STA.</p> <p>BootSelect Pin Status</p> <p>0: Low Level</p> <p>1: High Level</p> <p>The bit indicates current status of external BootSelect pin. In default state, this pin is pull high by internal register and normal boot is running. When this pin is driven to low level, normal boot is bypassed and it would jump to USB for special application, such as firmware update etc.</p> <p>The status of BootSelect pin should be sampled by APB clock. The debounce work is left for software.</p> |
| 7:0          | R              | 0x0             | <p>VER_BITS.</p> <p>This read-only bit field always reads back the mask revision level of the chip.</p>                                                                                                                                                                                                                                                                                                                                                                                                              |

#### 1.7.3.4. NMI INTERRUPT CONTROL REGISTER(DEFAULT: 0X00000000)

| Offset:0x30 |                |             | Register Name: NMI_IRQ_CTRL_REG                                                                                                                                                                                                                                                                                                       |
|-------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                           |
| 31:2        | /              | /           | /                                                                                                                                                                                                                                                                                                                                     |
| 1:0         | R/W            | 0x0         | <p>NMI_IRQ_SRC_TYPE.</p> <p>External NMI Interrupt Source Type.</p> <p>External NMI pin will be changed to alarm output if the power of I/O is switched off, and its power source is RTCVDD.</p> <p>00: Low level sensitive</p> <p>01: Negative edge triggered</p> <p>10: High level sensitive</p> <p>11: Positive edge sensitive</p> |

### 1.7.3.5. NMI INTERRUPT PENDING REGISTER(DEFAULT: 0X00000000)

| Offset:0x34 |                |             | Register Name: NMI_IRQ_PEND_REG                                                                                           |
|-------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                               |
| 31:1        | /              | /           | /                                                                                                                         |
| 0           | R/W            | 0x0         | NMI_IRQ_SRC_PEND.<br>NMI Source Pending and Clear Bit.<br>0: NMI interrupt is not pending.<br>1: NMI interrupt is pending |

### 1.7.3.6. NMI INTERRUPT ENABLE REGISTER(DEFAULT: 0X00000000)

| Offset:0x38 |                |             | Register Name: NMI_IRQ_ENABLE_REG                                                                                       |
|-------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                             |
| 31:1        | /              | /           | /                                                                                                                       |
| 0           | R/W            | 0x0         | NMI_IRQ_SRC_ENABLE.<br>NMI Source Enable and Disable Bit.<br>0: NMI interrupt is disable.<br>1: NMI interrupt is enable |

## 1.8. PWM

### 1.8.1. Overview

The PWM signals can be used for LCD contrast and brightness control.

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

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

PWM has two modes: in PWM cycle mode, the output will be a square waveform, and the frequency is set to the period register; in PWM pulse mode, the output will be a positive pulse or a negative pulse.

## 1.8.2. PWM Register List

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

| Register Name  | Offset | Description                   |
|----------------|--------|-------------------------------|
| PWM_CTRL_REG   | 0x200  | PWM Control Register          |
| PWM_CH0_PERIOD | 0x204  | PWM Channel 0 Period Register |
| PWM_CH1_PERIOD | 0x208  | PWM Channel 1 Period Register |

## 1.8.3. PWM Register Description

### 1.8.3.1. PWM CONTROL REGISTER(DEFAULT: 0X00000000)

| Offset: 0x200 |                |             | Register Name: PWM_CTRL_REG                                                                                                |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                |
| 31:30         | /              | /           | /.                                                                                                                         |
| 29            | RO             | 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            | RO             | 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.<br>0: disable                 |

| Offset: 0x200 |                |             | Register Name: PWM_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               |                |             | 1: enable                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23            | R/W            | 0x0         | <p>PWM_CH1_PULSE_OUT_START.<br/>           PWM Channel 1 pulse output start.<br/>           0: no effect, 1: output 1 pulse.</p> <p>The pulse width should be according to the period 1 register[15:0],and the pulse state should be according to the active state.</p> <p>After the pulse is finished, the bit will be cleared automatically.</p>                                                                                                 |
| 22            | R/W            | 0x0         | <p>PWM_CH1_MODE.<br/>           PWM Channel 1 mode.<br/>           0: cycle mode, 1: pulse mode.</p>                                                                                                                                                                                                                                                                                                                                               |
| 21            | R/W            | 0x0         | <p>PWM_CH1_CLK_GATING<br/>           Gating the Special Clock for PWM1(0: mask, 1: pass).</p>                                                                                                                                                                                                                                                                                                                                                      |
| 20            | R/W            | 0x0         | <p>PWM_CH1_ACT_STATE.<br/>           PWM Channel 1 Active State.<br/>           0: Low Level, 1: High Level.</p>                                                                                                                                                                                                                                                                                                                                   |
| 19            | R/W            | 0x0         | <p>PWM_CH1_EN.<br/>           PWM Channel 1 Enable.<br/>           0: Disable, 1: Enable.</p>                                                                                                                                                                                                                                                                                                                                                      |
| 18:15         | R/W            | 0x0         | <p>PWM_CH1_PRESCAL.<br/>           PWM Channel 1 Prescalar.</p> <p>These bits should be setting before the PWM Channel 1 clock gate on.</p> <p>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</p> |

| Offset: 0x200 |                |             | Register Name: PWM_CTRL_REG                                                                                                                                                                                                                                                                                 |
|---------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                 |
|               |                |             | 1100: /72k<br>1101: /<br>1110: /<br>1111: /1                                                                                                                                                                                                                                                                |
| 14:10         | /              | /           | /                                                                                                                                                                                                                                                                                                           |
| 9             | R/W            | 0x0         | <b>PWM0_BYPASS.</b><br>PWM CH0 bypass enable.<br>If the bit is set to 1, PWM0's output is OSC24MHz.<br>0: disable,<br>1: enable.                                                                                                                                                                            |
| 8             | R/W            | 0x0         | <b>PWM_CH0_PUL_START.</b><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         | <b>PWM_CHANNEL0_MODE.</b><br>0: cycle mode, 1: pulse mode.                                                                                                                                                                                                                                                  |
| 6             | R/W            | 0x0         | <b>SCLK_CH0_GATING.</b><br>Gating the Special Clock for PWM0(0: mask, 1: pass).                                                                                                                                                                                                                             |
| 5             | R/W            | 0x0         | <b>PWM_CH0_ACT_STA.</b><br>PWM Channel 0 Active State.<br>0: Low Level, 1: High Level.                                                                                                                                                                                                                      |
| 4             | R/W            | 0x0         | <b>PWM_CH0_EN.</b><br>PWM Channel 0 Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                                                                       |
| 3:0           | R/W            | 0x0         | <b>PWM_CH0_PRESCAL.</b><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                                                                                                                         |

| Offset: 0x200 |                |             | Register Name: PWM_CTRL_REG                                                                                                                         |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                         |
|               |                |             | 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 |

### 1.8.3.2. PWM CHANNEL 0 PERIOD REGISTER

| Offset: 0x204 |                |             | Register Name: PWM_CH0_PERIOD                                                                                                                                                                                                                                   |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                     |
| 31:16         | R/W            | x           | <b>PWM_CH0_ENTIRE_CYS</b><br>Number of the entire cycles in the PWM clock.<br>0 = 1 cycle<br>1 = 2 cycles<br>.....<br>N = N+1 cycles<br>If the register needs to be modified dynamically, the PCLK should be faster than the PWM CLK(PWM CLK = 24MHz/prescale). |
| 15:0          | R/W            | x           | <b>PWM_CH0_ENTIRE_ACT_CYS</b><br>Number of the active cycles in the PWM clock.<br>0 = 0 cycle<br>1 = 1 cycles<br>.....<br>N = N cycles                                                                                                                          |

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

### 1.8.3.3. PWM CHANNEL 1 PERIOD REGISTER

| Offset: 0x208 |                |             | Register Name: PWM_CH1_PERIOD                                                                                                                                                                                                                                                                                                    |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                      |
| 31:16         | R/W            | x           | <p>PWM_CH1_ENTIRE_CYS<br/>           Number of the entire cycles in the PWM clock.<br/>           0 = 1 cycle<br/>           1 = 2 cycles<br/>           .....<br/>           N = N+1<br/>           If the register needs to be modified dynamically, the PCLK should be faster than the PWM CLK(PWM CLK = 24MHz/prescale).</p> |
| 15:0          | R/W            | x           | <p>PWM_CH1_ENTIRE_CYS<br/>           Number of the active cycles in the PWM clock.<br/>           0 = 0 cycle<br/>           1 = 1 cycles<br/>           .....<br/>           N = N cycles</p>                                                                                                                                   |

## 1.9. Timer

### 1.9.1. Overview

A20 implements 6 timers.

Timer 0 and Timer 1 can take their inputs from internal RC oscillator, external 32768Hz crystal or OSC24M. They provide scheduler interrupt for OS to offer maximum accuracy and efficient management for systems with long or short response time. A 24-bit programmable overflow counter is supported, which can work in auto-reload mode or no-reload mode.

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

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

The real time clock is there for calendar usage. It is built around a 30-bit counter and used to count elapsed time in YY-MM-DD and HH-MM-SS. The unit can be operated by the backup battery while the system is power off. It has a built-in leap year generator and a independent power pin(RTCVDD).

The alarm is used to generate an alarm signal at a specified time in power-off mode or normal operation mode. In normal operation mode, both the alarm interrupt and the power management wakeup are activated while in power-off mode, only the power management wakeup signal is activated.

### 1.9.2. Timer Register List

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

| Register Name       | Offset | Description                     |
|---------------------|--------|---------------------------------|
| TMR_IRQ_EN_REG      | 0x0    | Timer IRQ Enable Register       |
| TMR_IRQ_STA_REG     | 0x4    | Timer Status Register           |
| TMR0_CTRL_REG       | 0x10   | Timer 0 Control Register        |
| TMR0_INTV_VALUE_REG | 0x14   | Timer 0 Interval Value Register |
| TMR0_CUR_VALUE_REG  | 0x18   | Timer 0 Current Value Register  |
| TMR1_CTRL_REG       | 0x20   | Timer 1 Control Register        |
| TMR1_INTV_VALUE_REG | 0x24   | Timer 1 Interval Value Register |
| TMR1_CUR_VALUE_REG  | 0x28   | Timer 1 Current Value Register  |
| TMR2_CTRL_REG       | 0x30   | Timer 2 Control Register        |
| TMR2_INTV_VALUE_REG | 0x34   | Timer 2 Interval Value Register |
| TMR2_CUR_VALUE_REG  | 0x38   | Timer 2 Current Value Register  |
| TMR3_CTRL_REG       | 0x40   | Timer 3 Control Register        |
| TMR3_INTV_VALUE_REG | 0x44   | Timer 3 Interval Value Register |
| TMR4_CTRL_REG       | 0x50   | Timer 4 Control Register        |
| TMR4_INTV_VALUE_REG | 0x54   | Timer 4 Interval Value Register |
| TMR4_CUR_VALUE_REG  | 0x58   | Timer 4 Current Value Register  |
| TMR5_CTRL_REG       | 0x60   | Timer 5 Control Register        |
| TMR5_INTV_VALUE_REG | 0x64   | Timer 5 Interval Value Register |
| TMR5_CUR_VALUE_REG  | 0x68   | Timer 5 Current Value Register  |
| AVS_CNT_CTL_REG     | 0x80   | AVS Control Register            |
| AVS_CNT0_REG        | 0x84   | AVS Counter 0 Register          |
| AVS_CNT1_REG        | 0x88   | AVS Counter 1 Register          |
| AVS_CNT_DIV_REG     | 0x8C   | AVS Divisor Register            |
| WDOG_CTRL_REG       | 0x90   | Watchdog Control Register       |
| WDOG_MODE_REG       | 0x94   | Watchdog Mode Register          |
| LOSC_CTRL_REG       | 0x100  | Low Oscillator Control Register |

| Register Name     | Offset        | Description                                |
|-------------------|---------------|--------------------------------------------|
| RTC YY_MM_DD_REG  | 0x104         | RTC Year-Month-Day Register                |
| RTC HH_MM_SS_REG  | 0x108         | RTC Hour-Minute-Second Register            |
| DD_HH_MM_SS_REG   | 0x10C         | Alarm Day-Hour-Minute-Second Register      |
| ALARM_WK_HH_MM_SS | 0x110         | Alarm Week HMS Register                    |
| ALARM_EN_REG      | 0x114         | Alarm Enable Register                      |
| ALARM_IRQ_EN      | 0x118         | Alarm IRQ Enable Register                  |
| ALARM_IRQ_STA_REG | 0x11C         | Alarm IRQ Status Register                  |
| TMR_GP_DATA_REG   | 0x120 + N*0x4 | Timer General Purpose Register<br>(N=0~15) |
| ALARM_CONFIG_REG  | 0x170         | Alarm Config Register                      |

### 1.9.3. Timer Register Description

#### 1.9.3.1. TIMER IRQ ENABLE REGISTER(DEFAULT: 0X00000000)

| Offset: 0x0 |                |             | Register Name: TMR_IRQ_EN_REG                                                                                    |
|-------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                      |
| 31:9        | /              | /           | /.                                                                                                               |
| 8           | R/W            | 0x0         | WDOG_IRQ_EN.<br>Watchdog Interrupt Enable.<br>0: No effect, 1: watchdog Interval Value reached interrupt enable. |
| 7:6         | /              | /           | /                                                                                                                |
| 5           | R/W            | 0x0         | TMR5_IRQ_EN.<br>Timer 5 Interrupt Enable.<br>0: No effect, 1: Timer 5 Interval Value reached interrupt enable.   |
| 4           | R/W            | 0x0         | TMR4_IRQ_EN.<br>Timer 4 Interrupt Enable.<br>0: No effect, 1: Timer 4 Interval Value reached interrupt enable.   |
| 3           | R/W            | 0x0         | TMR3_IRQ_EN.<br>Timer 3 Interrupt Enable.                                                                        |

| Offset: 0x0 |                |             | Register Name: TMR_IRQ_EN_REG                                                                                  |
|-------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                    |
|             |                |             | 0: No effect, 1: Timer 3 Interval Value reached interrupt enable.                                              |
| 2           | R/W            | 0x0         | TMR2_IRQ_EN.<br>Timer 2 Interrupt Enable.<br>0: No effect, 1: Timer 2 Interval Value reached interrupt enable. |
| 1           | R/W            | 0x0         | TMR1_IRQ_EN.<br>Timer 1 Interrupt Enable.<br>0: No effect, 1: Timer 1 Interval Value reached interrupt enable. |
| 0           | R/W            | 0x0         | TMR0_IRQ_EN.<br>Timer 0 Interrupt Enable.<br>0: No effect, 1: Timer 0 Interval Value reached interrupt enable. |

#### 1.9.3.2. TIMER IRQ STATUS REGISTER(DEFAULT: 0X00000000)

| Offset: 0x4 |                |             | Register Name: TMR_IRQ_STA_REG                                                                                                          |
|-------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                                             |
| 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.   |

| Offset: 0x4 |                |             | Register Name: TMR_IRQ_STA_REG                                                                                                         |
|-------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                                            |
| 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. |

### 1.9.3.3. TIMER 0 CONTROL REGISTER(DEFAULT: 0X00000004)

| Offset: 0x10 |                |             | Register Name: TMR0_CTRL_REG                                                                                                                                                                                    |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                     |
| 31:8         | /              | /           | /.                                                                                                                                                                                                              |
| 7            | R/W            | 0x0         | TMR0_MODE.<br>Timer 0 mode.<br>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically. |
| 6:4          | R/W            | 0x0         | TMR0_CLK_PRES.<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<br>101: /32<br>110: /64<br>111: /128                                                    |
| 3:2          | R/W            | 0x1         | TMR0_CLK_SRC.<br>Timer 0 Clock Source.<br>00: Low speed OSC,<br>01: OSC24M.<br>10: PLL6/6                                                                                                                       |

| Offset: 0x10 |                |             | Register Name: TMR0_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|              |                |             | 11: /.<br><br>TMR0_RELOAD.<br>Timer 0 Reload.<br>0: No effect, 1: Reload timer 0 Interval value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 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><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><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: the time between the timer disabled and enabled should be larger than 2\*Tcycles(Tcycles= Timer clock source/pre-scale).

#### 1.9.3.4. TIMER 0 INTERVAL VALUE REGISTER

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

Note: when you set the value, please take into consideration the system clock and the timer clock source.

#### 1.9.3.5. TIMER 0 CURRENT VALUE REGISTER

| Offset: 0x18 |                |             | Register Name: TMR0_CUR_VALUE_REG |
|--------------|----------------|-------------|-----------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                       |

| Offset: 0x18 |                |             | Register Name: TMR0_CUR_VALUE_REG         |
|--------------|----------------|-------------|-------------------------------------------|
| Bit          | Read/<br>Write | Default/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).

#### 1.9.3.6. TIMER 1 CONTROL REGISTER(DEFAULT: 0X00000004)

| Offset: 0x20 |                |                 | Register Name: TMR1_CTRL_REG                                                                                                                                                                                    |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/He<br>x | Description                                                                                                                                                                                                     |
| 31:8         | /              | /               | /.                                                                                                                                                                                                              |
| 7            | R/W            | 0x0             | TMR1_MODE.<br>Timer 1 mode.<br>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically. |
| 6:4          | R/W            | 0x0             | TMR1_CLK_PRES.<br>Select the pre-scale of timer 1 clock source.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128                                                    |
| 3:2          | R/W            | 0x1             | TMR1_CLK_SRC.<br>Timer 1 Clock Source.<br>00: Low speed OSC,<br>01: OSC24M.<br>10: PLL6/6<br>11: /.                                                                                                             |
| 1            | R/W            | 0x0             | TMR1_RELOAD.<br>Timer 1 Reload.                                                                                                                                                                                 |

| Offset: 0x20 |                |                 | Register Name: TMR1_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              |                |                 | 0: No effect, 1: Reload timer 1 Interval value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0            | R/W            | 0x0             | <p>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.</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> |

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

#### 1.9.3.7. TIMER 1 INTERVAL VALUE REGISTER

| Offset: 0x24 |                |                 | Register Name: TMR1_INTV_VALUE_REG          |
|--------------|----------------|-----------------|---------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                 |
| 31:0         | R/W            | x               | TMR1_INTV_VALUE.<br>Timer 1 Interval Value. |

Note: the value setting should take into consideration the system clock and the timer clock source.

#### 1.9.3.8. TIMER 1 CURRENT VALUE REGISTER

| Offset: 0x28 |                |                 | Register Name: TMR1_CUR_VALUE_REG         |
|--------------|----------------|-----------------|-------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                               |
| 31:0         | R/W            | 0x0             | 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 \times \text{TimerFreq}$  ( $\text{TimerFreq} = \text{TimerClkSource/pre-scale}$ ).

### 1.9.3.9. TIMER 2 CONTROL REGISTER(DEFAULT: 0X00000004)

| Offset: 0x30 |                |             | Register Name: TMR2_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:8         | /              | /           | /.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7            | R/W            | 0x0         | <p>TMR2_MODE.<br/>Timer 2 mode.</p> <p>0: Continuous mode. When interval value reached, the timer will not disable automatically.</p> <p>1: Single mode. When interval value reached, the timer will disable automatically.</p>                                                                                                                                                                                                                                                       |
| 6:4          | R/W            | 0x0         | <p>TMR2_CLK_PRES.<br/>Select the pre-scale of timer 2 clock source.</p> <p>000: /1<br/>001: /2<br/>010: /4<br/>011: /8<br/>100: /16<br/>101: /32<br/>110: /64<br/>111: /128</p>                                                                                                                                                                                                                                                                                                       |
| 3:2          | R/W            | 0x1         | <p>TMR2_CLK_SRC.<br/>Timer 2 Clock Source.</p> <p>00: Low speed OSC,<br/>01: OSC24M.<br/>1x: /.</p>                                                                                                                                                                                                                                                                                                                                                                                   |
| 1            | R/W            | 0x0         | <p>TMR2_RELOAD.<br/>Timer 2 Reload.</p> <p>0: No effect, 1: Reload timer 2 Interval value.</p>                                                                                                                                                                                                                                                                                                                                                                                        |
| 0            | R/W            | 0x0         | <p>TMR2_EN.<br/>Timer 2 Enable.</p> <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</p> |

| Offset: 0x30 |                |             | Register Name: TMR2_CTRL_REG                                                                                                                                                                                |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                 |
|              |                |             | 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: the time between the timer disabled and enabled should be larger than  $2 \times \text{Tcycles}$  ( $\text{Tcycles} = \text{Timer clock source/pre-scale}$ ).

#### 1.9.3.10. TIMER 2 INTERVAL VALUE REGISTER

| Offset: 0x34 |                |             | Register Name: TMR2_INTV_VALUE_REG          |
|--------------|----------------|-------------|---------------------------------------------|
| Bit          | Read/<br>Write | Default/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.

#### 1.9.3.11. TIMER 2 CURRENT VALUE REGISTER

| Offset: 0x38 |                |             | Register Name: TMR2_CUR_VALUE_REG         |
|--------------|----------------|-------------|-------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                               |
| 31:0         | R/W            | 0x0         | 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 \times \text{TimerFreq}$  ( $\text{TimerFreq} = \text{TimerClkSource/pre-scale}$ ).

#### 1.9.3.12. TIMER 3 CONTROL REGISTER(DEFAULT: 0X00000000)

| Offset: 0x40 |                |             | Register Name: TMR3_CTRL_REG                                                        |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                         |
| 31:5         | /              | /           | /.                                                                                  |
| 4            | R/W            | 0x0         | TMR3_MODE.<br>Timer 3 mode.<br>0: Continuous mode. When interval value reached, the |

| Offset: 0x40 |                |             | Register Name: TMR3_CTRL_REG                                                                                                                   |
|--------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                    |
|              |                |             | timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically.                    |
| 3:2          | R/W            | 0x0         | TMR3_CLK_PRES.<br>Select the pre-scale of timer 3 clock source.<br>Timer 3 clock source is the LOSC.<br>00: /16<br>01: /32<br>10: /64<br>11: / |
| 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).

#### 1.9.3.13. TIMER 3 INTERVAL VALUE REGISTER

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

#### 1.9.3.14. TIMER 4 CONTROL REGISTER(DEFAULT: 0X00000004)

| Offset: 0x50 |                |             | Register Name: TMR4_CTRL_REG                                                        |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                         |
| 31:8         | /              | /           | /.                                                                                  |
| 7            | R/W            | 0x0         | TMR4_MODE.<br>Timer 4 mode.<br>0: Continuous mode. When interval value reached, the |

| Offset: 0x50 |                |             | Register Name: TMR4_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              |                |             | timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6:4          | R/W            | 0x0         | TMR4_CLK_PRES.<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: Low speed OSC,<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 4 Interval value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 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\*Tcycles(Tcycles= Timer clock source/pre-scale).

#### **1.9.3.15. TIMER 4 INTERVAL VALUE REGISTER**

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

Note: the value setting should take the system clock and the timer clock source into consideration.

#### **1.9.3.16. TIMER 4 CURRENT VALUE REGISTER**

| Offset: 0x58 |                |             | Register Name: TMR4_CUR_VALUE_REG         |
|--------------|----------------|-------------|-------------------------------------------|
| Bit          | Read/<br>Write | Default/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, the timer 4 current value register needs to be written with zero.

#### **1.9.3.17. TIMER 5 CONTROL REGISTER(DEFAULT: 0X00000004)**

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

| Offset: 0x60 |                |             | Register Name: TMR5_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              |                |             | 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.<br>00: Low speed OSC,<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 5 Interval value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 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 counts from 0;
- 2) The time between the timer disabled and enabled should be larger than 2\*Tcycles(Tcycles= Timer clock source/pre-scale).

### 1.9.3.18. TIMER 5 INTERVAL VALUE REGISTER

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

Note: When you set the value, please take into consideration the system clock and the timer clock source.

### 1.9.3.19. TIMER 5 CURRENT VALUE REGISTER

| Offset: 0x68 |                |             | Register Name: TMR5_CUR_VALUE_REG         |
|--------------|----------------|-------------|-------------------------------------------|
| Bit          | Read/<br>Write | Default/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, timer 5 current value register needs to be written with zero.

### 1.9.3.20. AVS COUNTER CONTROL REGISTER(DEFAULT: 0X00000000)

| Offset: 0x80 |                |         | Register Name: AVS_CNT_CTL_REG                                                                |
|--------------|----------------|---------|-----------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default | Description                                                                                   |
| 31:1<br>0    | /              | /       | /                                                                                             |
| 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 |

| Offset: 0x80 |             |         | Register Name: AVS_CNT_CTL_REG                                                                                                         |
|--------------|-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read /Write | Default | Description                                                                                                                            |
| 7:2          | /           | /       | /                                                                                                                                      |
| 1            | R/W         | 0x0     | <p>AVS_CNT1_EN</p> <p>Audio/Video Sync Counter 1 Enable/ Disable. The counter source is OSC24M.</p> <p>0: Disable</p> <p>1: Enable</p> |
| 0            | R/W         | 0x0     | <p>AVS_CNT0_EN</p> <p>Audio/Video Sync Counter 1 Enable/ Disable. The counter source is OSC24M.</p> <p>0: Disable</p> <p>1: Enable</p> |

#### 1.9.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     | <p>AVS_CNT0</p> <p>Counter 0 for Audio/ Video Sync Application</p> <p>The high 32 bits of the internal 33-bits 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.</p> |

#### 1.9.3.22. AVS COUNTER 1 REGISTER(DEFAULT: 0X00000000)

| Offset: 0x88 |             |         | Register Name: AVS_CNT1_REG                                                                                                                                                                                |
|--------------|-------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Writ e | 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 counter register. The initial value of the internal 33-bits counter register can be set</p> |

| Offset: 0x88 |             |         | Register Name: AVS_CNT1_REG                                                                                                                                                                                                                                                                        |
|--------------|-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Writ e | Default | Description                                                                                                                                                                                                                                                                                        |
|              |             |         | 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. |

### 1.9.3.23. AVS COUNTER DIVISOR REGISTER(DEFAULT: 0X05DB05DB)

| Offset: 0x8C |             |         | Register Name: AVS_CNT_DIV_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>AVS CN1 CLK=24MHz/Divisor_N1.</p> <p>Divisor N1 = Bit[27:16] + 1.</p> <p>The number N is from 1 to 0x7ff. The zero value is reserved.</p> <p>The internal 33-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>AVS CN0 CLK=24MHz/Divisor_N0.</p> <p>Divisor N0 = Bit[11:0] + 1</p> <p>The number N is from 1 to 0x7ff. The zero value is reserved.</p> <p>The internal 33-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>   |

#### 1.9.3.24. WATCHDOG CONTROL REGISTER

| Offset: 0x90 |                |             | Register Name: WDOG_CTRL_REG                                                  |
|--------------|----------------|-------------|-------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                   |
| 31:1         | /              | /           | /.                                                                            |
| 0            | R/W            | 0x0         | WDOG_RSTSTART.<br>Watchdog Restart.<br>0: No effect, 1: Restart the Watchdog. |

#### 1.9.3.25. WATCHDOG MODE REGISTER(DEFAULT: 0X00000000)

| Offset: 0x94 |                |             | Register Name: WDOG_MODE_REG                                                                                                                                                                                                                                                                                                                                       |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                        |
| 31: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: / |

| Offset: 0x94 |                |             | Register Name: WDOG_MODE_REG                                                                                                   |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                    |
| 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.                                                          |

#### 1.9.3.26. LOSC CONTROL REGISTER (DEFAULT: 0X00004000)

| Offset: 0x100 |                |             | Register Name: LOSC_CTRL_REG                                                                                                                                                                                                                                                          |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                           |
| 31:16         | W              | 0x0         | KEY_FIELD.<br>Key Field. This field should be filled with 0x16AA, then the bit 0 can be written with the new value.                                                                                                                                                                   |
| 15            | R/W            | 0x0         | CLK32K_AUTO_SWT_PEND.<br>CLK32K auto switch pending.<br>0: no effect, 1: auto switch pending.                                                                                                                                                                                         |
| 14            | R/W            | 0x1         | CLK32K_AUTO_SWT_EN.<br>CLK32K auto switch enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                                           |
| 13:10         | /              | /           | /.                                                                                                                                                                                                                                                                                    |
| 9             | R/W            | 0x0         | ALM_DDHHMMSS_ACCE.<br>ALARM DD-HH-MM-SS access.<br>After writing the ALARM DD-HH-MM-SS register, this bit is set and it will be cleared until the real writing operation is finished.                                                                                                 |
| 8             | R/W            | 0x0         | RTC_HHMMSS_ACCE.<br>RTC HH-MM-SS access.<br>After writing the RTC HH-MM-SS register, this bit is set and it will be cleared until the real writing operation is finished.<br>After writing the RTC YY-MM-DD register, the YY-MM-DD register will be refreshed for at most one second. |

| Offset: 0x100 |                |             | Register Name: LOSC_CTRL_REG                                                                                                                                                                                                                                                          |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                           |
| 7             | R/W            | 0x0         | RTC_YYMMDD_ACCE.<br>RTC YY-MM-DD access.<br>After writing the RTC YY-MM-DD register, this bit is set and it will be cleared until the real writing operation is finished.<br>After writing the RTC YY-MM-DD register, the YY-MM-DD register will be refreshed for at most one second. |
| 6:4           | /              | /           | /                                                                                                                                                                                                                                                                                     |
| 3:2           | R/W            | 0x0         | EXT_LOSC_GSM.<br>External 32768Hz Crystal GSM.<br>00 low<br>01<br>10<br>11 high                                                                                                                                                                                                       |
| 1             | /              | /           | /                                                                                                                                                                                                                                                                                     |
| 0             | R/W            | 0x0         | OSC32K_SRC_SEL.<br>OSC32KHz Clock source Select.<br>0: Internal 32khz, 1: External 32.768Khz OSC.                                                                                                                                                                                     |

Note: If any bit of [9:7] is set, the RTC HH-MM-SS, YY-MM-DD and ALARM DD-HH-MM-SS register can't be written.

#### 1.9.3.27. RTC YY-MM-DD REGISTER (DEFAULT: 0X00000000)

| Offset: 0x104 |                |             | Register Name: RTC_YY_MM_DD_REG                                                                                          |
|---------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                              |
| 31            | R/W            | 0x0         | /                                                                                                                        |
| 30            | R/W            | 0x0         | RTC_SIM_CTRL.<br>RTC Simulation Control bit.                                                                             |
| 29:25         | /              | /           | /.                                                                                                                       |
| 24            | R/W            | 0x0         | LEAP.<br>Leap Year.<br>0: not, 1: Leap year.<br>This bit can not set by hardware. It should be set or clear by software. |

| Offset: 0x104 |                |             | Register Name: RTC_YY_MM_DD_REG      |
|---------------|----------------|-------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                          |
| 23:16         | R/W            | x           | YEAR.<br>Year.<br>Range from 0~255.  |
| 15:12         | /              | /           | /.                                   |
| 11:8          | R/W            | x           | MONTH.<br>Month.<br>Range from 1~12. |
| 7:5           | /              | /           | /.                                   |
| 4:0           | R/W            | x           | DAY.<br>Day.<br>Range from 1~31.     |

#### 1.9.3.28. RTC HH-MM-SS REGISTER

| Offset: 0x108 |                |             | Register Name: RTC_HH_MM_SS_REG                                                                                                                   |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                       |
| 31:29         | R/W            | 0x0         | WK_NO.<br>Week number.<br>000: Monday<br>001: Tuesday<br>010: Wednesday<br>011: Thursday<br>100: Friday<br>101: Saturday<br>110: Sunday<br>111: / |
| 28:21         | /              | /           | /.                                                                                                                                                |
| 20:16         | R/W            | x           | HOUR.<br>Range from 0~23                                                                                                                          |
| 15:14         | /              | /           | /.                                                                                                                                                |
| 13:8          | R/W            | x           | MINUTE.<br>Range from 0~59                                                                                                                        |

| Offset: 0x108 |                |             | Register Name: RTC_HH_MM_SS_REG |
|---------------|----------------|-------------|---------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                     |
| 7:6           | /              | /           | /.                              |
| 5:0           | R/W            | x           | SECOND.<br>Range from 0~59      |

#### 1.9.3.29. ALARM COUNTER DD-HH-MM-SS REGISTER

| Offset: 0x10C |                |             | Register Name: DD_HH_MM_SS_REG |
|---------------|----------------|-------------|--------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                    |
| 31:24         | R/W            | x           | DAY.<br>Range from 0~255.      |
| 23:22         | /              | /           | /                              |
| 20:16         | R/W            | x           | HOUR.<br>Range from 0~23.      |
| 15:14         | /              | /           | /.                             |
| 13:8          | R/W            | x           | MINUTE.<br>Range from 0~59.    |
| 7:6           | /              | /           | /.                             |
| 5:0           | R/W            | x           | SECOND.<br>Range from 0~59.    |

#### 1.9.3.30. ALARM WEEK HH-MM-SS REGISTER

| Offset: 0x110 |                |             | Register Name: ALARM_WK_HH_MM_SS |
|---------------|----------------|-------------|----------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                      |
| 31:21         | /              | /           | /                                |
| 20:16         | R/W            | x           | HOUR.<br>Range from 0~23.        |
| 15:14         | /              | /           | /.                               |
| 13:8          | R/W            | x           | MINUTE.                          |

| Offset: 0x110 |                |             | Register Name: ALARM_WK_HH_MM-SS |
|---------------|----------------|-------------|----------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                      |
|               |                |             | Range from 0~59.                 |
| 7:6           | /              | /           | /.                               |
| 5:0           | R/W            | x           | SECOND.<br>Range from 0~59.      |

### 1.9.3.31. ALARM ENABLE REGISTER

| Offset: 0x114 |                |             | Register Name: ALARM_EN_REG                                                                                                                                                                                                                                                                       |
|---------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                       |
|               |                |             | /.                                                                                                                                                                                                                                                                                                |
| 8             | R/W            | 0x0         | ALM_CNT_EN.<br>Alarm Counter Enable.<br>If this bit is set to "1", the Alarm Counter DD-HH-MM-SS register's valid bits will down count to zero, and the alarm pending bit will be set to "1".<br>0:disable,<br>1:enable.                                                                          |
| 7             | /              | /           | /                                                                                                                                                                                                                                                                                                 |
| 6             | R/W            | 0x0         | WK6_ALM_EN.<br>Week 6(Sunday) Alarm Enable.<br>0: Disable, 1: Enable.<br>If this bit is set to "1", only when the Alarm Week HH-MM-SS register valid bits is equal to RTC HH-MM-SS register and the register RTC HH-MM-SS bit[31:29] is 6, the week 6 alarm irq pending bit will be set to "1".   |
| 5             | R/W            | 0x0         | WK5_ALM_EN.<br>Week 5(Saturday) Alarm Enable.<br>0: Disable, 1: Enable.<br>If this bit is set to "1", only when the Alarm Week HH-MM-SS register valid bits is equal to RTC HH-MM-SS register and the register RTC HH-MM-SS bit[31:29] is 5, the week 5 alarm irq pending bit will be set to "1". |
| 4             | R/W            | 0x0         | WK4_ALM_EN.<br>Week 4(Friday) Alarm Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                                                             |

| Offset: 0x114 |                |             | Register Name: ALARM_EN_REG                                                                                                                                                                                                                                                                                     |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                     |
|               |                |             | If this bit is set to “1”, only when the Alarm Week HH-MM-SS register valid bits is equal to RTC HH-MM-SS register and the register RTC HH-MM-SS bit[31:29] is 4, the week 4 alarm irq pending bit will be set to “1”.                                                                                          |
| 3             | R/W            | 0x0         | <p>WK3_ALM_EN.<br/>Week 3(Thursday) Alarm Enable.<br/>0: Disable, 1: Enable.</p> <p>If this bit is set to “1”, only when the Alarm Week HH-MM-SS register valid bits is equal to RTC HH-MM-SS register and the register RTC HH-MM-SS bit[31:29] is 3, the week 3 alarm irq pending bit will be set to “1”.</p>  |
| 2             | R/W            | 0x0         | <p>WK2_ALM_EN.<br/>Week 2(Wednesday) Alarm Enable.<br/>0: Disable, 1: Enable.</p> <p>If this bit is set to “1”, only when the Alarm Week HH-MM-SS register valid bits is equal to RTC HH-MM-SS register and the register RTC HH-MM-SS bit[31:29] is 2, the week 2 alarm irq pending bit will be set to “1”.</p> |
| 1             | R/W            | 0x0         | <p>WK1_ALM_EN.<br/>Week 1(Tuesday) Alarm Enable.<br/>0: Disable, 1: Enable.</p> <p>If this bit is set to “1”, only when the Alarm Week HH-MM-SS register valid bits is equal to RTC HH-MM-SS register and the register RTC HH-MM-SS bit[31:29] is 1, the week 1 alarm irq pending bit will be set to “1”.</p>   |
| 0             | R/W            | 0x0         | <p>WK0_ALM_EN.<br/>Week 0(Monday) Alarm Enable.<br/>0: Disable, 1: Enable.</p> <p>If this bit is set to “1”, only when the Alarm Week HH-MM-SS register valid bits is equal to RTC HH-MM-SS register and the register RTC HH-MM-SS bit[31:29] is 0, the week 0 alarm irq pending bit will be set to “1”.</p>    |

### 1.9.3.32. ALARM IRQ ENABLE REGISTER

|               |                             |
|---------------|-----------------------------|
| Offset: 0x118 | Register Name: ALARM_IRQ_EN |
|---------------|-----------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                     |
|------------|------------------------|--------------------|------------------------------------------------------------------------|
| 31:2       | /                      | /                  | /.                                                                     |
| 1          | R/W                    | 0x0                | ALARM_WK_IRQ_EN.<br>Alarm Week IRQ Enable.<br>0:disable, 1:enable.     |
| 0          | R/W                    | 0x0                | ALARM_CNT_IRQ_EN.<br>Alarm Counter IRQ Enable.<br>0:disable, 1:enable. |

#### 1.9.3.33. ALARM IRQ STATUS REGISTER

| <b>Offset: 0x11C</b> |                        |                    | <b>Register Name: ALARM_IRQ_STA_REG</b>                                                                                                                                                                                  |
|----------------------|------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                                                                                                       |
| 31:2                 | /                      | /                  | /.                                                                                                                                                                                                                       |
| 1                    | R/W                    | 0x0                | WEEK_IRQ_PEND.<br>Alarm Week (0/1/2/3/4/5/6) IRQ Pending.<br>0: No effect, 1: Pending, week counter value is reached.<br>If alarm week irq enable is set to 1, the pending bit will be sent to the interrupt controller. |
| 0                    | R/W                    | 0x0                | CNT_IRQ_PEND.<br>Alarm Counter IRQ Pending bit.<br>0: No effect, 1: Pending, alarm counter value is reached.<br>If alarm counter irq enable is set to 1, the pending bit will be sent to the interrupt controller.       |

#### 1.9.3.34. TIMER GENERAL PURPOSE REGISTER

| <b>Offset: 0x120+N*0x4<br/>(N=0~15)</b> |                        |                    | <b>Register Name: TMR_GP_DATA_REG</b> |
|-----------------------------------------|------------------------|--------------------|---------------------------------------|
| <b>Bit</b>                              | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                    |
| 31:0                                    | R/W                    | x                  | TMR_GP_DATA.<br>Data[31:0].           |

Note: Timer general purpose register value can be stored if the RTCVDD is above 1.0V.

### 1.9.3.35. ALARM CONFIG REGISTER (DEFAULT: 0X00000000)

| Offset:0x170 |                |             | Register Name: ALARM_CONFIG_REG                                                                                                |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                    |
| 31:1         | /              | /           | /                                                                                                                              |
| 0            | R/W            | 0x0         | ALARM_WAKEUP.<br>Configuration of alarm wake up output.<br>0: disable alarm wake up output;<br>1: enable alarm wake up output. |

## 1.10. High Speed Timer

### 1.10.1. Overview

The A20 supports four high speed timers, whose clock sources are fixed to AHBCLK.

### 1.10.2. High Speed Timer Register List

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

| Register Name        | Offset | Description                             |
|----------------------|--------|-----------------------------------------|
| HS_TMR_IRQ_EN_REG    | 0x0    | HS Timer IRQ Enable Register            |
| HS_TMR_IRQ_STAS_REG  | 0x4    | HS Timer Status Register                |
| HS_TMR0_CTRL_REG     | 0x10   | HS Timer 0 Control Register             |
| HS_TMR0_INTV_LO_REG  | 0x14   | HS Timer 0 Interval Value Low Register  |
| HS_TMR0_INTV_HI_REG  | 0x18   | HS Timer 0 Interval Value High Register |
| HS_TMR0_CURNT_LO_REG | 0x1C   | HS Timer 0 Current Value Low Register   |
| HS_TMR0_CURNT_HI_REG | 0x20   | HS Timer 0 Current Value High Register  |
| HS_TMR1_CTRL_REG     | 0x30   | HS Timer 1 Control Register             |
| HS_TMR1_INTV_LO_REG  | 0x34   | HS Timer 1 Interval Value Low Register  |
| HS_TMR1_INTV_HI_REG  | 0x38   | HS Timer 1 Interval Value High Register |
| HS_TMR1_CURNT_LO_REG | 0x3C   | HS Timer 1 Current Value Low Register   |
| HS_TMR1_CURNT_HI_REG | 0x40   | HS Timer 1 Current Value High Register  |
| HS_TMR2_CTRL_REG     | 0x50   | HS Timer 2 Control Register             |
| HS_TMR2_INTV_LO_REG  | 0x54   | HS Timer 2 Interval Value Low Register  |
| HS_TMR2_INTV_HI_REG  | 0x58   | HS Timer 2 Interval Value High Register |
| HS_TMR2_CURNT_LO_REG | 0x5C   | HS Timer 2 Current Value Low Register   |
| HS_TMR2_CURNT_HI_REG | 0x60   | HS Timer 2 Current Value High Register  |
| HS_TMR3_CTRL_REG     | 0x70   | HS Timer 3 Control Register             |
| HS_TMR3_INTV_LO_REG  | 0x74   | HS Timer 3 Interval Value Low Register  |
| HS_TMR3_INTV_HI_REG  | 0x78   | HS Timer 3 Interval Value High Register |
| HS_TMR3_CURNT_LO_REG | 0x7C   | HS Timer 3 Current Value Low Register   |
| HS_TMR3_CURNT_HI_REG | 0x80   | HS Timer 3 Current Value High Register  |

### 1.10.3. High Speed Timer Controller Register

#### 1.10.3.1. HS TIMER IRQ ENABLE REGISTER (DEFAULT: 0X00000000)

| Offset:0x0 |                |             | Register Name: HS_TMR_IRQ_EN_REG                                                                                                           |
|------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit        | Read/<br>Write | Default/Hex | Description                                                                                                                                |
| 31:4       | /              | /           | /                                                                                                                                          |
| 3          | R/W            | 0x0         | HS_TMR3_INT_EN.<br>High Speed Timer 3 Interrupt Enable.<br>0: No effect;<br>1: High Speed Timer 3 Interval Value reached interrupt enable. |
| 2          | R/W            | 0x0         | HS_TMR2_INT_EN.<br>High Speed Timer 2 Interrupt Enable.<br>0: No effect;<br>1: High Speed Timer 2 Interval Value reached interrupt enable. |
| 1          | R/W            | 0x0         | HS_TMR1_INT_EN.<br>High Speed Timer 1 Interrupt Enable.<br>0: No effect;<br>1: High Speed Timer 1 Interval Value reached interrupt enable. |
| 0          | R/W            | 0x0         | HS_TMR0_INT_EN.<br>High Speed Timer 0 Interrupt Enable.<br>0: No effect;<br>1: High Speed Timer 0 Interval Value reached interrupt enable. |

#### 1.10.3.2. HS TIMER IRQ STATUS REGISTER (DEFAULT: 0X00000000)

| Offset:0x4 |                |             | Register Name: HS_TMR_IRQ_STAS_REG                                                   |
|------------|----------------|-------------|--------------------------------------------------------------------------------------|
| Bit        | Read/<br>Write | Default/Hex | Description                                                                          |
| 31:4       | /              | /           | /                                                                                    |
| 3          | R/W            | 0x0         | HS_TMR3_IRQ_PEND.<br>High Speed Timer 3 IRQ Pending. Set 1 to the bit will clear it. |

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

#### 1.10.3.3. HS TIMER 0 CONTROL REGISTER (DEFAULT: 0X00000000)

| Offset:0x10 |                |                 | Register Name: HS_TMR0_CTRL_REG                                                                                                                                                                                               |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/He<br>x | Description                                                                                                                                                                                                                   |
| 31          | R/W            | 0x0             | /                                                                                                                                                                                                                             |
| 30:8        | /              | /               | /                                                                                                                                                                                                                             |
| 7           | R/W            | 0x0             | HS_TMR0_MODE.<br>High Speed Timer 0 mode.<br>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically. |
| 6:4         | R/W            | 0x0             | HS_TMR0_CLK<br>Select the pre-scale of the high speed timer 0 clock sources.<br>000: /1<br>001: /2<br>010: /4<br>011: /8                                                                                                      |

| Offset:0x10 |                |                 | Register Name: HS_TMR0_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|             |                |                 | 100: /16<br>101: /<br>110: /<br>111: /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3:2         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1           | R/W            | 0x0             | HS_TMR0_RELOAD.<br>High Speed Timer 0 Reload.<br>0: No effect, 1: Reload High Speed Timer 0 Interval Value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0           | R/W            | 0x0             | HS_TMR0_EN.<br>High Speed Timer 0 Enable.<br>0: Stop/Pause, 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><br>If the current counter does not reach the zero, the timer enable bit is set to "0", the current value counter will pause. At least wait for 2 cycles, the start bit can be set to 1.<br><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. |

#### 1.10.3.4. HS TIMER 0 INTERVAL VALUE LO REGISTER

| Offset:0x14 |                |                 | Register Name: HS_TMR0_INTV_LO_REG                                  |
|-------------|----------------|-----------------|---------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/H<br>ex | Description                                                         |
| 31:0        | R/W            | x               | HS_TMR0_INTV_VALUE_LO.<br>High Speed Timer 0 Interval Value [31:0]. |

#### 1.10.3.5. HS TIMER 0 INTERVAL VALUE HI REGISTER

| Offset:0x18 | Register Name: HS_TMR0_INTV_HI_REG |
|-------------|------------------------------------|
|-------------|------------------------------------|

| Bit   | Read/<br>Write | Default/Hex | Description                                                          |
|-------|----------------|-------------|----------------------------------------------------------------------|
| 31:24 | /              | /           | /                                                                    |
| 23:0  | R/W            | x           | HS_TMR0_INTV_VALUE_HI.<br>High Speed Timer 0 Interval Value [55:32]. |

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

#### 1.10.3.6. HS TIMER 0 CURRENT VALUE LO REGISTER

| Offset:0x1C |                |             | Register Name: HS_TMR0_CURNT_LO_REG                               |
|-------------|----------------|-------------|-------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                       |
| 31:0        | R/W            | x           | HS_TMR0_CUR_VALUE_LO.<br>High Speed Timer 0 Current Value [31:0]. |

#### 1.10.3.7. HS TIMER 0 CURRENT VALUE HI REGISTER

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

Note:

- 1) HS 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 Lo register should be read or written first.

#### 1.10.3.8. HS TIMER 1 CONTROL REGISTER (DEFAULT: 0X00000000)

| Offset:0x30 |                |             | Register Name: HS_TMR1_CTRL_REG |
|-------------|----------------|-------------|---------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                     |
| 31          | R/W            | 0x0         | /                               |
| 30:8        | /              | /           | /                               |

| Offset:0x30 |                |                 | Register Name:HS_TMR1_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7           | R/W            | 0x0             | <p>HS_TMR1_MODE.</p> <p>High Speed Timer 1 mode.</p> <p>0: Continuous mode. When interval value reached, the timer will not disable automatically.</p> <p>1: Single mode. When interval value reached, the timer will disable automatically.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6:4         | R/W            | 0x0             | <p>HS_TMR1_CLK_SRC.</p> <p>Select the pre-scale of the high speed timer 1 clock sources.</p> <p>000: /1</p> <p>001: /2</p> <p>010: /4</p> <p>011: /8</p> <p>100: /16</p> <p>101: /</p> <p>110: /</p> <p>111: /</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3:2         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1           | R/W            | 0x0             | <p>HS_TMR1_RELOAD.</p> <p>High Speed Timer 1 Reload.</p> <p>0: No effect, 1: Reload High Speed Timer 1 Interval Value.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0           | R/W            | 0x0             | <p>HS_TMR1_EN.</p> <p>High Speed Timer 1 Enable.</p> <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 cycles, 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> |

### 1.10.3.9. HS TIMER 1 INTERVAL VALUE LO REGISTER

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

### 1.10.3.10. HS TIMER 1 INTERVAL VALUE HI REGISTER

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

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

### 1.10.3.11. HS TIMER 1 CURRENT VALUE LO REGISTER

| Offset:0x3C |                |             | Register Name: HS_TMR1_CURNT_LO_REG                               |
|-------------|----------------|-------------|-------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                       |
| 31:0        | R/W            | x           | HS_TMR1_CUR_VALUE_LO.<br>High Speed Timer 1 Current Value [31:0]. |

### 1.10.3.12. HS TIMER 1 CURRENT VALUE HI REGISTER

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

Note:

- 1) HS timer 1 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.

#### **1.10.3.13. HS TIMER 2 CONTROL REGISTER (DEFAULT: 0X00000000)**

| Offset:0x50 |                |             | Register Name: HS_TMR2_CTRL_REG                                                                                                                                                                                                                                                            |
|-------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                |
| 31          | R/W            | 0x0         | /                                                                                                                                                                                                                                                                                          |
| 30:8        | /              | /           | /                                                                                                                                                                                                                                                                                          |
| 7           | R/W            | 0x0         | HS_TMR2_MODE.<br>High Speed Timer 2 mode.<br>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically.                                                              |
| 6:4         | R/W            | 0x0         | HS_TMR0_CLK<br>Select the pre-scale of the high speed timer 0 clock sources.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /<br>110: /<br>111: /                                                                                                                         |
| 3:2         | /              | /           | /                                                                                                                                                                                                                                                                                          |
| 1           | R/W            | 0x0         | HS_TMR2_RELOAD.<br>High Speed Timer 2 Reload.<br>0: No effect, 1: Reload High Speed Timer 2 Interval Value.                                                                                                                                                                                |
| 0           | R/W            | 0x0         | HS_TMR2_EN.<br>High Speed 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 |

| Offset:0x50 |                |                 | Register Name: HS_TMR2_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/He<br>x | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|             |                |                 | <p>bit is set to “0”, the current value counter will pause. At least wait for 2 cycles, the start bit can be set to 1.</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> |

#### 1.10.3.14. HS TIMER 2 INTERVAL VALUE LO REGISTER

| Offset:0x54 |                |                 | Register Name: HS_TMR2_INTV_LO_REG                                          |
|-------------|----------------|-----------------|-----------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/He<br>x | Description                                                                 |
| 31:0        | R/W            | x               | <p>HS_TMR2_INTV_VALUE_LO.<br/>High Speed Timer 2 Interval Value [31:0].</p> |

#### 1.10.3.15. HS TIMER 2 INTERVAL VALUE HI REGISTER

| Offset:0x58 |                |                 | Register Name: HS_TMR2_INTV_HI_REG                                           |
|-------------|----------------|-----------------|------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/He<br>x | Description                                                                  |
| 31:24       | /              | /               | /                                                                            |
| 23:0        | R/W            | x               | <p>HS_TMR2_INTV_VALUE_HI.<br/>High Speed Timer 2 Interval Value [55:32].</p> |

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

#### 1.10.3.16. HS TIMER 2 CURRENT VALUE LO REGISTER

| Offset: 0x5C |                |                 | Register Name: HS_TMR2_CURNT_LO_REG                                       |
|--------------|----------------|-----------------|---------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                               |
| 31:0         | R/W            | x               | <p>HS_TMR2_CUR_VALUE_LO.<br/>High Speed Timer 2 Current Value [31:0].</p> |

### 1.10.3.17. HS TIMER 2 CURRENT VALUE HI REGISTER

| Offset: 0x60 |                |                 | Register Name: HS_TMR2_CURNT_HI_REG                                |
|--------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                        |
| 31:24        | /              | /               | /                                                                  |
| 23:0         | R/W            | x               | HS_TMR2_CUR_VALUE_HI.<br>High Speed Timer 2 Current Value [55:32]. |

Note:

- 1) High speed timer 2 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 Lo register should be read or written first.

### 1.10.3.18. HS TIMER 3 CONTROL REGISTER (DEFAULT: 0X00000000)

| Offset: 0x70 |                |             | Register Name: HS_TMR3_CTRL_REG                                                                                                                                                                                               |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                   |
| 31           | R/W            | 0x0         | /                                                                                                                                                                                                                             |
| 30:8         | /              | /           | /                                                                                                                                                                                                                             |
| 7            | R/W            | 0x0         | HS_TMR3_MODE.<br>High Speed Timer 3 mode.<br>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically. |
| 6:4          | R/W            | 0x0         | HS_TMR3_CLK_SRC.<br>Select the pre-scale of the high speed timer 3 clock sources.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /<br>110: /<br>111: /                                                       |
| 3:2          | /              | /           | /                                                                                                                                                                                                                             |
| 1            | R/W            | 0x0         | HS_TMR3_RELOAD.                                                                                                                                                                                                               |

| Offset: 0x70 |                |             | Register Name: HS_TMR3_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|              |                |             | High Speed Timer 3 Reload.<br>0: No effect, 1: Reload High Speed Timer 3 Interval Value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0            | R/W            | 0x0         | HS_TMR3_EN.<br>High Speed Timer 3 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 cycles, 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. |

#### 1.10.3.19. HS TIMER 3 INTERVAL VALUE LO REGISTER

| Offset: 0x74 |                |             | Register Name: HS_TMR3_INTV_LO_REG                                  |
|--------------|----------------|-------------|---------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                         |
| 31:0         | R/W            | x           | HS_TMR3_INTV_VALUE_LO.<br>High Speed Timer 3 Interval Value [31:0]. |

#### 1.10.3.20. HS TIMER 3 INTERVAL VALUE HI REGISTER

| Offset: 0x78 |                |             | Register Name: HS_TMR3_INTV_HI_REG                                   |
|--------------|----------------|-------------|----------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                          |
| 31:24        | /              | /           | /                                                                    |
| 23:0         | R/W            | x           | HS_TMR3_INTV_VALUE_HI.<br>High Speed Timer 3 Interval Value [55:32]. |

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

### 1.10.3.21. HS TIMER 3 CURRENT VALUE LO REGISTER

| Offset: 0x7C |                |             | Register Name: HS_TMR3_CURNT_LO_REG                               |
|--------------|----------------|-------------|-------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                       |
| 31:0         | R/W            | x           | HS_TMR3_CUR_VALUE_LO.<br>High Speed Timer 3 Current Value [31:0]. |

### 1.10.3.22. HS TIMER 3 CURRENT VALUE HI REGISTER

| Offset: 0x80 |                |             | Register Name: HS_TMR3_CURNT_HI_REG                                |
|--------------|----------------|-------------|--------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                        |
| 31:24        | /              | /           | /                                                                  |
| 23:0         | R/W            | x           | HS_TMR3_CUR_VALUE_HI.<br>High Speed Timer 3 Current Value [55:32]. |

Note:

- 1) High speed timer 1 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.

## 1.11. GIC

For details about GIC, please refer to the GIC PL400 technical reference manual and ARM GIC Architecture Specification V2.0.

### 1.11.1. Interrupt Source

| Interrupt Source | SRC | Vector | FIQ | Description      |
|------------------|-----|--------|-----|------------------|
| SGI 0            | 0   |        |     | SGI 0 interrupt  |
| SGI 1            | 1   |        |     | SGI 1 interrupt  |
| SGI 2            | 2   |        |     | SGI 2 interrupt  |
| SGI 3            | 3   |        |     | SGI 3 interrupt  |
| SGI 4            | 4   |        |     | SGI 4 interrupt  |
| SGI 5            | 5   |        |     | SGI 5 interrupt  |
| SGI 6            | 6   |        |     | SGI 6 interrupt  |
| SGI 7            | 7   |        |     | SGI 7 interrupt  |
| SGI 8            | 8   |        |     | SGI 8 interrupt  |
| SGI 9            | 9   |        |     | SGI 9 interrupt  |
| SGI 10           | 10  |        |     | SGI 10 interrupt |
| SGI 11           | 11  |        |     | SGI 11 interrupt |
| SGI 12           | 12  |        |     | SGI 12 interrupt |
| SGI 13           | 13  |        |     | SGI 13 interrupt |
| SGI 14           | 14  |        |     | SGI 14 interrupt |
| SGI 15           | 15  |        |     | SGI 15 interrupt |
| PPI 0            | 16  |        |     | PPI 0 interrupt  |
| PPI 1            | 17  |        |     | PPI 1 interrupt  |
| PPI 2            | 18  |        |     | PPI 2 interrupt  |
| PPI 3            | 19  |        |     | PPI 3 interrupt  |
| PPI 4            | 20  |        |     | PPI 4 interrupt  |

| <b>Interrupt Source</b> | <b>SRC</b> | <b>Vector</b> | <b>FIQ</b> | <b>Description</b>                   |
|-------------------------|------------|---------------|------------|--------------------------------------|
| PPI 5                   | 21         |               |            | PPI 5 interrupt                      |
| PPI 6                   | 22         |               |            | PPI 6 interrupt                      |
| PPI 7                   | 23         |               |            | PPI 7 interrupt                      |
| PPI 8                   | 24         |               |            | PPI 8 interrupt                      |
| PPI 9                   | 25         |               |            | PPI 9 interrupt                      |
| PPI 10                  | 26         |               |            | PPI 10 interrupt                     |
| PPI 11                  | 27         |               |            | PPI 11 interrupt                     |
| PPI 12                  | 28         |               |            | PPI 12 interrupt                     |
| PPI 13                  | 29         |               |            | PPI 13 interrupt                     |
| PPI 14                  | 30         |               |            | PPI 14 interrupt                     |
| PPI 15                  | 31         |               |            | PPI 15 interrupt                     |
| NMI                     | 32         |               |            | NMI interrupt.                       |
| UART 0                  | 33         |               |            | UART 0 interrupt                     |
| UART 1                  | 34         |               |            | UART 1 interrupt                     |
| UART 2                  | 35         |               |            | UART 2 interrupt                     |
| UART 3                  | 36         |               |            | UART 3 interrupt                     |
| IR 0                    | 37         |               |            | IR 0 interrupt                       |
| IR 1                    | 38         |               |            | IR 1 interrupt                       |
| TWI 0                   | 39         |               |            | TWI 0 interrupt                      |
| TWI 1                   | 40         |               |            | TWI 1 interrupt                      |
| TWI 2                   | 41         |               |            | TWI 2 interrupt                      |
| SPI 0                   | 42         |               |            | SPI 0 interrupt                      |
| SPI 1                   | 43         |               |            | SPI 1 interrupt                      |
| SPI 2                   | 44         |               |            | SPI 2 interrupt                      |
| SPDIF                   | 45         |               |            | SPDIF interrupt                      |
| AC97                    | 46         |               |            | AC97 interrupt                       |
| TS                      | 47         |               |            | TS interrupt                         |
| IIS0                    | 48         |               |            | Digital Audio Controller 0 interrupt |
| UART 4                  | 49         |               |            | UART 4 interrupt                     |
| UART 5                  | 50         |               |            | UART 5 interrupt                     |
| UART 6                  | 51         |               |            | UART 6 interrupt                     |

| <b>Interrupt Source</b> | <b>SRC</b> | <b>Vector</b> | <b>FIQ</b> | <b>Description</b>                     |
|-------------------------|------------|---------------|------------|----------------------------------------|
| UART 7                  | 52         |               |            | UART 7 interrupt                       |
| Keypad                  | 53         |               |            | Keypad interrupt.                      |
| Timer 0                 | 54         |               |            | Timer 0 interrupt                      |
| Timer 1                 | 55         |               |            | Timer 1 interrupt                      |
| Timer 2/Alarm/WD        | 56         |               |            | Timer 2 , Alarm, Watchdog interrupt    |
| Timer 3                 | 57         |               |            | Timer 3 interrupt.                     |
| CAN                     | 58         |               |            | CAN interrupt.                         |
| DMA                     | 59         |               |            | DMA interrupt                          |
| PIO                     | 60         |               |            | PIO interrupt                          |
| Touch Panel.            | 61         |               |            | Touch Panel interrupt.                 |
| Audio Codec             | 62         |               |            | Audio Codec interrupt                  |
| LRADC                   | 63         |               |            | LRADC interrupt                        |
| SD/MMC 0                | 64         |               |            | SD/MMC Host Controller 0 interrupt     |
| SD/MMC 1                | 65         |               |            | SD/MMC Host Controller 1 interrupt     |
| SD/MMC 2                | 66         |               |            | SD/MMC Host Controller 2 interrupt     |
| SD/MMC 3                | 67         |               |            | SD/MMC Host Controller 3 interrupt     |
| MS                      | 68         |               |            | Memory Stick Host Controller interrupt |
| NAND                    | 69         |               |            | NAND Flash Controller (NFC) interrupt  |
| USB 0                   | 70         |               |            | USB 0 interrupt                        |
| USB 1                   | 71         |               |            | USB 1 interrupt                        |
| USB 2                   | 72         |               |            | USB 2 interrupt                        |
| SCR                     | 73         |               |            | SCR interrupt.                         |
| CSI 0                   | 74         |               |            | CSI 0 interrupt                        |
| CSI 1                   | 75         |               |            | CSI 1 interrupt                        |
| LCD Controller 0        | 76         |               |            | LCD Controller 0 interrupt             |
| LCD Controller 1        | 77         |               |            | LCD Controller 1 interrupt             |
| MP                      | 78         |               |            | MP interrupt.                          |
| DE-FE0/DE-BE0           | 79         |               |            | DE-FE0/DE-BE0 interrupt                |
| DE-FE1/DE-BE1           | 80         |               |            | DE-FE1/DE-BE1 interrupt                |
| PMU                     | 81         |               |            | PMU interrupt                          |
| SPI3                    | 82         |               |            | SPI3 interrupt                         |

| <b>Interrupt Source</b> | <b>SRC</b> | <b>Vector</b> | <b>FIQ</b> | <b>Description</b>                                                                                                                |
|-------------------------|------------|---------------|------------|-----------------------------------------------------------------------------------------------------------------------------------|
|                         | 83         |               |            |                                                                                                                                   |
|                         | 84         |               |            |                                                                                                                                   |
| VE                      | 85         |               |            | VE interrupt                                                                                                                      |
| SS                      | 86         |               |            | Security System interrupt.                                                                                                        |
| EMAC                    | 87         |               |            | EMAC interrupt                                                                                                                    |
| SATA                    | 88         |               |            | SATA interrupt                                                                                                                    |
|                         | 89         |               |            |                                                                                                                                   |
| HDMI 0                  | 90         |               |            | HDMI 0 interrupt                                                                                                                  |
| TVE 0/1                 | 91         |               |            | TV encoder 0/1 interrupt                                                                                                          |
| ACE                     | 92         |               |            | ACE interrupt                                                                                                                     |
| TVD                     | 93         |               |            | TV decoder interrupt                                                                                                              |
| PS2-0                   | 94         |               |            | PS2-0 interrupt                                                                                                                   |
| PS2-1                   | 95         |               |            | PS2-1 interrupt                                                                                                                   |
| USB 3                   | 96         |               |            | USB 3 wakeup, connect, disconnect interrupt                                                                                       |
| USB 4                   | 97         |               |            | USB 4 wakeup, connect, disconnect interrupt                                                                                       |
| PLE/PERFMU              | 98         |               |            | PLE on non-secure transfers interrupt<br>PLE on secure transfer interrupt<br>PLE error interrupt<br>Performance monitor interrupt |
| Timer 4                 | 99         |               |            | Timer 4 interrupt                                                                                                                 |
| Timer 5                 | 100        |               |            | Timer 5 interrupt                                                                                                                 |
| GPU-GP                  | 101        |               |            | GPU-GP interrupt                                                                                                                  |
| GPU-GPMMU               | 102        |               |            | GPU-GPMMU interrupt                                                                                                               |
| GPU-PP0                 | 103        |               |            | GPU-PP0 interrupt                                                                                                                 |
| GPU-PPMMU0              | 104        |               |            | GPU-PPMMU0 interrupt                                                                                                              |
| GPU-PMU                 | 105        |               |            | GPU-PMU interrupt                                                                                                                 |
| GPU-PP1                 | 106        |               |            | GPU-PP1 interrupt                                                                                                                 |
| GPU-PPMMU1              | 107        |               |            | GPU-PPMMU1 interrupt                                                                                                              |
| GPU-RSV0                | 108        |               |            |                                                                                                                                   |
| GPU-RSV1                | 109        |               |            |                                                                                                                                   |
| GPU-RSV2                | 110        |               |            |                                                                                                                                   |
| GPU-RSV3                | 111        |               |            |                                                                                                                                   |

| Interrupt Source | SRC | Vector | FIQ | Description                          |
|------------------|-----|--------|-----|--------------------------------------|
| GPU-RSV4         | 112 |        |     |                                      |
| HS Timer 0       | 113 |        |     | HS Timer 0 interrupt                 |
| HS Timer 1       | 114 |        |     | HS Timer 1 interrupt                 |
| HS Timer 2       | 115 |        |     | HS Timer 2 interrupt                 |
| HS Timer 3       | 116 |        |     | HS Timer 3 interrupt                 |
| GMAC             | 117 |        |     | GMAC interrupt                       |
| HDMI 1           | 118 |        |     | HDMI 1 interrupt                     |
| IIS1             | 119 |        |     | Digital Audio Controller 1 interrupt |
| TWI 3            | 120 |        |     | TWI 3 interrupt                      |
| TWI 4            | 121 |        |     | TWI 4 interrupt                      |
| IIS 2            | 122 |        |     | Digital Audio Controller 2 interrupt |

## 1.12. DMA

### 1.12.1. Overview

There are two kinds of DMA in the chip. One is Normal DMA with 8 channels, the other is Dedicated DMA with 8 channels .

For normal DMA, only one channel can be active and the sequence is in line with the priority level. While for the dedicated DMA, at most 8-channel can be active at the same time if their source or destination has no conflict. The dedicated DMA can only transfer data between the DRAM and the module.

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.

Although the increase mode of NDMA should be address aligned, but its byte counter should not be multiple.

The DMA Source Address, Destination Address, Byte Counter Registers can be modified even if the DMA is started.

### 1.12.2. DMA Register List

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

| Register Name            | Offset            | Description                                                    |
|--------------------------|-------------------|----------------------------------------------------------------|
| DMA_IRQ_EN_REG           | 0x0               | DMA IRQ Enable                                                 |
| DMA_IRQ_PEND_STA_REG     | 0x4               | DMA IRQ Pending Status                                         |
| NDMA_AUTO_GAT_REG        | 0x8               | NDMA Auto Gating                                               |
| 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+0x4  | Normal DMA Source Address<br>(N=0,1,2,3,4,5,6,7)               |
| NDMA_DEST_ADDR_REG       | 0x100+N*0x20+0x8  | Normal DMA Destination Address<br>(N=0,1,2,3,4,5,6,7)          |
| NDMA_BC_REG              | 0x100+N*0x20+0xC  | Normal DMA Byte Counter<br>(N=0,1,2,3,4,5,6,7)                 |
| DDMA_CFG_REG             | 0x300+N*0x20      | Dedicated DMA Configuration<br>(N=0,1,2,3,4,5,6,7)             |
| DDMA_SRC_START_ADDR_REG  | 0x300+N*0x20+0x4  | Dedicated DMA Source Start Address<br>(N=0,1,2,3,4,5,6,7)      |
| DDMA_DEST_START_ADDR_REG | 0x300+N*0x20+0x8  | Dedicated DMA Destination Start Address<br>(N=0,1,2,3,4,5,6,7) |
| DDMA_BC_REG              | 0x300+N*0x20+0xC  | Dedicated DMA Byte Counter<br>(N=0,1,2,3,4,5,6,7)              |
| DDMA_PARA_REG            | 0x300+N*0x20+0x18 | Dedicated DMA Parameter<br>(N=0,1,2,3,4,5,6,7)                 |

### 1.12.3. DMA Controller Register Description

#### 1.12.3.1. DMA IRQ ENABLE REGISTER(DEFAULT: 0X00000000)

| Offset: 0x0 |                |             | Register Name: DMA_IRQ_EN_REG                                                                 |
|-------------|----------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                   |
| 31          | R/W            | 0x0         | DDMA7_END_IRQ_EN.<br>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.  |

| Offset: 0x0 |                |             | Register Name: DMA_IRQ_EN_REG                                                                |
|-------------|----------------|-------------|----------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                  |
| 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.<br>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.    |

| Offset: 0x0 |                |             | Register Name: DMA_IRQ_EN_REG                                                             |
|-------------|----------------|-------------|-------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                               |
| 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. |

### 1.12.3.2. DMA IRQ PENDING STATUS REGISTER(DEFAULT: 0X00000000)

| Offset: 0x4 |                |             | Register Name: DMA_IRQ_PEND_STA_REG                                                                                                 |
|-------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/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<br>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                                                                                                                  |

| Offset: 0x4 |                |             | Register Name: DMA_IRQ_PEND_STA_REG                                                                                                |
|-------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                                        |
|             |                |             | 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                                               |

| Offset: 0x4 |                |             | Register Name: DMA_IRQ_PEND_STA_REG                                                                                              |
|-------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                                      |
|             |                |             | 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                                             |

| Offset: 0x4 |                |             | Register Name: DMA_IRQ_PEND_STA_REG                                                                                              |
|-------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                                      |
|             |                |             | 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.<br>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. |

### 1.12.3.3. NDMA AUTO GATING REGISTER(DEFAULT: 0X00000000)

| Offset: 0x8 |                |             | Register Name: NDMA_AUTO_GAT_REG<br>Default Value: 0x0000_0000                                                                                                        |
|-------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                                                                                                                                                           |
| 31:17       | /              | /           | /.                                                                                                                                                                    |
| 16          | R/W            | 0x0         | NDMA Auto Clock Gating bit<br>0: NDMA auto clock gating enable<br>1: NDMA auto clock gating disable<br>If NDMA works in Continuous mode, this bit should be set to 1. |

| <b>Offset: 0x8</b> |                        |                    | <b>Register Name: NDMA_AUTO_GAT_REG</b><br><b>Default Value: 0x0000_0000</b> |
|--------------------|------------------------|--------------------|------------------------------------------------------------------------------|
| <b>Bit</b>         | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                           |
| 15:0               | /                      | /                  | /.                                                                           |

#### 1.12.3.4. NORMAL DMA CONFIGURATION REGISTER(DEFAULT: 0X00000000)

| <b>Offset:</b><br><b>0x100+N*0x20</b><br><b>(N=0,1,2,3,4,5,6,7)</b> |                        |                    | <b>Register Name: NDMA_CTRL_REG</b>                                                                                                                                                                                                                          |
|---------------------------------------------------------------------|------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                                                          | <b>Read/<br/>Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                                                                                                                                           |
| 31                                                                  | R/W                    | 0x0                | DMA_LOADING.<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 finished. It will be cleared automatically.<br>Set 0 to the bit will reset the corresponding DMA channel. |
| 30                                                                  | R/W                    | 0x0                | DMA_CONTI_MODE_EN.<br>DMA Continuous Mode Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                  |
| 29:27                                                               | R/W                    | 0x0                | DMA_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_DEST_DATA_WIDTH.<br>Normal DMA Destination Data Width.<br>00: 8-bit<br>01: /<br>10: 32-bit<br>11: /                                                                                                                                                     |
| 24:23                                                               | R/W                    | 0x0                | DMA_DEST_BST_LEN.<br>DMA Destination Burst Length.<br>00: 1<br>01: /                                                                                                                                                                                         |

| Offset:<br><b>0x100+N*0x20</b><br>(N=0,1,2,3,4,5,6,7) |                |             | Register Name: <b>NDMA_CTRL_REG</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                   | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                       |                |             | 10: 8<br>11: /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 22                                                    | R/W            | 0x0         | DMA_DEST_SEC.<br>DMA Destination Security<br>0: secure, 1: non-secure.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 21                                                    | R/W            | 0x0         | NDMA_DEST_ADDR_TYPE.<br>Normal DMA Destination Address Type.<br>0: Increment<br>1: No Change.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 20:16                                                 | R/W            | 0x0         | NDMA_DEST_DRQ_TYPE.<br>Normal DMA Destination DRQ Type.<br>00000 : IR0-TX<br>00001 : IR1-TX<br>00010 : SPDIF-TX<br>00011 : IIS0-TX<br>00100 : IIS1-TX<br>00101 : AC97-TX<br>00110 : IIS2-TX<br>00111 :<br>01000 : UART0 TX<br>01001 : UART1 TX<br>01010 : UART2 TX<br>01011 : UART3 TX<br>01100 : UART4 TX<br>01101 : UART5 TX<br>01110 : UART6 TX<br>01111 : UART7 TX<br>10000 : HDMI DDC TX<br>10001 : USB EP1<br>10010 : /<br>10011 : Audio Codec D/A<br>10100 : /<br>10101 : SRAM(range : )<br>10110 : SDRAM |

| Offset:<br><b>0x100+N*0x20</b><br>(N=0,1,2,3,4,5,6,7) |                |             | Register Name: <b>NDMA_CTRL_REG</b>                                                                                                                                                                            |
|-------------------------------------------------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                   | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                    |
|                                                       |                |             | 10111 : /<br>11000 : SPI0 TX<br>11001 : SPI1 TX<br>11010 : SPI2 TX<br>11011 : SPI3 TX<br>11100 : USB EP2<br>11101 : USB EP3<br>11110 : USB EP4<br>11111 : USB EP5                                              |
| 15                                                    | R/W            | 0x0         | <b>BC_MODE_SEL.</b><br>BC mode select.<br>0 : normal mode(the value read back is equal to the value that is written)<br>1 : remain mode(the value read back is equal to the remain counter to be transferred). |
| 14:11                                                 | /              | /           | /.                                                                                                                                                                                                             |
| 10:9                                                  | R/W            | 0x0         | <b>NDMA_SRC_DATA_WIDTH.</b><br>Normal DMA Source Data Width.<br>00: 8-bit<br>01: /<br>10: 32-bit<br>11: /                                                                                                      |
| 8:7                                                   | R/W            | 0x0         | <b>DMA_SRC_BST_LEN.</b><br>DMA Source Burst Length.<br>00: 1<br>01: /<br>10: 8<br>11: /                                                                                                                        |
| 6                                                     | R/W            | 0x0         | <b>DMA_SRC_SEC.</b><br>DMA Source Security.<br>0 : secure, 1 : non-secure.                                                                                                                                     |
| 5                                                     | R/W            | 0x0         | <b>NDMA_SRC_ADDR_TYPE.</b><br>Normal DMA Source Address Type.                                                                                                                                                  |

| Offset:<br><b>0x100+N*0x20</b><br>(N=0,1,2,3,4,5,6,7) |                |             | Register Name: <b>NDMA_CTRL_REG</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------------------------------------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                   | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                       |                |             | 0: Increment<br>1: No Change                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4:0                                                   | R/W            | 0x0         | NDMA_SRC_DRQ_TYPE.<br>Normal DMA Source DRQ Type.<br>00000 : IR0-RX<br>00001 : IR1-RX<br>00010 : SPDIF-RX<br>00011 : IIS0-RX<br>00100 : IIS1-RX<br>00101 : AC97-RX<br>00110 : IIS2-RX<br>00111 : /<br>01000 : UART0 RX<br>01001 : UART1 RX<br>01010 : UART2 RX<br>01011 : UART3 RX<br>01100 : UART4 RX<br>01101 : UART5 RX<br>01110 : UART6 RX<br>01111 : UART7 RX<br>10000 : HDMI DDC RX<br>10001 : USB EP1<br>10010 : /<br>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 : SPI3 RX<br>11100 : USB EP2<br>11101 : USB EP3<br>11110 : USB EP4<br>11111 : USB EP5 |

#### 1.12.3.5. 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/<br>Write | Default/Hex | Description                                  |
| 31:0                                            | R/W            | 0x0         | NDMA_SRC_ADDR.<br>Normal DMA Source Address. |

#### 1.12.3.6. 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/<br>Write | Default/Hex | Description                                        |
| 31:0                                            | R/W            | 0x0         | NDMA_DEST_ADDR.<br>Normal DMA Destination Address. |

#### 1.12.3.7. 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/<br>Write | Default/Hex | Description                          |
| 31:18                                           | /              | /           | /.                                   |
| 17:0                                            | R/W            | 0x0         | NDMA_BC.<br>Normal DMA Byte Counter. |

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

#### 1.12.3.8. DEDICATED DMA CONFIGURATION REGISTER(DEFAULT: 0X00000000)

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

| <b>Bit</b> | <b>Read /Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                                                                                                                                                                      |
|------------|--------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W                | 0x0                | DMA_LOADING.<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 finished. 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                | DMA_BSY_STA.<br>DMA Busy Status.<br>0: DMA idle, 1: DMA busy.                                                                                                                                                                                                                           |
| 29         | R/W                | 0x0                | DMA_CONT_MODE_EN.<br>DMA Continuous Mode Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                                              |
| 28         | R/W                | 0x0                | DMA_DEST_SEC.<br>DMA Destination Security.<br>0: secure, 1: non-secure                                                                                                                                                                                                                  |
| 27         | /                  | /                  | /.                                                                                                                                                                                                                                                                                      |
| 26:25      | R/W                | 0x0                | DMA_DEST_DATA_WIDTH.<br>DMA Destination Data Width.<br>00: 8-bit<br>01: /<br>10: 32-bit<br>11: /                                                                                                                                                                                        |
| 24:23      | R/W                | 0x0                | DMA_DEST_BST_LEN.<br>DMA Destination Burst Length.<br>00: 1<br>01: /<br>10: 8<br>11: /.                                                                                                                                                                                                 |
| 22:21      | R/W                | 0x0                | DMA_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_DEST_DRQ_TYPE.                                                                                                                                                                                                                                                                     |

| Offset:<br><b>0x300+N*0x20</b><br>(N=0,1,2,3,4,5,6,7) |             |             | Register Name: <b>DDMA_CFG_REG</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                   | Read /Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                       |             |             | Dedicated DMA Destination 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: 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: TCON1<br>0x10: /<br>0x11: /<br>0x12: /<br>0x13: /<br>0x14: /<br>0x15: /<br>0x16: /<br>0x17: Memory Stick Controller (MSC)<br>0x18: HDMI Audio<br>0x19: /<br>0x1A: SPI0 TX<br>0x1B: /<br>0x1C: SPI2 TX<br>0x1D: /<br>0x1E: SPI3 TX<br>0x1F: / |
| 15                                                    | R/W         | 0x0         | BC_MODE_SEL.<br>BC mode select.<br>0 : normal mode(the value read back is equal to the value that is written)<br>1 : remain mode(the value read back is equal to the remain counter to be transferred).                                                                                                                                                                                                                                                                                                                                |

| Offset:<br><b>0x300+N*0x20</b><br>(N=0,1,2,3,4,5,6,7) |             |             | Register Name: <b>DDMA_CFG_REG</b>                                                                                                                                                                                          |
|-------------------------------------------------------|-------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                   | Read /Write | Default/Hex | Description                                                                                                                                                                                                                 |
| 14:13                                                 | /           | /           | /.                                                                                                                                                                                                                          |
| 12                                                    | R/W         | 0x0         | DMA_SRC_SEC.<br>DMA Source Security.<br>0: secure, 1: non-secure.                                                                                                                                                           |
| 11                                                    | /           | /           | /                                                                                                                                                                                                                           |
| 10:9                                                  | R/W         | 0x0         | DMA_SRC_DATA_WIDTH.<br>DMA Source Data Width.<br>00: 8-bit<br>01: /<br>10: 32-bit<br>11: /                                                                                                                                  |
| 8:7                                                   | R/W         | 0x0         | DMA_SRC_BST_LEN.<br>DMA Source Burst Length.<br>00: 1<br>01: /<br>10: 8<br>11: ../..                                                                                                                                        |
| 6:5                                                   | R/W         | 0x0         | DMA_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 |

| Offset:<br><b>0x300+N*0x20</b><br>(N=0,1,2,3,4,5,6,7) |             |             | Register Name: <b>DDMA_CFG_REG</b>                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                   | Read /Write | Default/Hex | Description                                                                                                                                                                                                                                                                                              |
|                                                       |             |             | 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: Memory Stick Controller (MSC)<br>0x18: /<br>0x19: /<br>0x1A: /<br>0x1B: SPI0 RX.<br>0x1C: /<br>0x1D: SPI2 RX<br>0x1E: /<br>0x1F: SPI3 RX |

#### 1.12.3.9. DEDICATED DMA SOURCE START ADDRESS REGISTER

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

### 1.12.3.10. DEDICATED DMA DESTINATION START ADDRESS REGISTER

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

### 1.12.3.11. DEDICATED DMA BYTE COUNTER REGISTER

| <b>Offset:</b><br><b>0x300+N*0x20+0xC</b><br><b>(N=0,1,2,3,4,5,6,7)</b> |                        |                         | <b>Register Name:</b> DDMA_BC_REG       |
|-------------------------------------------------------------------------|------------------------|-------------------------|-----------------------------------------|
| <b>Bit</b>                                                              | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                      |
| 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 16M.

### 1.12.3.12. DEDICATED DMA PARAMETER REGISTER

| <b>Offset:</b><br><b>0x300+N*0x20+0x18</b><br><b>(N=0,1,2,3,4,5,6,7)</b> |                        |                         | <b>Register Name:</b> DDMA PARA_REG                   |
|--------------------------------------------------------------------------|------------------------|-------------------------|-------------------------------------------------------|
| <b>Bit</b>                                                               | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                    |
| 31:24                                                                    | R/W                    | 0x0                     | DEST_DATA_BLK_SIZE.<br>Destination Data Block Size n. |
| 23:16                                                                    | R/W                    | 0x0                     | DEST_WAIT_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                    | 0x0                     | SRC_WAIT_CYC.<br>Source Wait Clock Cycles n.          |

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

For Allwinnertech Only

## 1.13. Audio Codec

### 1.13.1. Overview

The embedded Audio Codec is a high-quality stereo audio codec with headphone amplifier.

It features:

- On-chip 24-bit DAC for playback
- On-chip 24-bit ADC for recorder
- Support analog/ digital volume control
- Support 48K and 44.1K sample family
- Support 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 automatic change to True Ground to protect headphone amplifier and make function work normal mode

### 1.13.2. Audio Codec Block Diagram



### 1.13.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_FIFO_C | 0x04   | DAC FIFO Control Register         |

| Register Name    | Offset | Description                           |
|------------------|--------|---------------------------------------|
| 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_DAC_TUNE      | 0x14   | DAC/ ADC Performance Tuning 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          |
| AC_SYS_VERI      | 0x38   | System Calibration Verify Register    |
| AC_MIC_PHONE_CAL | 0x3c   | MIC gain & Phone out Control Register |

## 1.13.4. Audio Codec Register Description

### 1.13.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        | R/W        | 0x0     | MODQU.<br>Internal DAC Quantization Levels<br>Levels=[7*(21+MODQU[3:0])]/128<br>Default levels=7*21/128=1.15 |
| 24           | R/W        | 0x0     | DWA.<br>DWA Function Disable                                                                                 |

| Offset: 0x00 |            |         | Register Name: AC_DAC_DPC                                                                  |
|--------------|------------|---------|--------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                |
|              |            |         | 0: Enable<br>1: Disable                                                                    |
| 23:19        | /          | /       | /                                                                                          |
| 18           | R/W        | 0x0     | HPF_EN.<br>High Pass Filter Enable<br>0: Disable<br>1: Enable                              |
| 17:12        | R/W        | 0x0     | DVOL.<br>Digital volume control: dvc, ATT=(DVC[5:0]-2)*(-1.16dB)<br>62 steps, -1.16dB/step |
| 11:0         | /          | /       | /                                                                                          |

#### 1.13.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<br>001: 32KHz<br>011: 16KHz<br>101: 8KHz<br>111: 96KHz<br>44.1KHz/22.05KHz/11.025KHz can be supported by Audio PLL Configure Bit |
| 28          | R/W        | 0x0     | FIR Version<br>0: 64-Tap FIR<br>1: 32-Tap FIR                                                                                                                                                                           |
| 27          | /          | /       | /                                                                                                                                                                                                                       |
| 26          | R/W        | 0x0     | SEND_LASAT.                                                                                                                                                                                                             |

| Offset: 0x4 |            |         | Register Name: AC_DAC_FIFOC                                                                                                                                                                                                                                |
|-------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/Write | Default | Description                                                                                                                                                                                                                                                |
|             |            |         | Audio sample select when TX FIFO under run<br>0: Sending zero<br>1: Sending last audio sample                                                                                                                                                              |
| 25:24       | R/W        | 0x0     | FIFO_MODE.<br>For 24-bits transmitted audio sample:<br>00/10: FIFO_I[23:0] = {TXDATA[31:8]}<br>01/11: Reserved<br>For 16-bits transmitted audio sample:<br>00/10: FIFO_I[23:0] = {TXDATA[31:16], 8'b0}<br>01/11: FIFO_I[23:0] = {TXDATA[15:0], 8'b0}       |
| 23          | /          | /       | /                                                                                                                                                                                                                                                          |
| 22:21       | R/W        | 0x0     | DAC_DRQ_CLR_CNT.<br>When TX FIFO available room less than or equal N, DRQ Request will be de-asserted. N is defined here:<br>00: IRQ/DRQ Deasserted when WLEVEL > TXTL<br>01: 4<br>10: 8<br>11: 16                                                         |
| 20:15       | /          | /       | /                                                                                                                                                                                                                                                          |
| 14:8        | R/W        | 0x10    | TX_TRIG_LEVEL.<br>TX FIFO Empty Trigger Level (TXTL[12:0])<br>Interrupt and DMA request trigger level for TX FIFO normal condition.<br>IRQ/DRQ Generated when WLEVEL $\leq$ TXTL<br>Notes:<br>WLEVEL represents the number of valid samples in the TX FIFO |
| 7           | R/W        | 0x0     | ADDA_LOOP_EN.<br>ADDA loop Enable, adda<br>0: Disable                                           1: Enable                                                                                                                                                  |
| 6           | R/W        | 0x0     | DAC_MONO_EN.<br>DAC Mono Enable<br>0: Stereo, 64 levels FIFO<br>1: mono, 128 levels FIFO<br>When enabled, L & R channel send same data                                                                                                                     |
| 5           | R/W        | 0x0     | TX_SAMPLE_BITS.                                                                                                                                                                                                                                            |

| Offset: 0x4 |            |         | Register Name: AC_DAC_FIFOC                                                       |
|-------------|------------|---------|-----------------------------------------------------------------------------------|
| Bit         | Read/Write | Default | Description                                                                       |
|             |            |         | 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'    |

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

| Offset: 0x8 |            |         | Register Name: AC_DAC_FIFOS                                                                                                                                                               |
|-------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/Write | Default | Description                                                                                                                                                                               |
|             |            |         | 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<br>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           | /          | /       | /                                                                                                                                                                                         |

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

#### 1.13.4.5. DAC ANALOG CONTROL REGISTER

| Offset: 0x10 |     |         | Register Name: AC_DAC_ACTRL |
|--------------|-----|---------|-----------------------------|
| Bit          | R/W | Default | Description                 |
|              |     |         |                             |

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

| Offset:0x10 |     |         | Register Name: AC_DAC_ACTRL                                                  |
|-------------|-----|---------|------------------------------------------------------------------------------|
| Bit         | R/W | Default | Description                                                                  |
|             |     |         | 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<br>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.                                                                      |

| Offset:0x10 |     |         | Register Name: AC_DAC_ACTRL                                                                                |
|-------------|-----|---------|------------------------------------------------------------------------------------------------------------|
| Bit         | R/W | Default | Description                                                                                                |
|             |     |         | 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, (): 0:Mute<br>1: Not mute |
| 5:0         | R/W | 0x0     | PAVOL.<br>PA Volume Control, (PAVOL): Total 64 level, from 0dB to -62dB, 1dB/step,mute when 000000         |

#### 1.13.4.6. DAC/ADC ANALOG PERFORMANCE TUNING REGISTER

| Offset:0x14 |     |         | Register Name: AC_ADDA_BIAS_CTRL |
|-------------|-----|---------|----------------------------------|
| Bit         | R/W | Default | Description                      |
| 31:0        | /   | /       | /                                |

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

| Offset: 0x1C |            |         | Register Name: AC_ADC_FIFOC                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              |            |         | 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<br>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><b>Notes:</b><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                                                                                                                                                                                                                                                                                                                                                          |

| Offset: 0x1C |            |         | Register Name: AC_ADC_FIFOC                                                          |
|--------------|------------|---------|--------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                          |
|              |            |         | 1: 24 bits                                                                           |
| 5            | /          | /       | /                                                                                    |
|              |            |         | ADC_DRQ_EN.<br>ADC FIFO Data Available DRQ Enable.<br>0: Disable<br>1: Enable        |
| 4            | R/W        | 0x0     |                                                                                      |
|              |            |         | ADC_IRQ_EN.<br>ADC FIFO Data Available IRQ Enable.<br>0: Disable<br>1: Enable        |
| 3            | R/W        | 0x0     |                                                                                      |
|              |            |         | ADC_OVERRUN_IRQ_EN.<br>ADC FIFO Over Run IRQ Enable<br>0: Disable<br>1: Enable       |
| 2            | /          | /       | /                                                                                    |
|              |            |         | ADC_FIFO_FLUSH.<br>ADC FIFO Flush.<br>Write '1' to flush TX FIFO, self clear to '0'. |
| 1            | R/W        | 0x0     |                                                                                      |
| 0            | R/W        | 0x0     |                                                                                      |

#### 1.13.4.8. ADC FIFO STATUS REGISTER

| Offset: 0x20 |            |         | Register Name: AC_ADC_FIFOS                                                                                    |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                    |
|              |            |         | /                                                                                                              |
| 31:24        | /          | /       | /                                                                                                              |
|              |            |         | RXA.<br>RX FIFO Available<br>0: No available data in RX FIFO<br>1: More than one sample in RX FIFO (>= 1 word) |
| 23           | R          | 0x0     |                                                                                                                |
|              |            |         | 22:14 / / /                                                                                                    |
|              |            |         | 22:14 / / /                                                                                                    |
|              |            |         | 13:8 R 0x0 RXA_CNT.<br>RX FIFO Available Sample Word Counter                                                   |
| 7:4          | /          | /       | /                                                                                                              |

| Offset: 0x20 |            |         | Register Name: AC_ADC_FIFOS                                                                                                                                                                      |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                      |
| 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            | /          | /       | /                                                                                                                                                                                                |

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

#### 1.13.4.10. 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<br>1-Enable |

| Offset:0x28 |     |         | Register Name: AC_PA_ADC_ACTRL                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | R/W | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 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:23       | /   | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 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)<br>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 |

| Offset:0x28 |     |         | Register Name: AC_PA_ADC_ACTRL                                                                                                                                                                                                                             |
|-------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | R/W | Default | Description                                                                                                                                                                                                                                                |
|             |     |         | 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          | /   | /       | /                                                                                                                                                                                                                                                          |
| 11          | R/W | 0       | LHPOUTN<br>Left Headphone Amplifier Output Negative To Right HPOUT Mute<br>0: mute<br>1: Not-mute                                                                                                                                                          |
| 10          | R/W | 0       | RHPOUTN<br>Right Headphone Amplifier Output Negative To Left HPOUT Mute<br>0: mute<br>1: Not-mute                                                                                                                                                          |
| 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     | DITHER_CLK_SELECT.<br>ADC dither clock select<br>00: about 43KHz<br>01: about 51KHz<br>10: about 64KHz<br>11: about 85KHz                                                                                                                                  |
| 5           | /   | /       | /                                                                                                                                                                                                                                                          |
| 4           | R/W | 0x0     | PA_EN.                                                                                                                                                                                                                                                     |

| Offset:0x28 |     |         | Register Name: AC_PA_ADC_ACTRL                                                                        |
|-------------|-----|---------|-------------------------------------------------------------------------------------------------------|
| Bit         | R/W | Default | Description                                                                                           |
|             |     |         | 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     | COMPTEN.<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<br>01: 4-6ms<br>10: 8-12ms<br>11: 16-24ms |

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

#### 1.13.4.12. ADC RX COUNTER REGISTER

| Offset: 0x34 |            |         | Register Name: AC_ADC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:0         | R/W        | 0x0     | <p>RX_CNT.</p> <p>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> |

#### 1.13.4.13. BIAS & DA16 CALIBRATION VERIFY REGISTER

| Offset: 0x38 |            |         | Register Name: AC_DAC_CAL                                                                               |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                             |
| 31:24        | /          | /       | /                                                                                                       |
| 23           | R/W        | 0x0     | <p>BIASCALVERIFY.</p> <p>Bias Calibration Verify 0</p> <p>0: Calibration</p> <p>1: Register setting</p> |
| 22:17        | R/W        | 0x20    | <p>BIASVERIFY.</p> <p>Bias Register Setting Data 101101</p>                                             |
| 16:11        | R          | 0x20    | <p>BIASCALI.</p> <p>Bias Calibration Data 100000</p>                                                    |
| 10           | R/W        | 0x0     | <p>DA16CALVERIFY.</p> <p>DA16 Calibration Verify</p> <p>0: Calibration</p> <p>1: Register setting 0</p> |
| 9:5          | R/W        | 0x10    | <p>DA16VERIFY.</p> <p>DA16 Register Setting Data 10010</p>                                              |
| 4:0          | R          | 0x10    | <p>DA16CALI.</p> <p>DA16 Calibration Date 10000</p>                                                     |

#### 1.13.4.14. MIC GAIN & PHONE OUT CONTROL REGISTER

| Offset: 0x3c |     |         | Register Name: AC_MIC_PHONE_CAL                                                                                                                  |
|--------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | R/W | Default | Description                                                                                                                                      |
| 31:29        | R/W | 0x4     | PREG1.<br>MIC1 pre-amplifier Gain Control<br>000: 0dB<br>001: 24dB<br>010: 27dB<br>011: 30dB<br>100: 33dB<br>101: 36dB<br>110: 39dB<br>111: 42dB |
| 28:26        | R/W | 0x4     | PREG2.<br>MIC2 pre-amplifier Gain Control<br>000: 0dB<br>001: 24dB<br>010: 27dB<br>011: 30dB<br>100: 33dB<br>101: 36dB<br>110: 39dB<br>111: 42dB |
| 25:8         | /   | /       | /                                                                                                                                                |
| 7:5          | R/W | 0x3     | PHONEOUTG.<br>PHONEOUT Gain Control<br>000: -4.5dB<br>001: -3.0dB<br>010: -1.5dB<br>011: 0dB<br>100: 1.5dB<br>101: 3dB<br>110: 4.5dB<br>111: 6dB |
| 4            | R/W | 0       | PHONEOUTEN.<br>PHONEOUT enable<br>0: disable                                                                                                     |

| Offset: 0x3c |     |         | Register Name: AC_MIC_PHONE_CAL                                               |
|--------------|-----|---------|-------------------------------------------------------------------------------|
| Bit          | R/W | Default | Description                                                                   |
|              |     |         | 1: enable                                                                     |
| 3            | R/W | 0       | PHONEOUTS3.<br>MIC1 Boost stage to Phone out mute<br>0: Mute<br>1: Not mute   |
| 2            | R/W | 0       | PHONEOUTS2.<br>MIC2 Boost stage to Phone out mute<br>0: Mute<br>1: Not mute   |
| 1            | R/W | 0       | PHONEOUTS1.<br>Right Output mixer to Phone out mute<br>0: Mute<br>1: Not mute |
| 0            | R/W | 0       | PHONEOUTS0<br>Left Output mixer to Phone out mute<br>0: Mute<br>1: Not mute   |

## 1.14. LRADC

### 1.14.1. Overview

LRADC is of 6-bit resolution for key application.

It features:

- Support APB 32-bits bus width
- Support interrupt
- Support Hold Key and General Key
- Support Single Key and Continue key mode
- 6-bit resolution
- Support voltage input range from 0V to 2V

### 1.14.2. LRADC 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.

#### Hold Key and General Key Function Introduction



When ADC\_IN Signal change from ADC\_REF to 2/3 ADC\_REF (Level A), the comparator24 sends first interrupt to control logic; When ADC\_IN Signal changes from 2/3 ADC\_REF to certain level (configurable), the comparator25 gives the second interrupt. If the control Logic gets 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.

### 1.14.3. LRADC Register List

| Module Name | Base Address |
|-------------|--------------|
|             |              |

| Module Name | Base Address |
|-------------|--------------|
| LRADC       | 0x01C22800   |

| Register Name | Offset | Description                      |
|---------------|--------|----------------------------------|
| LRADC_CTRL    | 0x00   | LRADC Control Register           |
| LRADC_INTC    | 0x04   | LRADC Interrupt Control Register |
| LRADC_INTS    | 0x08   | LRADC Interrupt Status Register  |
| LRADC_DATA0   | 0x0c   | LRADC Data Register 0            |
| LRADC_DATA1   | 0x10   | LRADC Data Register 1            |

## 1.14.4. LRADC Register Description

### 1.14.4.1. LRADC CONTROL REGISTER

| Offset: 0x00 |            |             | Register Name: LRADC_CTRL                                                                               |
|--------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                                                                             |
| 31: 24       | R/W        | 0x1         | FIRST_CONCERT_DLY.<br>ADC First Convert Delay setting, ADC conversion is delayed by n samples           |
| 23:22        | R/W        | 0x0         | ADC_CHAN_SELECT.<br>ADC channel select<br>00: ADC0 channel<br>01: ADC1 channel<br>1x: ADC0&ADC1 channel |
| 21:20        | /          | /           | /                                                                                                       |
| 19:16        | R/W        | 0x0         | CONTINUE_TIME_SELECT.<br>Continue Mode time select, one of 8*(N+1) sample as a valuable sample data     |
| 15:14        | /          | /           | /                                                                                                       |
| 13:12        | R/W        | 0x0         | KEY_MODE_SELECT.<br>Key Mode Select:<br>00: Normal Mode                                                 |

| Offset: 0x00 |                |                 | Register Name: LRADC_CTRL                                                                                                                                        |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                      |
|              |                |                 | 01: Single Mode<br>10: Continue Mode                                                                                                                             |
| 11:8         | R/W            | 0x1             | LEVELA_B_CNT.<br>Level A to Level B time threshold select, judge ADC convert value in level A to level B in n+1 samples                                          |
| 7            | /              | /               | /                                                                                                                                                                |
| 6            | R/W            | 0x1             | LRADC_HOLD_EN.<br>LRADC Sample hold Enable<br>0: Disable<br>1: Enable                                                                                            |
| 5: 4         | R/W            | 0x2             | LEVELB_VOL.<br>Level B Corresponding Data Value setting (the real voltage value)<br>00: 0x3C (~1.9v)<br>01: 0x39 (~1.8v)<br>10: 0x36 (~1.7v)<br>11: 0x33 (~1.6v) |
| 3: 2         | R/W            | 0x2             | LRADC_SAMPLE_RATE.<br>LRADC Sample Rate<br>00: 250 Hz<br>01: 125 Hz<br>10: 62.5 Hz<br>11: 32.25 Hz                                                               |
| 1            | /              | /               | /                                                                                                                                                                |
| 0            | R/W            | 0x0             | LRADC_EN.<br>LRADC enable<br>0: Disable<br>1: Enable                                                                                                             |

#### 1.14.4.2. LRADC INTERRUPT CONTROL REGISTER

| Offset: 0x04 |                |                 | Register Name: LRADC_INTC |
|--------------|----------------|-----------------|---------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description               |

| Offset: 0x04 |                |             | Register Name: LRADC_INTC                                                               |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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               |

| Offset: 0x04 |                |             | Register Name: LRADC_INTC                                             |
|--------------|----------------|-------------|-----------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                           |
| 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 |

#### 1.14.4.3. LRADC INTERRUPT STATUS REGISTER

| Offset: 0x08 |                |             | Register Name: LRADC_INT                                                                                                                                                                                                                                                                               |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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                                                                                                                                                                                |

| Offset: 0x08 |                |             | Register Name: LRADC_INT                                                                                                                                                                                                                                                                                                                                     |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                  |
|              |                |             | <p>line is set if the corresponding interrupt is enabled.</p> <p>0: NO IRQ</p> <p>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable.</p>                                                                                                                                            |
| 9            | R/W            | 0x0         | <p>ADC1_KEYDOWN_IRQ_PENDING.</p> <p>ADC 1 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</p> <p>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable.</p> |
| 8            | R/W            | 0x0         | <p>ADC1_DATA_IRQ_PENDING.</p> <p>ADC 1 Data IRQ Pending Bit</p> <p>0: No IRQ</p> <p>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable.</p>                                                                                                                                          |
| 7:5          | /              | /           | /                                                                                                                                                                                                                                                                                                                                                            |
| 4            | R/W            | 0x0         | <p>ADC0_KEYUP_PENDING.</p> <p>ADC 0 Key up pending Bit</p> <p>When general key pull up, it the corresponding interrupt is enabled.</p> <p>0: No IRQ</p> <p>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable</p>                                                                    |
| 3            | R/W            | 0x0         | <p>ADC0_ALRDY_HOLD_PENDING.</p> <p>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</p> <p>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable</p>                            |
| 2            | R/W            | 0x0         | ADC0_HOLDKEY_PENDING.                                                                                                                                                                                                                                                                                                                                        |

| Offset: 0x08 |                |             | Register Name: LRADC_INT                                                                                                                                                                                                                                                                                                                       |
|--------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                    |
|              |                |             | <p>ADC 0 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 enabled.</p>                                  |
| 1            | R/W            | 0x0         | <p>ADC0_KEYDOWN_PENDNG.<br/> ADC 0 Key Down IRQ Pending Bit<br/> When General 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 enabled.</p> |
| 0            | R/W            | 0x0         | <p>ADC0_DATA_PENDNG.<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.</p>                                                                                                                                        |

#### 1.14.4.4. LRADC DATA 0 REGISTER

| Offset: 0x0c |                |             | Register Name: LRADC_DATA    |
|--------------|----------------|-------------|------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                  |
| 31:6         | /              | /           | /                            |
| 5:0          | R              | 0x0         | LRADC0_DATA.<br>LRADC 0 Data |

#### 1.14.4.5. LRADC DATA 1 REGISTER

| Offset: 0x10 |                |             | Register Name: LRADC_DATA    |
|--------------|----------------|-------------|------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                  |
| 31:6         | /              | /           | /                            |
| 5:0          | R              | 0x0         | LRADC1_DATA.<br>LRADC 1 Data |

## 1.15. TP

### 1.15.1. Overview

The TP controller is a 4-wire resistive touch screen controller, including 12-bit resolution A/D converter. Especially, it provides the ability of dual touch detection. The controller through the implementation of the two A/D conversion has been identified by the location of the screen of single touch, in addition to measurable increase in pressure on the touch screen.

It features:

- 12-bit SAR type A/D converter
- 4-wire I/F
- Dual touch detection
- Touch-pressure measurement (Support programmable threshold)
- Sampling frequency up to 2MHz
- 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

### 1.15.2. Typical Application Circuit



### 1.15.3. TP Clock Tree



### 1.15.4. A/D Conversion Time

When the clock source is 24MHz and the prescaler value is 6, total 12-bit conversion time is as following:

$$\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}$$

**FS\_TIME** (Frequency Scan Time) bases on TACQ and Touch Mode, they must meet the following inequation:  $\text{FS\_TIME} \geq M * (\text{TACQ} + \text{Conversion Time})$

For example, if touch acquire time divider is 15, then  $TACQ = 4\text{MHz} / (16 * (15 + 1)) = 64\text{us}$ . When TP mode is dual and pressure measurement mode, then  $M=6$ , and the FS\_TIME must be no less than  $6 * (64 + 3.25) \text{ us}$ .



Dual Touch and Pressure Measurement



Dual Touch No Pressure Measurement



Single Touch and Pressure Measurement Mode



Single Touch No Pressure Measurement Mode



General ADC Mode

## 1.15.5. Principle of Operation

### 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 work in single-ended or differential mode. Selecting Aux ADC or temperature should work in single-ended mode; as a touch screen application, it works in a differential mode, which can effectively eliminate the impact on conversion accuracy caused by the parasitic resistance of the driver switch and external interference.

### SINGLE-ENDED MODE

When the TP controller is in the measurement mode of AUX or Temp, the internal ADC is in single-ended mode, using the 3V reference source as the ADC reference voltage, application of the principle of single-ended mode is shown below:



Simplified Diagram of Single-Ended Reference

## DIFFERENTIAL MODE

When the TP controller is in the measurement mode of X,Y,Z, the internal ADC is in differential mode. The advantage of differential mode is that +REF and -REF can input directly to the Y+, Y-, which can eliminate measurement error because of the switch on resistance. The disadvantage is that during both the sample and conversion process, the driver will need to be on, which will increase the power consumption.



Simplified Diagram of Differential Reference

## SINGLE TOUCH DETECTION

The principle of operation is illustrated below, For an X coordinate measurement, the X+ pin is internally switched to VCC\_REF and X- to GND. The X plate becomes a potential divider, and the voltage at the point of contact is proportional to its X co-ordinate. This voltage is measured on the Y+, which carry no current (hence there is no voltage drop in R<sub>Y+</sub> or R<sub>Y-</sub>). 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 coordinate measurements are similar to X

coordinate measurements, with the X and Y plates interchanged. In Single Touch mode, only need to test X+, Y+ signal. But In Dual Touch mode, it need to test X+, X-, Y+, Y- signal.



Single Touch X-Position Measurement

## DUAL TOUCH DETECTION

The principle of operation is illustrated below, For an X coordinate measurement, the X+ pin is internally switched to 3V and X- to GND. The X plate becomes a potential divider, and the voltage at the point of contact is proportional to its X coordinate. 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-|$ . In practice, we can set a threshold. If  $\Delta X$  or  $\Delta Y$  greater than the threshold, we consider it as a dual touch, otherwise as a single touch.



Dual Touch X-Position Measurements

## TOUCH-PRESSURE MEASUREMENT

The pressure applied to the touch screen by a pen or finger to filter unavailable can also be measured by the controller using some simple calculations. The contact resistance between the X and Y plates is measured, provide a good indication of the size of the depressed area and the applied pressure. The area of the touch spot t is proportional to the size of the object touching it. And the

value of this resistance ( $R_{\text{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\text{PLATE}}$ ). Three touch screen conversions are required: measurement of the X position,  $X_{\text{POSITION}}(Y+ \text{ input})$ ; measurement of the  $X+$  input with the excitation voltage applied to  $Y+$  and  $X-$  ( $Z1$  measurement); and measurement of the  $Y-$  input with the excitation voltage applied to  $Y+$  and  $X-$  ( $Z2$  measurement). These three measurements are illustrated in Figure 12. The controller have two special ADC channel settings to configure the X and Y switches for the  $Z1$  and  $Z2$  measurements and store the results in the  $Z1$  and  $Z2$  result registers. The touch resistance ( $R_{\text{TOUCH}}$ ) can then be calculated using the following equation:

$$R_{\text{TOUCH}} = (R_{X\text{PLATE}}) \times (X_{\text{POSITION}} / 4096) \times [(Z2/Z1) - 1] \quad (1)$$



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_{\text{POSITION}}$ ), the Y position ( $Y_{\text{POSITION}}$ ), and the  $Z1$  position. The following equation also calculates the touch resistance ( $R_{\text{TOUCH}}$ ):

$$R_{\text{TOUCH}} = R_{X\text{PLATE}} \times (X_{\text{POSITION}}/4096) \times [(4096/Z1) - 1] - R_{Y\text{PLATE}} \times [1 - (Y_{\text{POSITION}}/4096)] \quad (2)$$

## PEN DOWN DETECTION, WITH PROGRAMMABLE SENSITIVITY

Pen down detection is used as an interrupt to the host.  $R_{\text{IRQ}}$  is an internal pull-up resistor with a programmable value of 6~96 kΩ (default 48kΩ). The pen down IRQ output is pulled high by an internal pull-up. In the pen down detection, the  $Y-$  driver is on and connected to GND, and the pen down IRQ output is connected to the  $X+$  input. When the panel is touched, the  $X+$  input is pulled to ground through the touch screen, and the pen down IRQ output goes low because of the current path through the panel to GND, initiating an interrupt to the processor. During the measurement cycle for  $X$ ,  $Y$ , and  $Z$ -position, the  $X+$  input is disconnected from the pen down IRQ pull-down transistor to eliminate any pull-up resistor leakage current from flowing through the touch screen, thus causing no errors.



Example of Pen touch Interrupt via Pen Down IRQ

## 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. Then the averaging filter size determines the number of values to average. There are four choices which is configured by TP\_CTRL3 register (bit 1 and bit 0) to filtrate the ADC sampling data. It is showed in following table.

Median and averaging Filter Size (TP\_CTRL3)

| <b>bit1</b> | <b>bit0</b> | <b>Averaging Filter Size</b> | <b>Median Filter Size</b> |
|-------------|-------------|------------------------------|---------------------------|
| 0           | 0           | 2                            | 4                         |
| 0           | 1           | 3                            | 5                         |
| 1           | 0           | 4                            | 8                         |
| 1           | 1           | 8                            | 16                        |

In this example, the TP\_CTRL3 register bit 1 and bit 0 is configured as 2'b11. So the median filter has

a window size of 16. This means that 16 measurements are taken and arranged in descending order in a temporary array. The averaging window size in this example is 8. The output is the average of the middle eight values of the 16 measurements taken with the median filter.



Median and Averaging Filter Example

### 1.15.6. 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 and averaging filter Controller Register              |
| TP_INT_FIFOC  | 0x10   | TP Interrupt FIFO Control Register                           |
| TP_INT_FIFOS  | 0x14   | TP Interrupt FIFO Status Register                            |

| Register Name | Offset | Description                    |
|---------------|--------|--------------------------------|
| TP_TPR        | 0x18   | TP Temperature Period Register |
| TP_CDAT       | 0x1c   | TP Common Data                 |
| TEMP_DATA     | 0x20   | Temperature Data Register      |
| TP_DATA       | 0x24   | TP Data Register               |
| TP_IO_CONFIG  | 0x28   | TP IO Configuration            |
| TP_PORT_DATA  | 0x2c   | TP IO Port Data                |

## 1.15.7. TP Register Description

### 1.15.7.1. TP CONTROL REGISTER 0

| Offset: 0x00 |                | Register Name: TP_CTRL0 |                                                                                                                                                                                |
|--------------|----------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex         | Description                                                                                                                                                                    |
| 31:24        | R/W            | 0xF                     | ADC_FIRST_DLY.<br>ADC First Convert Delay Time(T_FCDT)setting<br>Based on ADC First Convert Delay Mode select (Bit 23)<br>$T_{FCDT} = ADC\_FIRST\_DLY * ADC\_FIRST\_DLY\_MODE$ |
| 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                                                                              |

| Offset: 0x00 |                | Register Name: TP_CTRL0 |                                                                                                                                                                                |
|--------------|----------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex         | Description                                                                                                                                                                    |
| 19:16        | R/W            | 0x0                     | FS_DIV.<br>ADC Sample Frequency Divider<br>0000: CLK_IN/2 <sup>(20-n)</sup><br>0001: CLK_IN/2 <sup>(20-n)</sup><br>0010: CLK_IN/2 <sup>(20-n)</sup><br>....<br>1111: CLK_IN/32 |
| 15:0         | R/W            | 0x0                     | TACQ.<br>Touch panel ADC acquire time<br>CLK_IN/(16*(N+1))                                                                                                                     |

### 1.15.7.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            | R/W            | 0x1                     | CHOP_TEMP_EN<br>Chop temperature calibration enable<br>0: Disable<br>1: Enable                         |
| 6            | R/W            | 0x0                     | TOUCH_PAN_CALI_EN.                                                                                     |

| <b>Offset: 0x04</b> |                        | <b>Register Name: TP_CTRL1</b> |                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------|------------------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default<br/>/Hex</b>        | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                |
|                     |                        |                                | 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. |

### 1.15.7.3. TP CONTROL REGISTER 2

| <b>Offset: 0x08</b> |                        |                         | <b>Register Name: TP_CNT2</b>                                                             |
|---------------------|------------------------|-------------------------|-------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                                        |
| 31:28               | R/W                    | 0x8                     | TP_SENSITIVE_ADJUST.<br>Internal Pull-up Resistor Control<br>0000 least sensitive<br>0011 |

| Offset: 0x08 |                |             | Register Name: TP_CNT2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              |                |             | <p>.....</p> <p>1111 most sensitive</p> <p>Notes: Used to adjust sensitivity of pen down detection</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 27:26        | R/W            | 0x0         | <p>TP_FIFO_MODE_SELECT.</p> <p>TP FIFO Access Data Mode Select</p> <p>00: FIFO store X1,Y1 data for single touch no pressure mode</p> <p>01: FIFO store X1,Y1, <math>\Delta</math>X, <math>\Delta</math>Y data for dual touch no pressure mode</p> <p>10: FIFO store X1,Y1, X2,Y2 data for dual touch no pressure mode</p> <p>11: FIFO store X1,Y1, X2,Y2,Z1,Z2 data for dual touch and pressure mode</p> <p>Notes: The ADC output data in single touch mode can store in FIFO with TP_FIFO_MODE_SELECT configured as 01,10,11. But the data <math>\Delta</math>X, <math>\Delta</math>Y is theoretically equal to zero and X2,Y2 is equal to X1,Y1.</p> |
| 25           | /              | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 24           | R/W            | 0x0         | <p>PRE_MEA_EN.</p> <p>TP Pressure Measurement Enable Control</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23:0         | R/W            | 0xFFFF      | <p>PRE_MEA_THRE_CNT.</p> <p>TP Pressure Measurement threshold Control</p> <p>Notes:</p> <p>0x000000: least sensitive</p> <p>0xFFFF: most sensitive</p> <p>Notes: used to adjust sensitivity of touch</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 1.15.7.4. MEDIAN AND AVERAGING FILTER CONTROL REGISTER

| Offset: 0x0c |                |                 | Register Name: TP_CTRL3 |
|--------------|----------------|-----------------|-------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description             |
| 31:3         | /              | /               | /                       |
| 2            | R/W            | 0x0             | FILTER_EN.              |

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

#### 1.15.7.5. TP INTERRUPT& FIFO CONTROL REGISTER

| Offset: 0x10 |                |                 | Register Name: TP_INT                                                                         |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                   |
| 31:19        | /              | /               | <b>0x0000_0F00</b>                                                                            |
| 18           | R/W            | 0x0             | TEMP_IRQ_EN.<br>Temperature IRQ Enable<br>0: Disable<br>1: Enable                             |
| 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<br>0: Disable<br>1: Enable               |
| 15:14        | /              | /               | /                                                                                             |
| 13           | R/W            | 0x0             | TP_DATA_XY_CHANGE.<br>TP FIFO X,Y Data interchange Function Select<br>0: Disable<br>1: Enable |
| 12:8         | R/W            | 0xF             | TP_FIFO_TRIG_LEVEL.<br>TP FIFO Data Available Trigger Level                                   |

| Offset: 0x10 |                |                 | Register Name: TP_INT                                                                          |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                    |
|              |                |                 | <b>0x0000_0F00</b>                                                                             |
|              |                |                 | 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 |

#### 1.15.7.6. TP INTERRUPT& FIFO STATUS REGISTER

| Offset: 0x14 |                |                 | Register Name: TP_FIFOCS                                                                                                                                                              |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                           |
| 31:19        | /              | /               | /                                                                                                                                                                                     |
| 18           | R/W            | 0x0             | TEMP_IRQ_PENDING.<br>Temperature 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 |
| 17           | R/W            | 0x0             | FIFO_OVERRUN_PENDING.                                                                                                                                                                 |

|       |     |     |                                                                                                                                                                                                           |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 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.<br>TP FIFO Data Available pending Bit<br>0: NO Pending IRQ<br>1: FIFO Available Pending IRQ<br>Write '1' to clear this interrupt or 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. |

#### 1.15.7.7. TP TEMPERATURE PERIOD REGISTER

| Offset: 0x18 |                |                 | Register Name: TP_TPR |
|--------------|----------------|-----------------|-----------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description           |
|              |                |                 |                       |

| Offset: 0x18 |                |                 | Register Name: TP_TPR                              |
|--------------|----------------|-----------------|----------------------------------------------------|
| Bit          | Read/<br>Write | 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*(1/clk_in) |

#### 1.15.7.8. COMMON DATA REGISTER

| Offset: 0x1c |                |                 | Register Name: TP_CDAT                                                                |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                           |
| 31:12        | /              | /               | /                                                                                     |
| 11:0         | R/W            | 0x800           | TP_CDAT.<br>TP Common Data<br>Notes: used to adjust the tolerance of the internal ADC |

#### 1.15.7.9. TEMPERATURE DATA REGISTER

| Offset: 0x20 |                |             | Register Name: TEMP_DATA             |
|--------------|----------------|-------------|--------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                          |
|              |                |             | Default: 0x0000_0000                 |
| 31:12        | /              | /           | /                                    |
| 11:0         | R              | 0x0         | TEMP_DATA.<br>Temperature Data Value |

#### 1.15.7.10. TP DATA REGISTER

| Offset: 0x24 | Register Name: TP_DATA |
|--------------|------------------------|
|--------------|------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                                               |
|------------|------------------------|-------------------------|--------------------------------------------------------------------------------------------------|
| 31:12      | /                      | /                       | /                                                                                                |
| 11:0       | R                      | 0x0                     | TP_DATA.<br>Touch Panel X ,Ydata or Auxiliary analog input data converted by<br>the internal ADC |

### 1.15.7.11. 3.6.11 TP PORT IO CONFIGURE REGISTER

| <b>Offset: 0x28</b> |                        |                         | <b>Register Name: TP_IO_CONFIG</b>                                                                                    |
|---------------------|------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                                                                    |
| 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_XN 011:/<br>100: / 101:/<br>110: / 111:/ |
| 3                   | /                      | /                       | /                                                                                                                     |
| 2:0                 | R/W                    | 0x2                     | TX_P_SELECT<br>TX_P Port Function Select:                                                                             |

| Offset: 0x28 |                |                 | Register Name: TP_IO_CONFIG                 |                                          |
|--------------|----------------|-----------------|---------------------------------------------|------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                 |                                          |
|              |                |                 | 000:Input<br>010: TP_XP<br>100: /<br>110: / | 001:Output<br>011: /<br>101: /<br>111: / |

#### 1.15.7.12. TP PORT DATA REGISTER

| Offset: 0x2c |                |                 | Register Name: TP_PORT_DATA                                                |
|--------------|----------------|-----------------|----------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                |
| 31:12        | /              | /               | /                                                                          |
| 3:0          | R/W            | 0x0             | TP_PORT_DATA<br>TP Port Data Value, TP_YN,TP_YP, TP_XN, TP_XP(y2/y1/x2/x1) |

## 1.16. Security System

### 1.16.1. Overview

The Security System (SS) is one encrypt/ decrypt function accelerator that is suitable for a variety of applications. It supports both encryption and decryption. Several modes are supported by the SS module.

It features:

- AES, DES, 3DES, SHA-1, MD5 are supported by this system
- ECB, CBC, CNT modes for AES/DES/3DES
- 128-bit, 192-bit and 256-bit key size for AES
- 160-bit hardware PRNG with 192-bit seed
- 32-word RX FIFO and 32-word TX FIFO for high speed application
- Support CPU mode and DMA mode
- Interrupt support

## 1.16.2. Security System Block Diagram



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

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                          |
|----------------------|---------------|---------------------------------------------|
| 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_CTS_LEN           | 0x60          | AES-CTS ciphertext length                   |
| SS_RXFIFO            | 0x200         | RX FIFO input port                          |
| SS_TXFIFO            | 0x204         | TX FIFO output port                         |

## 1.16.4. Security System Register Description

### 1.16.4.1. SECURITY SYSTEM CONTROL REGISTER

| Offset: 0x00 |            |         | Register Name: SS_CTL<br>Default Value: 0x0000_0000                                                                                                             |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                     |
| 31:28        | /          | /       | /                                                                                                                                                               |
| 27:24        | R/W        | 0       | SKEY_SELECT<br>AES/DES/3DES key select<br>0: Select input SS_KEYx (Normal Mode)<br>1: Select SID_RKEYx from Security ID<br>2: Select SID_BKEYx from Security ID |

| Offset: 0x00 |            |         | Register Name: SS_CTL<br>Default Value: 0x0000_0000                                                                                                                                                         |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                 |
|              |            |         | 3-10: Select internal Key n (n from 0 to 7)<br>Others: Reserved                                                                                                                                             |
| 18:16        | R          | x       | DIE_ID<br>Die Bonding ID                                                                                                                                                                                    |
| 15           | R/W        | 0       | PRNG_MODE<br>PRNG generator mode<br>0: One-shot mode<br>1: Continue mode                                                                                                                                    |
| 14           | R/W        | 0       | IV_MODE<br>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. |
| 13:12        | R/W        | 0       | SS_OP_MODE<br>SS Operation Mode<br>00: Electronic Code Book (ECB) mode<br>01: Cipher Block Chaining (CBC) mode<br>10: Counter (CNT) mode<br>11: AES Ciphertext Stealing (CTS) mode                          |
| 11:10        | R/W        | 0       | CNT_WIDTH<br>Counter Width for CNT Mode<br>00: 16-bits Counter<br>01: 32-bits Counter<br>10: 64-bits Counter<br>11: Reserved                                                                                |
| 9:8          | R/W        | 0       | AES_KEY_SIZE<br>Key Size for AES<br>00: 128-bits<br>01: 192-bits<br>10: 256-bits<br>11: Reserved                                                                                                            |
| 7            | R/W        | 0       | SS_OP_DIR<br>SS Operation Direction                                                                                                                                                                         |

| <b>Offset: 0x00</b> |                   |                | <b>Register Name: SS_CTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                               |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                              |
|                     |                   |                | 0: Encryption<br>1: Decryption                                                                                                                                                                                                                                                                                                                                                                  |
| 6:4                 | R/W               | 0              | <b>SS_METHOD</b><br>SS Method<br>000: AES<br>001: DES<br>010: Triple DES (3DES)<br>011: SHA-1<br>100: MD5<br>101: PRNG<br>Others: Reserved                                                                                                                                                                                                                                                      |
| 3                   | /                 | /              | /                                                                                                                                                                                                                                                                                                                                                                                               |
| 2                   | R/W               | 0              | <b>SHA1_MD5_END_BIT</b><br>SHA-1/MD5 Data End bit<br><p>Write '1' to tell SHA-1/MD5 engine that the text data is end. If there is some data in FIFO, the engine would fetch these data and process them. After finishing message digest, this bit is clear to '0' by hardware and message digest can be read out from digest registers.</p> <p>Notes: It is only used for SHA-1/MD5 engine.</p> |
| 1                   | R/W               | 0              | <b>PRNG_START</b><br>PRNG start bit<br><p>In PRNG one-shot mode, write '1' to start PRNG. After generating one group random data (5 words), this bit is clear to '0' by hardware.</p>                                                                                                                                                                                                           |
| 0                   | R/W               | 0              | <b>SS_ENABLE</b><br>SS Enable<br><p>A disable on this bit overrides any other block and flushes all FIFOs.</p> <p>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                  |

#### 1.16.4.2. SECURITY SYSTEM KEY [N] REGISTER

| <b>Offset: 0x04 +4*n</b> |                   |                | <b>Register Name: SS_KEY[n]</b><br><b>Default Value: 0x0000_0000</b> |
|--------------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>               | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                     | R/W               | 0              | SS_KEY<br>Key[n] Input Value (n= 0~7)/ PRNG Seed[n] (n= 0~5)         |

#### 1.16.4.3. SECURITY SYSTEM IV[N] REGISTER

| <b>Offset: 0x24 +4*n</b> |                   |                | <b>Register Name: SS_IV[n]</b><br><b>Default Value: 0x0000_0000</b> |
|--------------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>               | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:0                     | R/W               | 0              | SS_IV_VALUE<br>Initialization Vector (IV[n]) Input Value (n= 0~3)   |

#### 1.16.4.4. SECURITY SYSTEM COUNTER[N] REGISTER

| <b>Offset: 0x34 +4*n</b> |                   |                | <b>Register Name: SS_CNT[n]</b><br><b>Default Value: 0x0000_0000</b> |
|--------------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>               | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                     | R/W               | 0              | SS_CNT_VALUE<br>Counter mode preload Counter Input Value (n= 0~3)    |

#### 1.16.4.5. SECURITY SYSTEM FIFO CONTROL/ STATUS REGISTER

| <b>Offset: 0x44</b> |                   |                | <b>Register Name: SS_FCSR</b><br><b>Default Value: 0x6000_0F0F</b>   |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31                  | /                 | /              | /                                                                    |
| 30                  | R                 | 0x1            | RXFIFO_STATUS<br>RX FIFO Empty<br>0: No room for new word in RX FIFO |

| <b>Offset: 0x44</b> |                   |                | <b>Register Name: SS_FCSR</b><br><b>Default Value: 0x6000_0F0F</b>                                                                                                                                      |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                      |
|                     |                   |                | 1: More than one room for new word in RX FIFO ( $\geq 1$ word)                                                                                                                                          |
| 29:24               | R                 | 0x20           | RXFIFO_EMP_CNT<br>RX FIFO Empty Space Word Counter                                                                                                                                                      |
| 23                  | /                 | /              | /                                                                                                                                                                                                       |
| 22                  | R                 | 0              | TXFIFO_STATUS<br>TX FIFO Data Available Flag<br>0: No available data in TX FIFO<br>1: More than one data in TX FIFO ( $\geq 1$ word)                                                                    |
| 21:16               | R                 | 0              | TXFIFO_AVA_CNT<br>TX FIFO Available Word Counter                                                                                                                                                        |
| 15:13               | /                 | /              | /                                                                                                                                                                                                       |
| 12:8                | R/W               | 0xF            | RXFIFO_INT_TRIG_LEVEL<br>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            | TXFIFO_INT_TRIG_LEVEL<br>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 for output the result data. |

#### 1.16.4.6. SECURITY SYSTEM INTERRUPT CONTROL/ STATUS REGISTER

| <b>Offset: 0x48</b> |                   |                | <b>Register Name: SS_ICSR</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:11               | /                 | /              | /                                                                  |
| 10                  | R/W               | 0              | RXFIFO_EMP_PENDING_BIT                                             |

| Offset: 0x48 |            |         | Register Name: SS_ICSR<br>Default Value: 0x0000_0000                                                                                                                                                                                                              |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                       |
|              |            |         | RX FIFO Empty Pending bit<br>0: No pending<br>1: RX FIFO Empty pending<br>Notes: Write '1' to clear or automatic clear if interrupt condition fails.                                                                                                              |
| 9            | /          | /       | /                                                                                                                                                                                                                                                                 |
| 8            | R/W        | 0       | TXFIFO_AVA_PENDING_BIT<br>TX FIFO Data Available Pending bit<br>0: No TX FIFO pending<br>1: TX FIFO pending<br>Notes: Write '1' to clear or automatic clear if interrupt condition fails.                                                                         |
| 7:5          | /          | /       | /                                                                                                                                                                                                                                                                 |
| 4            | R/W        | 0       | DRA_ENABLE<br>DRQ Enable<br>0: Disable DRQ (CPU polling mode)<br>1: Enable DRQ (DMA mode)                                                                                                                                                                         |
| 3            | /          | /       | /                                                                                                                                                                                                                                                                 |
| 2            | R/W        | 0       | RXFIFO_EMP_INT_ENABLE<br>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 great or equal ( $\geq$ ) the preset threshold, the interrupt is trigger and the correspond flag is set.       |
| 1            | /          | /       | /                                                                                                                                                                                                                                                                 |
| 0            | R/W        | 0       | TXFIFO_AVA_INT_ENABLE<br>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 great or equal ( $\geq$ ) the preset threshold, the interrupt is trigger and the correspond flag is set. |

#### 1.16.4.7. SECURITY SYSTEM MESSAGE DIGEST[N] REGISTER

| <b>Offset: 0x4C +4*n</b> |                   |                | <b>Register Name: SS_MD[n]</b><br><b>Default Value: 0x0000_0000</b> |
|--------------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>               | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:0                     | R                 | 0              | SS_MID_DATA<br>SHA1/ MD5 Message digest MD[n] for SHA1/MD5 (n= 0~4) |

#### 1.16.4.8. SECURITY SYSTEM CTS LENGTH REGISTER

| <b>Offset: 0x60</b> |                   |                | <b>Register Name: SS_CTS_LEN</b><br><b>Default Value: 0x0000_0000</b>     |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                        |
| 31:0                | R/W               | 0              | AES-CTS ciphertext length in byte unit<br>The value of '0' means no data. |

#### 1.16.4.9. SECURITY SYSTEM RX FIFO REGISTER

| <b>Offset: 0x200</b> |                   |                | <b>Register Name: SS_RX</b><br><b>Default Value: 0x0000_0000</b> |
|----------------------|-------------------|----------------|------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                               |
| 31:0                 | W                 | 0              | SS_RX_FIFO<br>32-bits RX FIFO for Input                          |

#### 1.16.4.10. SECURITY SYSTEM TX FIFO REGISTER

| <b>Offset: 0x204</b> |                   |                | <b>Register Name: SS_TX</b><br><b>Default Value: 0x0000_0000</b> |
|----------------------|-------------------|----------------|------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                               |
| 31:0                 | R                 | 0              | SS_TX_FIFO<br>32-bits TX FIFO for Output                         |

#### 1.16.4.11. SECURITY SYSTEM CLOCK REQUIREMENT

| Clock Name | Description     | Requirement          |
|------------|-----------------|----------------------|
| ahb_clk    | AHB bus clock   | $\geq 24\text{MHz}$  |
| ss_clk     | SS serial clock | $\leq 150\text{MHz}$ |

## 1.17. Security JTAG

### 1.17.1. Overview

This is authentication module for security JTAG. There are two bits in EFUSE field. The two bits can be program before ship. One bit is used for enable/disable JTAG function and another bit is used for whether JTAG authentication function is ON. When JTAG function and JTAG authentication function is ON, the user must provide JTAG password before using JTAG function.

## 1.17.2. Security JTAG Register List

| Module Name | Base Address |
|-------------|--------------|
| SJTAG       | 0x01C23C00   |

## 1.17.3. Security JTAG Register Description

### 1.17.3.1. SJTAG PASSWORD 0 REGISTER

| <b>Offset: 0x00</b> |            |         | <b>Register Name: SJTAG_PWD0</b><br><b>Default Value: 0xFFFF_FFFF</b> |
|---------------------|------------|---------|-----------------------------------------------------------------------|
| Bit                 | Read/Write | Default | Description                                                           |
| 31:0                | W          | X       | JTAG_PWD<br>SJTAG Password [31:0]                                     |

### 1.17.3.2. SJTAG PASSWORD 1 REGISTER

| <b>Offset: 0x04</b> |            |         | <b>Register Name: SJTAG_PWD1</b><br><b>Default Value: 0xFFFF_FFFF</b> |
|---------------------|------------|---------|-----------------------------------------------------------------------|
| Bit                 | Read/Write | Default | Description                                                           |
| 31:0                | W          | X       | JTAG_PWD<br>SJTAG Password [63:32]                                    |

### 1.17.3.3. SJTAG STATUS REGISTER

| <b>Offset: 0x08</b> |            |         | <b>Register Name: SJTAG_STATUS</b><br><b>Default Value: 0xFFFF_FFFF</b> |
|---------------------|------------|---------|-------------------------------------------------------------------------|
| Bit                 | Read/Write | Default | Description                                                             |
| 31:1                | /          | /       | /                                                                       |

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: SJTAG_STATUS</b><br><b>Default Value: 0XXXX_XXXX</b>                            |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                |
| 0                   | R                 | x              | JTAG_ONOFF_FLAG<br>JTAG function ON/OFF flag<br>0: JTAG function is ON<br>1: JTAG function is OFF |

## 1.18. Security ID

### 1.18.1. Overview

There is one on chip EFUSE, which provides 128-bit, 64-bit and one 32-bit electrical fuses for security application.

It features:

- 128-bit electrical fuses for root key
- 128-bit electrical fuses for boot key
- 64-bit electrical fuses for security JTAG
- 16-bit electrical fuses for chip configure application
- 16-bit electrical fuses for vendors application

### 1.18.2. SID Block Diagram



### 1.18.3. Security System 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] |
| SID_BKEY0     | 0x10   | Boot Key[31:0]   |
| SID_BKEY1     | 0x14   | Boot Key[63:32]  |

| Register Name | Offset | Description                                                    |
|---------------|--------|----------------------------------------------------------------|
| SID_BKEY2     | 0x18   | Boot Key[95:64]                                                |
| SID_BKEY3     | 0x1c   | Boot Key[127:96]                                               |
| SID_JKEY0     | 0x20   | Security JTAG key[31:0]                                        |
| SID_JKEY1     | 0x24   | Security JTAG key[63:32]                                       |
| SID_CKEY      | 0x28   | 16-bit key for configuration and 16-bit for vendor application |
| SID_PRCTL     | 0x40   | SID Program/Read Control Register                              |
| SID_PKEY      | 0x50   | SID Program Key Value Register                                 |
| SID_RKEY      | 0x60   | SID Read Key Value Register                                    |

## 1.18.4. Security ID Register Description

### 1.18.4.1. SID ROOT KEY 0 REGISTER

| <b>Offset: 0x00</b> |            |         | <b>Register Name: SID_RKEY0</b><br><b>Default Value: 0xFFFF_FFFF</b> |
|---------------------|------------|---------|----------------------------------------------------------------------|
| Bit                 | Read/Write | Default | Description                                                          |
| 31:0                | R          | x       | ROOT_KEY<br>Securiy root key[31:0]                                   |

### 1.18.4.2. SID ROOT KEY 1 REGISTER

| <b>Offset: 0x04</b> |            |         | <b>Register Name: SID_RKEY1</b><br><b>Default Value: 0xFFFF_FFFF</b> |
|---------------------|------------|---------|----------------------------------------------------------------------|
| Bit                 | Read/Write | Default | Description                                                          |
| 31:0                | R          | x       | ROOT_KEY<br>Securiy root key[63:32]                                  |

#### 1.18.4.3. SID ROOT KEY 2 REGISTER

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: SID_RKEY2</b><br><b>Default Value: 0xXXXX_XXXX</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                | R                 | x              | ROOT_KEY<br>Securiy root key[95:64]                                  |

#### 1.18.4.4. SID ROOT KEY 3 REGISTER

| <b>Offset: 0x0c</b> |                   |                | <b>Register Name: SID_RKEY3</b><br><b>Default Value: 0xXXXX_XXXX</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                | R                 | x              | ROOT_KEY<br>Securiy root key[127:96]                                 |

#### 1.18.4.5. SID BOOT KEY 0 REGISTER

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: SID_BKEY0</b><br><b>Default Value: 0xXXXX_XXXX</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                | R                 | x              | BOOT_KEY<br>Securiy boot key[31:0]                                   |

#### 1.18.4.6. SID BOOT KEY 1 REGISTER

| <b>Offset: 0x14</b> |                   |                | <b>Register Name: SID_BKEY1</b><br><b>Default Value: 0xXXXX_XXXX</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                | R                 | x              | BOOT_KRY<br>Securiy boot key[63:32]                                  |

#### 1.18.4.7. SID BOOT KEY 2 REGISTER

| <b>Offset: 0x18</b> |                   |                | <b>Register Name: SID_BKEY2</b><br><b>Default Value: 0xXXXX_XXXX</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                | R                 | x              | BOOT_KRY<br>Securiy boot key[95:64]                                  |

#### 1.18.4.8. SID BOOT KEY 3 REGISTER

| <b>Offset: 0x1c</b> |                   |                | <b>Register Name: SID_BKEY3</b><br><b>Default Value: 0xXXXX_XXXX</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                | R                 | x              | BOOT_KRY<br>Securiy boot key[127:96]                                 |

#### 1.18.4.9. SID SJTAG KEY 0 REGISTER

| <b>Offset: 0x20</b> |                   |                | <b>Register Name: SID_JKEY0</b><br><b>Default Value: 0xXXXX_XXXX</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                | R                 | x              | JTAG_KEY<br>Securiy JTAG key [31:0]                                  |

#### 1.18.4.10. SID SJTAG KEY 1 REGISTER

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: SID_JKEY1</b><br><b>Default Value: 0xXXXX_XXXX</b>                                                                              |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                |
| 31:0                | R                 | x              | JTAG_KEY<br>Securiy JTAG key [63:31]<br>When JTAG key read lock flag is off, the 64-bits JKEY value can be read out by CPU, else it is undefined. |

#### 1.18.4.11. SID COMMON KEY REGISTER

| Offset: 0x28 |            |         | Register Name: SID_CKEY<br>Default Value: 0XXXX_XXXX                                                                                                                                                |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                         |
| 31:16        | R          | x       | VENDOR_FIELD<br>16-bit key for vendor application                                                                                                                                                   |
| 15:13        | /          | /       | /                                                                                                                                                                                                   |
| 12           | R          | x       | HDMI_KEY_LOCK<br>HDMI HDCP key read lock flag<br>0: key value can be read out by CPU<br>1: key value can't be read out by CPU<br>HDCP Data Address 0x80~0x19F.                                      |
| 11:6         | R          | x       | /                                                                                                                                                                                                   |
| 5            | R          | x       | BKEY_VALID_FLAG<br>Boot key valid flag<br>0: Boot key invalid<br>1: Boot key valid<br>When this field is '1', CPU would perform security boot after power up. This bit would be checked by bootrom. |
| 4            | R          | x       | BKEY_READ_LOCK<br>Boot key read lock flag<br>0: key value can be read out by CPU<br>1: key value can't be read out by CPU                                                                           |
| 3            | R          | x       | RKEY_READ_LOCK<br>Root key read lock flag<br>0: key value can be read out by CPU<br>1: key value can't be read out by CPU                                                                           |
| 2            | R          | x       | JKEY_READ_LOCK<br>JTAG key read lock flag<br>0: key value can be read out by CPU<br>1: key value can't be read out by CPU                                                                           |
| 1            | R          | x       | JTAG_AUTH_ONOFF<br>JTAG Authentication on/off bit<br>0: JTAG security password check off                                                                                                            |

| <b>Offset: 0x28</b> |                   |                | <b>Register Name: SID_CKEY</b><br><b>Default Value: 0xXXXX_XXXX</b>                                                                    |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                     |
|                     |                   |                | 1: JTAG security password check on<br>This bit is active only when JTAG function is enabled.                                           |
| 0                   | R                 | x              | JTAG_ENA<br>JTAG function enable/disable bit<br>0: JTAG function enable<br>1: JTAG function is closed and user can't use JTAG to debug |

#### 1.18.4.12. SID PROGRAM/READ CONTROL REGISTER

| <b>Offset: 0x40</b> |                   |                | <b>Register Name: SID_PRCTL</b><br><b>Default Value: 0x0000_0000</b>                                                                         |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                           |
| 31:25               | /                 | /              | /                                                                                                                                            |
| 24:16               | R/W               | 0              | PG_INDEX<br>Program index<br>The index value of 8-bits electrical fuses hardware macrocell, and the lowest two bit must be zero.             |
| 15:8                | R/W               | 0              | OP_LOCK<br>Efuse Operation Lock<br>The Read Start (Bit1) and Program Start (Bit0) only can be write when these bits (Bit[15:8]) set to 0xAC. |
| 7:3                 | /                 | /              |                                                                                                                                              |
| 2                   | R                 | x              | HW_READ_STATUS<br>Hardware Read Status<br>0: No Hardware Operation<br>1: Hardware Reading                                                    |
| 1                   | R/W               | 0              | READ_START<br>Software Read Start<br>Write '1' to start software read and automatically clear to '0' after read.                             |
| 0                   | R/W               | 0              | PG_START<br>Software program start<br>Write '1' to start software program and automatically clear to                                         |

| <b>Offset: 0x40</b> |                   |                | <b>Register Name: SID_PRCTL</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
|                     |                   |                | '0' after program.                                                   |

#### 1.18.4.13. SID PROGRAM KEY VALUE REGISTER

| <b>Offset: 0x50</b> |                   |                | <b>Register Name: SID_PKEY</b><br><b>Default Value: 0x0000_0000</b>                                           |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                            |
| 31:0                | R/W               | 0              | PG_KEY_VALUE<br>Program key value<br>The CPU can write 32-bits value into this register for fuse by software. |

#### 1.18.4.14. SID READ KEY VALUE REGISTER

| <b>Offset: 0x60</b> |                   |                | <b>Register Name: SID_RKEY</b><br><b>Default Value: 0x0000_0000</b>                                           |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                            |
| 31:0                | R                 | 0              | PG_KEY_VALUE<br>Program key value<br>The CPU can write 32-bits value into this register for fuse by software. |

## 1.19. Port Controller

### 1.19.1. Port Description

The chip has several ports for multi-functional input/out pins. They are shown below:

Port A(PA): 18 input/output port  
Port B(PB): 24 input/output port  
Port C(PC): 25 input/output port  
Port D(PD): 28 input/output port  
Port E(PE) : 12 input/output port  
Port F(PF) : 6 input/output port  
Port G(PG) : 12 input/output port  
Port H(PH) : 28 input/output port  
Port I(PI) : 22 input/output port  
Port S(PS) : 84 input/output port for DRAM controller

For various system configurations, these ports can be easily configured by software. All these ports (except PS) can be configured as GPIO if multiplexed functions not used. 32 external PIO interrupt sources are supported and interrupt mode can be configured by software.

### 1.19.2. Port Configuration Table

| <b>Port A(PA)</b> | <b>Multiplex Function Select</b> |           |            |              |           |
|-------------------|----------------------------------|-----------|------------|--------------|-----------|
| PA0               | ERXD3                            | SPI1_CS0  | UART2_RTS  | GRXD3        |           |
| PA1               | ERXD2                            | SPI1_CLK  | UART2_CTS  | GRXD2        |           |
| PA2               | ERXD1                            | SPI1_MOSI | UART2_TX   | GRXD1        |           |
| PA3               | ERXD0                            | SPI1_MISO | UART2_RX   | GRXD0        |           |
| PA4               | ETXD3                            | SPI1_CS1  |            | GTXD3        |           |
| PA5               | ETXD2                            | SPI3_CS0  |            | GTXD2        |           |
| PA6               | ETXD1                            | SPI3_CLK  |            | GTXD1        |           |
| PA7               | ETXD0                            | SPI3_MOSI |            | GTXD0        |           |
| PA8               | ERXCK                            | SPI3_MISO |            | GRXCK        |           |
| PA9               | ERXERR                           | SPI3_CS1  |            | GNULL/ERXERR | I2S1_MCLK |
| PA10              | ERXDV                            |           | UART1_TX   | GRXCTL/RXDV  |           |
| PA11              | EMDC                             |           | UART1_RX   | GMDC         |           |
| PA12              | EMDIO                            | UART6_TX  | UART1_RTS  | GMDIO        |           |
| PA13              | ETXEN                            | UART6_RX  | UART1_CTS  | GTXCTL/ETXEN |           |
| PA14              | ETXCK                            | UART7_TX  | UART1_DTR  | GNULL/ETXCK  | I2S1_BCLK |
| PA15              | ECRS                             | UART7_RX  | UART1_DSR  | GTXCK/ECRS   | I2S1_LRCK |
| PA16              | ECOL                             | CAN_TX    | UART1_DCD  | GCLKIN/ECOL  | I2S1_DO   |
| PA17              | ETXERR                           | CAN_RX    | UART1_RING | GNULL/ETXERR | I2S1_DI   |

Port A(PA) Multiplex Function Select Table

| <b>Port B(PB)</b> | <b>Multiplex Function Select</b> |           |            |  |           |
|-------------------|----------------------------------|-----------|------------|--|-----------|
| PB0               | TWI0_SCK                         |           |            |  |           |
| PB1               | TWI0_SDA                         |           |            |  |           |
| PB2               | PWM0                             |           |            |  |           |
| PB3               | IR0_TX                           |           | SPDIF_MCLK |  | STANBYWFI |
| PB4               | IR0_RX                           |           |            |  |           |
| PB5               | I2S_MCLK                         | AC97_MCLK |            |  |           |

| <b>Port B(PB)</b> | <b>Multiplex Function Select</b> |           |          |  |
|-------------------|----------------------------------|-----------|----------|--|
| PB6               | I2S_BCLK                         | AC97_BCLK |          |  |
| PB7               | I2S_LRCK                         | AC97_SYNC |          |  |
| PB8               | I2S_DO0                          | AC97_DO   |          |  |
| PB9               | I2S_DO1                          |           |          |  |
| PB10              | I2S_DO2                          |           |          |  |
| PB11              | I2S_DO3                          |           |          |  |
| PB12              | I2S_DI                           | AC97_DI   | SPDIF_DI |  |
| PB13              | SPI2_CS1                         |           | SPDIF_DO |  |
| PB14              | SPI2_CS0                         | JTAG_MS0  |          |  |
| PB15              | SPI2_CLK                         | JTAG_CK0  |          |  |
| PB16              | SPI2_MOSI                        | JTAG_DO0  |          |  |
| PB17              | SPI2_MISO                        | JTAG_DIO  |          |  |
| PB18              | TWI1_SCK                         |           |          |  |
| PB19              | TWI1_SDA                         |           |          |  |
| PB20              | TWI2_SCK                         |           |          |  |
| PB21              | TWI2_SDA                         |           |          |  |
| PB22              | UART0_TX                         | IR1_TX    |          |  |
| PB23              | UART0_RX                         | IR1_RX    |          |  |

Port B(PB) Multiplex Function Select Table

| <b>Port C(PC)</b> | <b>Multiplex Function Select</b> |           |  |  |
|-------------------|----------------------------------|-----------|--|--|
| PC0               | NWE#                             | SPI0_MOSI |  |  |
| PC1               | NALE                             | SPI0_MISO |  |  |
| PC2               | NCLE                             | SPI0_CLK  |  |  |
| PC3               | NCE1                             |           |  |  |
| PC4               | NCE0                             |           |  |  |
| PC5               | NRE#                             |           |  |  |
| PC6               | NRB0                             | SDC2_CMD  |  |  |
| PC7               | NRB1                             | SDC2_CLK  |  |  |
| PC8               | NDQ0                             | SDC2_D0   |  |  |
| PC9               | NDQ1                             | SDC2_D1   |  |  |
| PC10              | NDQ2                             | SDC2_D2   |  |  |

| <b>Port C(PC)</b> | <b>Multiplex Function Select</b> |           |  |  |        |
|-------------------|----------------------------------|-----------|--|--|--------|
| PC11              | NDQ3                             | SDC2_D3   |  |  |        |
| PC12              | NDQ4                             |           |  |  |        |
| PC13              | NDQ5                             |           |  |  |        |
| PC14              | NDQ6                             |           |  |  |        |
| PC15              | NDQ7                             |           |  |  |        |
| PC16              | NWP                              |           |  |  |        |
| PC17              | NCE2                             |           |  |  |        |
| PC18              | NCE3                             |           |  |  |        |
| PC19              | NCE4                             | SPI2_CS0  |  |  | EINT12 |
| PC20              | NCE5                             | SPI2_CLK  |  |  | EINT13 |
| PC21              | NCE6                             | SPI2_MOSI |  |  | EINT14 |
| PC22              | NCE7                             | SPI2_MISO |  |  | EINT15 |
| PC23              |                                  | SPI0_CS0  |  |  |        |
| PC24              | NDQS                             |           |  |  |        |

Port C(PC) Multiplex Function Select Table

| <b>Port D(PD)</b> | <b>Multiplex Function Select</b> |           |  |  |  |
|-------------------|----------------------------------|-----------|--|--|--|
| PD0               | LCD0_D0                          | LVDS0_VP0 |  |  |  |
| PD1               | LCD0_D1                          | LVDS0_VN0 |  |  |  |
| PD2               | LCD0_D2                          | LVDS0_VP1 |  |  |  |
| PD3               | LCD0_D3                          | LVDS0_VN1 |  |  |  |
| PD4               | LCD0_D4                          | LVDS0_VP2 |  |  |  |
| PD5               | LCD0_D5                          | LVDS0_VN2 |  |  |  |
| PD6               | LCD0_D6                          | LVDS0_VPC |  |  |  |
| PD7               | LCD0_D7                          | LVDS0_VNC |  |  |  |
| PD8               | LCD0_D8                          | LVDS0_VP3 |  |  |  |
| PD9               | LCD0_D9                          | LVDS0_VN3 |  |  |  |
| PD10              | LCD0_D10                         | LVDS1_VP0 |  |  |  |
| PD11              | LCD0_D11                         | LVDS1_VN0 |  |  |  |
| PD12              | LCD0_D12                         | LVDS1_VP1 |  |  |  |
| PD13              | LCD0_D13                         | LVDS1_VN1 |  |  |  |
| PD14              | LCD0_D14                         | LVDS1_VP2 |  |  |  |

| <b>Port D(PD)</b> | <b>Multiplex Function Select</b> |           |  |  |  |
|-------------------|----------------------------------|-----------|--|--|--|
| PD15              | LCD0_D15                         | LVDS1_VN2 |  |  |  |
| PD16              | LCD0_D16                         | LVDS1_VPC |  |  |  |
| PD17              | LCD0_D17                         | LVDS1_VNC |  |  |  |
| PD18              | LCD0_D18                         | LVDS1_VP3 |  |  |  |
| PD19              | LCD0_D19                         | LVDS1_VN3 |  |  |  |
| PD20              | LCD0_D20                         | CSI1_MCLK |  |  |  |
| PD21              | LCD0_D21                         | SMC_VPPEN |  |  |  |
| PD22              | LCD0_D22                         | SMC_VPPP  |  |  |  |
| PD23              | LCD0_D23                         | SMC_DET   |  |  |  |
| PD24              | LCD0_CLK                         | SMC_VCCEN |  |  |  |
| PD25              | LCD0_DE                          | SMC_RST   |  |  |  |
| PD26              | LCD0_HSYNC                       | SMC_SLK   |  |  |  |
| PD27              | LCD0_VSYNC                       | SMC_SDA   |  |  |  |

Port D(PD) Multiplex Function Select Table

| <b>Port E(PE)</b> | <b>Multiplex Function Select</b> |            |  |  |  |
|-------------------|----------------------------------|------------|--|--|--|
| PE0               | TS0_CLK                          | CSI0_PCLK  |  |  |  |
| PE1               | TS0_ERR                          | CSI0_MCLK  |  |  |  |
| PE2               | TS0_SYNC                         | CSI0_HSYNC |  |  |  |
| PE3               | TS0_DLVD                         | CSI0_VSYNC |  |  |  |
| PE4               | TS0_D0                           | CSI0_D0    |  |  |  |
| PE5               | TS0_D1                           | CSI0_D1    |  |  |  |
| PE6               | TS0_D2                           | CSI0_D2    |  |  |  |
| PE7               | TS0_D3                           | CSI0_D3    |  |  |  |
| PE8               | TS0_D4                           | CSI0_D4    |  |  |  |
| PE9               | TS0_D5                           | CSI0_D5    |  |  |  |
| PE10              | TS0_D6                           | CSI0_D6    |  |  |  |
| PE11              | TS0_D7                           | CSI0_D7    |  |  |  |

Port E(PE) Multiplex Function Select Table

| <b>Port F(PF)</b> | <b>Multiplex Function Select</b> |  |          |  |  |
|-------------------|----------------------------------|--|----------|--|--|
| PF0               | SDC0_D1                          |  | JTAG_MS1 |  |  |

| <b>Port F(PF)</b> | <b>Multiplex Function Select</b> |  |          |  |  |
|-------------------|----------------------------------|--|----------|--|--|
| PF1               | SDC0_D0                          |  | JTAG_DI1 |  |  |
| PF2               | SDC0_CLK                         |  | UART0_TX |  |  |
| PF3               | SDC0_CMD                         |  | JTAG_DO1 |  |  |
| PF4               | SDC0_D3                          |  | UART0_RX |  |  |
| PF5               | SDC0_D2                          |  | JTAG_CK1 |  |  |

Port F(PF) Multiplex Function Select Table

| <b>Port G(PG)</b> | <b>Multiplex Function Select</b> |            |           |          |  |
|-------------------|----------------------------------|------------|-----------|----------|--|
| PG0               | TS1_CLK                          | CSI1_PCLK  | SDC1_CMD  |          |  |
| PG1               | TS1_ERR                          | CSI1_MLCK  | SDC1_CLK  |          |  |
| PG2               | TS1_SYNC                         | CSI1_HSYNC | SDC1_D0   |          |  |
| PG3               | TS1_DVLD                         | CSI1_VSYNC | SDC1_D1   |          |  |
| PG4               | TS1_D0                           | CSI1_D0    | SDC1_D2   | CSI0_D8  |  |
| PG5               | TS1_D1                           | CSI1_D1    | SDC1_D3   | CSI0_D9  |  |
| PG6               | TS1_D2                           | CSI1_D2    | UART3_TX  | CSI0_D10 |  |
| PG7               | TS1_D3                           | CSI1_D3    | UART3_RX  | CSI0_D11 |  |
| PG8               | TS1_D4                           | CSI1_D4    | UART3_RTS | CSI0_D12 |  |
| PG9               | TS1_D5                           | CSI1_D5    | UART3_CTS | CSI0_D13 |  |
| PG10              | TS1_D6                           | CSI1_D6    | UART4_TX  | CSI0_D14 |  |
| PG11              | TS1_D7                           | CSI1_D7    | UART4_RX  | CSI0_D15 |  |

Port G(PG) Multiplex Function Select Table

| <b>Port H(PH)</b> | <b>Multiplex Function Select</b> |  |           |       |       |         |
|-------------------|----------------------------------|--|-----------|-------|-------|---------|
| PH0               | LCD1_D0                          |  | UART3_TX  |       | EINT0 | CSI1_D0 |
| PH1               | LCD1_D1                          |  | UART3_RX  |       | EINT1 | CSI1_D1 |
| PH2               | LCD1_D2                          |  | UART3_RTS |       | EINT2 | CSI1_D2 |
| PH3               | LCD1_D3                          |  | UART3CTS  |       | EINT3 | CSI1_D3 |
| PH4               | LCD1_D4                          |  | UART4_TX  |       | EINT4 | CSI1_D4 |
| PH5               | LCD1_D5                          |  | UART4_RX  |       | EINT5 | CSI1_D5 |
| PH6               | LCD1_D6                          |  | UART5_TX  | MS_BS | EINT6 | CSI1_D6 |

| <b>Port H(PH)</b> | <b>Multiplex Function Select</b> |        |          |           |        |            |  |
|-------------------|----------------------------------|--------|----------|-----------|--------|------------|--|
| PH7               | LCD1_D7                          |        | UART5_RX | MS_CLK    | EINT7  | CSI1_D7    |  |
| PH8               | LCD1_D8                          | ERXD3  | KP_IN0   | MS_D0     | EINT8  | CSI1_D8    |  |
| PH9               | LCD1_D9                          | ERXD2  | KP_IN1   | MS_D1     | EINT9  | CSI1_D9    |  |
| PH10              | LCD1_D10                         | ERXD1  | KP_IN2   | MS_D2     | EINT10 | CSI1_D10   |  |
| PH11              | LCD1_D11                         | ERXD0  | KP_IN3   | MS_D3     | EINT11 | CSI1_D11   |  |
| PH12              | LCD1_D12                         |        | PS2_SCK1 |           | EINT12 | CSI1_D12   |  |
| PH13              | LCD1_D13                         |        | PS2_SDA1 | SMC_RST   | EINT13 | CSI1_D13   |  |
| PH14              | LCD1_D14                         | ETXD3  | KP_IN4   | SMC_VPPEN | EINT14 | CSI1_D14   |  |
| PH15              | LCD1_D15                         | ETXD2  | KP_IN5   | SMC_VPPP  | EINT15 | CSI1_D15   |  |
| PH16              | LCD1_D16                         | ETXD1  | KP_IN6   | SMC_DET   | EINT16 | CSI1_D16   |  |
| PH17              | LCD1_D17                         | ETXD0  | KP_IN7   | SMC_VCCEN | EINT17 | CSI1_D17   |  |
| PH18              | LCD1_D18                         | ERXCK  | KP_OUT0  | SMC_SLK   | EINT18 | CSI1_D18   |  |
| PH19              | LCD1_D19                         | ERXERR | KP_OUT1  | SMC_SDA   | EINT19 | CSI1_D19   |  |
| PH20              | LCD1_D20                         | ERXDV  | CAN_TX   |           | EINT20 | CSI1_D20   |  |
| PH21              | LCD1_D21                         | EMDC   | CAN_RX   |           | EINT21 | CSI1_D21   |  |
| PH22              | LCD1_D22                         | EMDIO  | KP_OUT2  | SDC1_CMD  |        | CSI1_D22   |  |
| PH23              | LCD1_D23                         | ETXEN  | KP_OUT3  | SDC1_CLK  |        | CSI1_D23   |  |
| PH24              | LCD1_CLK                         | ETXCK  | KP_OUT4  | SDC1_D0   |        | CSI1_PCLK  |  |
| PH25              | LCD1_DE                          | ECRS   | KP_OUT5  | SDC1_D1   |        | CSI1_FIELD |  |
| PH26              | LCD1_HSY NC                      | ECOL   | KP_OUT6  | SDC1_D2   |        | CSI1_HSYNC |  |
| PH27              | LCD1_VSY NC                      | ETXERR | KP_OUT7  | SDC1_D3   |        | CSI1_VSYNC |  |

Port H(PH) Multiplex Function Select Table

| <b>Port I(PI)</b> | <b>Multiplex Function Select</b> |          |  |  |  |  |  |
|-------------------|----------------------------------|----------|--|--|--|--|--|
| PI0               |                                  | TWI3_SCK |  |  |  |  |  |
| PI1               |                                  | TWI3_SDA |  |  |  |  |  |
| PI2               |                                  | TWI4_SCK |  |  |  |  |  |
| PI3               | PWM1                             | TWI4_SDA |  |  |  |  |  |
| PI4               | SDC3_CMD                         |          |  |  |  |  |  |
| PI5               | SDC3_CLK                         |          |  |  |  |  |  |

| <b>Port I(PI)</b> | <b>Multiplex Function Select</b> |           |           |        |  |
|-------------------|----------------------------------|-----------|-----------|--------|--|
| PI6               | SDC3_D0                          |           |           |        |  |
| PI7               | SDC3_D1                          |           |           |        |  |
| PI18              | SDC3_D2                          |           |           |        |  |
| PI19              | SDC3_D3                          |           |           |        |  |
| PI10              | SPI0_CS0                         | UART5_TX  |           | EINT22 |  |
| PI11              | SPI0_CLK                         | UART5_RX  |           | EINT23 |  |
| PI12              | SPI0_MOSI                        | UART6_TX  | CLK_OUT_A | EINT24 |  |
| PI13              | SPI0_MISO                        | UART6_RX  | CLK_OUT_B | EINT25 |  |
| PI14              | SPI0_CS1                         | PS2_SCK1  | TCLKIN0   | EINT26 |  |
| PI15              | SPI1_CS1                         | PS2_SDA1  | TCLKIN1   | EINT27 |  |
| PI16              | SPI1_CS0                         | UART2_RTS |           | EINT28 |  |
| PI17              | SPI1_CLK                         | UART2_CTS |           | EINT29 |  |
| PI18              | SPI1_MOSI                        | UART2_TX  |           | EINT30 |  |
| PI19              | SPI1_MISO                        | UART2_RX  |           | EINT31 |  |
| PI20              | PS2_SCK0                         | UART7_TX  | HSCL      |        |  |
| PI21              | PS2_SDA0                         | UART7_RX  | HSDA      |        |  |

Port I(PI) Multiplex Function Select Table

### 1.19.3. Port Register List

| <b>Module Name</b> | <b>Base Address</b> |
|--------------------|---------------------|
| PIO                | 0x01C20800          |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                          |
|----------------------|---------------|---------------------------------------------|
| Pn_CFG0              | n*0x24+0x00   | Port n Configure Register 0 (n from 0 to 9) |
| Pn_CFG1              | n*0x24+0x04   | Port n Configure Register 1 (n from 0 to 9) |
| Pn_CFG2              | n*0x24+0x08   | Port n Configure Register 2 (n from 0 to 9) |
| Pn_CFG3              | n*0x24+0x0C   | Port n Configure Register 3 (n from 0 to 9) |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                              |
|----------------------|---------------|-------------------------------------------------|
| Pn_DAT               | n*0x24+0x10   | Port n Data Register (n from 0 to 9)            |
| Pn_DRV0              | n*0x24+0x14   | Port n Multi-Driving Register 0 (n from 0 to 9) |
| Pn_DRV1              | n*0x24+0x18   | Port n Multi-Driving Register 1 (n from 0 to 9) |
| Pn_PUL0              | n*0x24+0x1C   | Port n Pull Register 0 (n from 0 to 9)          |
| Pn_PUL1              | n*0x24+0x20   | Port n Pull Register 1 (n from 0 to 9)          |
| 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                 |

## 1.19.4. Port Register Description

### 1.19.4.1. PA CONFIGURE REGISTER 0

| <b>Offset: 0x00</b> |                   |                | <b>Register Name: PA_CFG0</b>                                                                                                                                                                                                    |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |                   |                | <b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                |
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                               |
| 31                  | /                 | /              | /                                                                                                                                                                                                                                |
| 30:28               | R/W               | 0              | PA7_SELECT<br>000: Input                            001: Output<br>010: ETXD0                            011: SPI3_MOSI<br>100: Reserved                        101: GTXD0<br>110: Reserved                        111: Reserved |
| 27                  | /                 | /              | Reserved                                                                                                                                                                                                                         |
| 26:24               | R/W               | 0              | PA6_SELECT<br>000: Input                            001: Output<br>010: ETXD1                            011: SPI3_CLK                                                                                                           |

| Offset: 0x00 |            |         | Register Name: PA_CFG0                                                                                                                                                                                                           |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                      |
|              |            |         | 100: Reserved                          101: GTXD1<br>110: Reserved                          111: Reserved                                                                                                                        |
| 23           | /          | /       | /                                                                                                                                                                                                                                |
| 22:20        | R/W        | 0       | PA5_SELECT<br>000: Input                            001: Output<br>010: ETXD2                            011: SPI3_CS0<br>100: Reserved                        101: GTXD2<br>110: Reserved                        111: Reserved  |
| 19           | /          | /       | /                                                                                                                                                                                                                                |
| 18:16        | R/W        | 0       | PA4_SELECT<br>000: Input                            001: Output<br>010: ETXD3                            011: SPI1_CS1<br>100: Reserved                        101: GTXD3<br>110: Reserved                        111: Reserved  |
| 15           | /          | /       | /                                                                                                                                                                                                                                |
| 14:12        | R/W        | 0       | PA3_SELECT<br>000: Input                            001: Output<br>010: ERXD0                            011: SPI1_MISO<br>100: UART2_RX                        101: GRXD0<br>110: Reserved                        111: Reserved |
| 11           | /          | /       | /                                                                                                                                                                                                                                |
| 10:8         | R/W        | 0       | PA2_SELECT<br>000: Input                            001: Output<br>010: ERXD1                            011: SPI1_MOSI<br>100: UART2_TX                        101: GRXD1<br>110: Reserved                        111: Reserved |
| 7            | /          | /       | /                                                                                                                                                                                                                                |
| 6:4          | R/W        | 0       | PA1_SELECT<br>000: Input                            001: Output<br>010: ERXD2                            011: SPI1_CLK<br>100: UART2_CTS                      101: GRXD2<br>110: Reserved                        111: Reserved   |
| 3            | /          | /       | Reserved                                                                                                                                                                                                                         |

| Offset: 0x00               |            |         | Register Name: PA_CFG0                                                    |
|----------------------------|------------|---------|---------------------------------------------------------------------------|
| Default Value: 0x0000_0000 |            |         |                                                                           |
| Bit                        | Read/Write | Default | Description                                                               |
| 2:0                        | R/W        | 0       | PA0_SELECT<br>000: Input<br>010: ERXD3<br>100: UART2_RTS<br>110: Reserved |
|                            |            |         | 001: Output<br>011: SPI1_CS0<br>101: GRXD3<br>111: Reserved               |

#### 1.19.4.2. PA CONFIGURE REGISTER 1

| Offset: 0x04               |            |         | Register Name: PA_CFG1                                                      |
|----------------------------|------------|---------|-----------------------------------------------------------------------------|
| 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: UART1_DSR<br>110: I2S1_LRCK  |
|                            |            |         | 001: Output<br>011: UART7_RX<br>101: GTXCK/ECRS<br>111: Reserved            |
| 27                         | /          | /       | /                                                                           |
| 26:24                      | R/W        | 0       | PA14_SELECT<br>000: Input<br>010: ETXCK<br>100: UART1_DTR<br>110: I2S1_BCLK |
|                            |            |         | 001: Output<br>011: UART7_TX<br>101: GNULL/ETXCK<br>111: Reserved           |
| 23                         | /          | /       | /                                                                           |
| 22:20                      | R/W        | 0       | PA13_SELECT<br>000: Input<br>010: ETXEN<br>100: UART1_CTS<br>110: Reserved  |
|                            |            |         | 001: Output<br>011: UART6_RX<br>101: GTXCTL/ETXEN<br>111: Reserved          |
| 19                         | /          | /       | /                                                                           |
| 18:16                      | R/W        | 0       | PA12_SELECT<br>000: Input                                                   |
|                            |            |         | 001: Output                                                                 |

| Offset: 0x04 |            |         | Register Name: PA_CFG1                                                                                                                                                                                 |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                            |
|              |            |         | 010:EMDIO                    011:UART6_TX<br>100:UART1_RTS                101:GMDIO<br>110: Reserved                111: Reserved                                                                      |
| 15           | /          | /       | /                                                                                                                                                                                                      |
| 14:12        | R/W        | 0       | PA11_SELECT<br>000: Input                    001: Output<br>010: EMDC                    011: Reserved<br>100: UART1_RX                101: GMDC<br>110: Reserved                111: Reserved         |
| 11           | /          | /       | /                                                                                                                                                                                                      |
| 10:8         | R/W        | 0       | PA10_SELECT<br>000: Input                    001: Output<br>010:ERXDV                    011: Reserved<br>100: UART1_TX                101: GRXCTL/ERXDV<br>110: Reserved                111: Reserved |
| 7            | /          | /       | /                                                                                                                                                                                                      |
| 6:4          | R/W        | 0       | PA9_SELECT<br>000: Input                    001: Output<br>010: ERXERR                 011: SPI3_CS1<br>100: Reserved                101: GNULL/ERXERR<br>110: I2S1_MCLK               111: Reserved   |
| 3            | /          | /       | /                                                                                                                                                                                                      |
| 2:0          | R/W        | 0       | PA8_SELECT<br>000: Input                    001: Output<br>010:ERXCK                    011: SPI3_MISO<br>100: Reserved                101: GRXCK<br>110: Reserved                111: Reserved        |

#### 1.19.4.3. PA CONFIGURE REGISTER 2

| Offset: 0x08 | Register Name: PA_CFG2     |
|--------------|----------------------------|
|              | Default Value: 0x0000_0000 |

| <b>Bit</b> | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                              |
|------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | /                 | /              | /                                                                                                                                               |
| 6:4        | R/W               | 0              | PA17_SELECT<br>000: Input<br>010: ETXERR<br>100: UART1_RING<br>110: I2S1_DI<br>001: Output<br>011: CAN_RX<br>101: GNULL/ETXERR<br>111: Reserved |
| 3          | /                 | /              | /                                                                                                                                               |
| 2:0        | R/W               | 0              | PA16_SELECT<br>000: Input<br>010: ECOL<br>100: UART1_DCD<br>110: I2S1_DO<br>001: Output<br>011: CAN_TX<br>101: GCLKIN/ECOL<br>111: Reserved     |

#### 1.19.4.4. PA CONFIGURE REGISTER 3

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

#### 1.19.4.5. PA DATA REGISTER

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: PA_DAT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                       |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
| 31:18               | /                 | /              | /                                                                                                                                                                                                                                                                                                                       |
| 17:0                | R/W               | 0              | <b>PA_DAT</b><br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 1.19.4.6. PA MULTI-DRIVING REGISTER 0

| <b>Offset: 0x14</b>   |                   |                | <b>Register Name: PA_DRV0</b><br><b>Default Value: 0x5555_5555</b>                                                                          |
|-----------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                          |
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x1            | PA_DRV<br>PA[n] Multi-Driving Select (n = 0~15)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 1.19.4.7. PA MULTI-DRIVING REGISTER 1

| <b>Offset: 0x18</b>  |                   |                | <b>Register Name: PA_DRV1</b><br><b>Default Value: 0x0000_0005</b>                                                                           |
|----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                           |
| 31:4                 | /                 | /              | /                                                                                                                                            |
| [2i+1:2i]<br>(i=0~1) | R/W               | 0x1            | PA_DRV<br>PA[n] Multi-Driving Select (n = 16~17)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 1.19.4.8. PA PULL REGISTER 0

| <b>Offset: 0x1C</b>   |                   |                | <b>Register Name: PA_PULL0</b><br><b>Default Value: 0x0000_0000</b>                                                                      |
|-----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                       |
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x0            | PA_PULL<br>PA[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down                    11: Reserved |

#### 1.19.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_PULL<br>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 |

#### 1.19.4.10. PB CONFIGURE REGISTER 0

| Offset: 0x24 |            |         | Register Name: PB_CFG0<br>Default Value: 0x0000_0000                                                                               |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                        |
| 31           | /          | /       | /                                                                                                                                  |
| 30:28        | R/W        | 0       | PB7_SELECT<br>000: Input 001: Output<br>010: I2S_LRCK 011: AC97_SYNC<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 27           | /          | /       | /                                                                                                                                  |
| 26:24        | R/W        | 0       | PB6_SELECT<br>000: Input 001: Output<br>010: I2S_BCLK 011: AC97_BCLK<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 23           | /          | /       | /                                                                                                                                  |
| 22:20        | R/W        | 0       | PB5_SELECT<br>000: Input 001: Output<br>010: I2S_MCLK 011: AC97_MCLK<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 19           | /          | /       | /                                                                                                                                  |

| Offset: 0x24 |            |         | Register Name: PB_CFG0                                                                                                                         |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                    |
| 18:16        | R/W        | 0       | PB4_SELECT<br>000: Input<br>010: IR0_RX<br>100: Reserved<br>110: Reserved<br>001: Output<br>011: Reserved<br>101: Reserved<br>111: Reserved    |
| 15           | /          | /       | /                                                                                                                                              |
| 14:12        | R/W        | 0       | PB3_SELECT<br>000: Input<br>010: IR0_TX<br>100: SPDIF_MCLK<br>110: STANBYWFI<br>001: Output<br>011: Reserved<br>101: Reserved<br>111: Reserved |
| 11           | /          | /       | /                                                                                                                                              |
| 10:8         | R/W        | 0       | PB2_SELECT<br>000: Input<br>010: PWM0<br>100: Reserved<br>110: Reserved<br>001: Output<br>011: Reserved<br>101: Reserved<br>111: Reserved      |
| 7            | /          | /       | /                                                                                                                                              |
| 6:4          | R/W        | 0       | PB1_SELECT<br>000: Input<br>010: TWI0_SDA<br>100: Reserved<br>110: Reserved<br>001: Output<br>011: Reserved<br>101: Reserved<br>111: Reserved  |
| 3            | /          | /       | /                                                                                                                                              |
| 2:0          | R/W        | 0       | PB0_SELECT<br>000: Input<br>010: TWI0_SCK<br>100: Reserved<br>110: Reserved<br>001: Output<br>011: Reserved<br>101: Reserved<br>111: Reserved  |

#### 1.19.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: SPI2_CLK<br>100: Reserved<br>110: Reserved |
| 27           | /          | /       | /                                                                            |
| 26:24        | R/W        | 0       | PB14_SELECT<br>000: Input<br>010: SPI2_CS0<br>100: Reserved<br>110: Reserved |
| 23           | /          | /       | /                                                                            |
| 22:20        | R/W        | 0       | PB13_SELECT<br>000: Input<br>010: SPI2_CS1<br>100: SPDIF_DO<br>110: Reserved |
| 19           | /          | /       | /                                                                            |
| 18:16        | R/W        | 0       | PB12_SELECT<br>000: Input<br>010: I2S_DI<br>100: SPDIF_DI<br>110: Reserved   |
| 15           | /          | /       | /                                                                            |
| 14:12        | R/W        | 0       | PB11_SELECT<br>000: Input<br>010: I2S_DO3<br>100: Reserved<br>110: Reserved  |
| 11           | /          | /       | /                                                                            |
| 10:8         | R/W        | 0       | PB10_SELECT                                                                  |

| Offset: 0x28 |            |         | Register Name: PB_CFG1                                                                                                                                                                                                           |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                      |
|              |            |         | 000: Input                            001: Output<br>010: I2S_DO2                        011: Reserved<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved               |
| 7            | /          | /       | /                                                                                                                                                                                                                                |
| 6:4          | R/W        | 0       | PB9_SELECT<br>000: Input                            001: Output<br>010: I2S_DO1                        011: Reserved<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved |
| 3            | /          | /       | /                                                                                                                                                                                                                                |
| 2:0          | R/W        | 0       | PB8_SELECT<br>000: Input                            001: Output<br>010: I2S_DO0                        011: AC97_DO<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved  |

#### 1.19.4.12. PB CONFIGURE REGISTER 2

| Offset: 0x2C |            |         | Register Name: PB_CFG2                                                                                                                                                                                                         |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                    |
| 31           | /          | /       | /                                                                                                                                                                                                                              |
| 30:28        | R/W        | 0       | PB23_SELECT<br>000: Input                            001: Output<br>010: UART0_RX                      011: IR1_RX<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved |
| 27           | /          | /       | /                                                                                                                                                                                                                              |
| 26:24        | R/W        | 0       | PB22_SELECT<br>000: Input                            001: Output<br>010: UART0_TX                      011: IR1_TX                                                                                                             |

| Offset: 0x2C |            |         | Register Name: PB_CFG2                                                                                                                                                                                                             |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                        |
|              |            |         | 100: Reserved                          101: Reserved<br>110: Reserved                          111: Reserved                                                                                                                       |
| 23           | /          | /       | Reserved                                                                                                                                                                                                                           |
| 22:20        | R/W        | 0       | PB21_SELECT<br>000: Input                            001: Output<br>010: TWI2_SDA                        011: Reserved<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved |
| 19           | /          | /       | /                                                                                                                                                                                                                                  |
| 18:16        | R/W        | 0       | PB20_SELECT<br>000: Input                            001: Output<br>010: TWI2_SCK                        011: Reserved<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved |
| 15           | /          | /       | /                                                                                                                                                                                                                                  |
| 14:12        | R/W        | 0       | PB19_SELECT<br>000: Input                            001: Output<br>010: TWI1_SDA                        011: Reserved<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved |
| 11           | /          | /       | /                                                                                                                                                                                                                                  |
| 10:8         | R/W        | 0       | PB18_SELECT<br>000: Input                            001: Output<br>010: TWI1_SCK                        011: Reserved<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved |
| 7            | /          | /       | /                                                                                                                                                                                                                                  |
| 6:4          | R/W        | 0       | PB17_SELECT<br>000: Input                            001: Output<br>010: SPI2_MISO                      011: JTAG_DIO<br>100: Reserved                        101: Reserved<br>110: Reserved                        111: Reserved  |
| 3            | /          | /       | /                                                                                                                                                                                                                                  |

| <b>Offset: 0x2C</b> |                   |                | <b>Register Name: PB_CFG2</b><br><b>Default Value: 0x0000_0000</b>            |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                            |
| 2:0                 | R/W               | 0              | PB16_SELECT<br>000: Input<br>010: SPI2_MOSI<br>100: Reserved<br>110: Reserved |
|                     |                   |                | 001: Output<br>011: JTAG_D00<br>101: Reserved<br>111: Reserved                |

#### 1.19.4.13. PB CONFIGURE REGISTER 3

| <b>Offset: 0x30</b> |                   |                | <b>Register Name: PB_CFG3</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                | /                 | /              | /                                                                  |

#### 1.19.4.14. PB DATA REGISTER

| <b>Offset: 0x34</b> |                   |                | <b>Register Name: PB_DAT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                       |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
| 31:24               | /                 | /              | /                                                                                                                                                                                                                                                                                                                       |
| 23:0                | R/W               | 0              | <b>PB_DAT</b><br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 1.19.4.15. PB MULTI-DRIVING REGISTER 0

|                     |                                                                    |
|---------------------|--------------------------------------------------------------------|
| <b>Offset: 0x38</b> | <b>Register Name: PB_DRV0</b><br><b>Default Value: 0x5555_5555</b> |
|---------------------|--------------------------------------------------------------------|

| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                    |
|-----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------|
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x1            | PB_DRV<br>PB[n] Multi-Driving Select (n = 0~15)<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 1.19.4.16. PB MULTI-DRIVING REGISTER 1

| <b>Offset: 0x3C</b>  |                   |                | <b>Register Name: PB_DRV1</b><br><b>Default Value: 0x0000_5555</b>                                     |
|----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                     |
| 31:16                | /                 | /              | /                                                                                                      |
| [2i+1:2i]<br>(i=0~7) | R/W               | 0x1            | PB_DRV<br>PB[n] Multi-Driving Select (n = 16~23)<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 1.19.4.17. PB PULL REGISTER 0

| <b>Offset: 0x40</b>   |                   |                | <b>Register Name: PB_PULL0</b><br><b>Default Value: 0x0000_0000</b>                                                   |
|-----------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                    |
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x0            | PB_PULL<br>PB[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |

#### 1.19.4.18. PB PULL REGISTER 1

| <b>Offset: 0x44</b> |                   |                | <b>Register Name: PB_PULL1</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |

| Offset: 0x44         |            |         | Register Name: PB_PULL1<br>Default Value: 0x0000_0000                                                                         |
|----------------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                                                                                   |
| 31:16                | /          | /       | /                                                                                                                             |
| [2i+1:2i]<br>(i=0~7) | R/W        | 0x0     | PB_PULL<br>PB[n] Pull-up/down Select (n = 16~23)<br>00: Pull-up/down disable 01: Pull-up enable<br>10: Pull-down 11: Reserved |

#### 1.19.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: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 27           | /          | /       | /                                                                                                                             |
| 26:24        | R/W        | 0       | PC6_SELECT<br>000: Input 001: Output<br>010: NRB0 011: SDC2_CMD<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 23           | /          | /       | /                                                                                                                             |
| 22:20        | R/W        | 0       | PC5_SELECT<br>000: Input 001: Output<br>010: NRE# 011: Reserved<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 19           | /          | /       | /                                                                                                                             |
| 18:16        | R/W        | 0       | PC4_SELECT<br>000: Input 001: Output                                                                                          |

| Offset: 0x48 |            |         | Register Name: PC_CFG0                                                                                                                                                                                                                                              |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                         |
|              |            |         | 010: NCE0                                  011: Reserved<br>100: Reserved                                101: Reserved<br>110: Reserved                                111: Reserved                                                                                |
| 15           | /          | /       | /                                                                                                                                                                                                                                                                   |
| 14:12        | R/W        | 0       | PC3_SELECT<br>000: Input                                    001: Output<br>010: NCE1                                     011: Reserved<br>100: Reserved                                101: Reserved<br>110: Reserved                                111: Reserved  |
| 11           | /          | /       | /                                                                                                                                                                                                                                                                   |
| 10:8         | R/W        | 0       | PC2_SELECT<br>000: Input                                    001: Output<br>010: NCLE                                    011: SPI0_CLK<br>100: Reserved                                101: Reserved<br>110: Reserved                                111: Reserved   |
| 7            | /          | /       | /                                                                                                                                                                                                                                                                   |
| 6:4          | R/W        | 0       | PC1_SELECT<br>000: Input                                    001: Output<br>010: NALE                                    011: SPI0_MISO<br>100: Reserved                                101: Reserved<br>110: Reserved                                111: Reserved  |
| 3            | /          | /       | /                                                                                                                                                                                                                                                                   |
| 2:0          | R/W        | 0       | PC0_SELECT<br>000: Input                                    001: Output<br>010: NWE                                      011: SPI0_MOSI<br>100: Reserved                                101: Reserved<br>110: Reserved                                111: Reserved |

#### 1.19.4.20. PC CONFIGURE REGISTER 1

| Offset: 0x4C | Register Name: PC_CFG1     |
|--------------|----------------------------|
|              | Default Value: 0x0000_0000 |

| <b>Bit</b> | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                       |
|------------|-------------------|----------------|--------------------------------------------------------------------------|
| 31         | /                 | /              | /                                                                        |
| 30:28      | R/W               | 0              | PC15_SELECT<br>000: Input<br>010: NDQ7<br>100: Reserved<br>110: Reserved |
| 27         | /                 | /              | /                                                                        |
| 26:24      | R/W               | 0              | PC14_SELECT<br>000: Input<br>010: NDQ6<br>100: Reserved<br>110: Reserved |
| 23         | /                 | /              | /                                                                        |
| 22:20      | R/W               | 0              | PC13_SELECT<br>000: Input<br>010: NDQ5<br>100: Reserved<br>110: Reserved |
| 19         | /                 | /              | /                                                                        |
| 18:16      | R/W               | 0              | PC12_SELECT<br>000: Input<br>010: NDQ4<br>100: Reserved<br>110: Reserved |
| 15         | /                 | /              | /                                                                        |
| 14:12      | R/W               | 0              | PC11_SELECT<br>000: Input<br>010: NDQ3<br>100: Reserved<br>110: Reserved |
| 11         | /                 | /              | /                                                                        |
| 10:8       | R/W               | 0              | PC10_SELECT<br>000: Input<br>010: NDQ2<br>100: Reserved                  |

| <b>Offset: 0x4C</b> |                   |                | <b>Register Name: PC_CFG1</b>                                                                                                                    |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                               |
|                     |                   |                | 110: Reserved      111: Reserved                                                                                                                 |
| 7                   | /                 | /              | /                                                                                                                                                |
| 6:4                 | R/W               | 0              | PC9_SELECT<br>000: Input      001: Output<br>010: NDQ1      011: SDC2_D1<br>100: Reserved      101: Reserved<br>110: Reserved      111: Reserved |
| 3                   | /                 | /              | /                                                                                                                                                |
| 2:0                 | R/W               | 0              | PC8_SELECT<br>000: Input      001: Output<br>010: NDQ0      011: SDC2_D0<br>100: Reserved      101: Reserved<br>110: Reserved      111: Reserved |

#### 1.19.4.21. PC CONFIGURE REGISTER 2

| <b>Offset: 0x50</b> |                   |                | <b>Register Name: PC_CFG2</b>                                                                                                                          |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                     |
| 31                  | /                 | /              | /                                                                                                                                                      |
| 30:28               | R/W               | 0              | PC23_SELECT<br>000: Input      001: Output<br>010: Reserved      011: SPI0_CS0<br>100: Reserved      101: Reserved<br>110: Reserved      111: Reserved |
| 17                  | /                 | /              | /                                                                                                                                                      |
| 26:24               | R/W               | 0              | PC22_SELECT<br>000: Input      001: Output<br>010: NCE7      011: SPI2_MISO<br>100: Reserved      101: Reserved<br>110: Reserved      111: Reserved    |
| 23                  | /                 | /              | /                                                                                                                                                      |

| Offset: 0x50 |            |         | Register Name: PC_CFG2                                                   |
|--------------|------------|---------|--------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                              |
| 22:20        | R/W        | 0       | PC21_SELECT<br>000: Input<br>010: NCE6<br>100: Reserved<br>110: Reserved |
| 19           | /          | /       | /                                                                        |
| 18:16        | R/W        | 0       | PC20_SELECT<br>000: Input<br>010: NCE5<br>100: Reserved<br>110: Reserved |
| 15           | /          | /       | /                                                                        |
| 14:12        | R/W        | 0       | PC19_SELECT<br>000: Input<br>010: NCE4<br>100: Reserved<br>110: Reserved |
| 11           | /          | /       | /                                                                        |
| 10:8         | R/W        | 0       | PC18_SELECT<br>000: Input<br>010: NCE3<br>100: Reserved<br>110: Reserved |
| 7            | /          | /       | /                                                                        |
| 6:4          | R/W        | 0       | PC17_SELECT<br>000: Input<br>010: NCE2<br>100: Reserved<br>110: Reserved |
| 3            | /          | /       | /                                                                        |
| 2:0          | R/W        | 0       | PC16_SELECT<br>000: Input<br>010: NWP                                    |

| <b>Offset: 0x50</b> |                   |                | <b>Register Name: PC_CFG2</b><br><b>Default Value: 0x0000_0000</b>                                             |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                             |
|                     |                   |                | 100: Reserved                          101: Reserved<br>110: Reserved                            111: Reserved |
|                     |                   |                |                                                                                                                |

#### 1.19.4.22. PC CONFIGURE REGISTER 3

| <b>Offset: 0x54</b> |                   |                | <b>Register Name: PC_CFG3</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                               |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                               |
| 31:3                | /                 | /              | /                                                                                                                                                                                                                                                |
| 2:0                 | R/W               | 0              | PC24_SELECT<br>000: Input                              001: Output<br>010: NDQS                                011: Reserved<br>100: Reserved                            101: Reserved<br>110: Reserved                            111: Reserved |

#### 1.19.4.23. PC DATA REGISTER

| <b>Offset: 0x58</b> |                   |                | <b>Register Name: PC_DAT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
| 31:24               | /                 | /              | /                                                                                                                                                                                                                                                                                                                |
| 23:0                | R/W               | 0              | PC_DAT<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 1.19.4.24. PC MULTI-DRIVING REGISTER 0

| <b>Offset: 0x5C</b>   |                   |                | <b>Register Name: PC_DRV0</b><br><b>Default Value: 0x5555_5555</b>                                                                                          |
|-----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                          |
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x1            | PC_DRV<br>PC[n] Multi-Driving_SELECT (n = 0~15)<br>00: Level 0                            01: Level 1<br>10: Level 2                            11: Level 3 |

#### 1.19.4.25. PC MULTI-DRIVING REGISTER 1

| <b>Offset: 0x60</b>  |                   |                | <b>Register Name: PC_DRV1</b><br><b>Default Value: 0x0001_5555</b>                                                                                           |
|----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                           |
| 31:18                | /                 | /              | /                                                                                                                                                            |
| [2i+1:2i]<br>(i=0~8) | R/W               | 0x1            | PC_DRV<br>PC[n] Multi-Driving Select (n = 16~24)<br>00: Level 0                            01: Level 1<br>10: Level 2                            11: Level 3 |

#### 1.19.4.26. PC PULL REGISTER 0

| <b>Offset: 0x64</b>   |                   |                | <b>Register Name: PC_PULL0</b><br><b>Default Value: 0x0000_5140</b>                                                                              |
|-----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                               |
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x0000_5140    | PC_PULL<br>PC[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down                            11: Reserved |

#### 1.19.4.27. PC PULL REGISTER 1

| Offset: 0x68         |            |             | Register Name: PC_PULL1<br>Default Value: 0x0000_4016                                                                  |
|----------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default     | Description                                                                                                            |
| 31:18                | /          | /           | /                                                                                                                      |
| [2i+1:2i]<br>(i=0~8) | R/W        | 0x0000_4016 | PC_PULL<br>PC[n] Pull-up/down Select (n = 16~24)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |

#### 1.19.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 001: Output<br>010: LCD0_D7 011: LVDS0_VNC<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 27           | /          | /       | Reserved                                                                                                                          |
| 26:24        | R/W        | 0       | PD6_SELECT<br>000: Input 001: Output<br>010: LCD0_D6 011: LVDS0_VPC<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 23           | /          | /       | /                                                                                                                                 |
| 22:20        | R/W        | 0       | PD5_SELECT<br>000: Input 001: Output<br>010: LCD0_D5 011: LVDS0_VN2<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 19           | /          | /       | /                                                                                                                                 |

| Offset: 0x6C |            |         | Register Name: PD_CFG0                                                     |
|--------------|------------|---------|----------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                |
| 18:16        | R/W        | 0       | PD4_SELECT<br>000: Input<br>010: LCD0_D4<br>100: Reserved<br>110: Reserved |
| 15           | /          | /       | /                                                                          |
| 14:12        | R/W        | 0       | PD3_SELECT<br>000: Input<br>010: LCD0_D3<br>100: Reserved<br>110: Reserved |
| 11           | /          | /       | /                                                                          |
| 10:8         | R/W        | 0       | PD2_SELECT<br>000: Input<br>010: LCD0_D2<br>100: Reserved<br>110: Reserved |
| 7            | /          | /       | /                                                                          |
| 6:4          | R/W        | 0       | PD1_SELECT<br>000: Input<br>010: LCD0_D1<br>100: Reserved<br>110: Reserved |
| 3            | /          | /       | /                                                                          |
| 2:0          | R/W        | 0       | PD0_SELECT<br>000: Input<br>010: LCD0_D0<br>100: Reserved<br>110: Reserved |

#### 1.19.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<br>010: LCD0_D15<br>100: Reserved<br>110: Reserved |
| 27           | /          | /       | /                                                                            |
| 26:24        | R/W        | 0       | PD14_SELECT<br>000: Input<br>010: LCD0_D14<br>100: Reserved<br>110: Reserved |
| 23           | /          | /       | /                                                                            |
| 22:20        | R/W        | 0       | PD13_SELECT<br>000: Input<br>010: LCD0_D13<br>100: Reserved<br>110: Reserved |
| 19           | /          | /       | /                                                                            |
| 18:16        | R/W        | 0       | PD12_SELECT<br>000: Input<br>010: LCD0_D12<br>100: Reserved<br>110: Reserved |
| 15           | /          | /       | /                                                                            |
| 14:12        | R/W        | 0       | PD11_SELECT<br>000: Input<br>010: LCD0_D11<br>100: Reserved<br>110: Reserved |
| 11           | /          | /       | /                                                                            |
| 10:8         | R/W        | 0       | PD10_SELECT                                                                  |

| Offset: 0x70 |            |         | Register Name: PD_CFG1                                                            |
|--------------|------------|---------|-----------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                       |
|              |            |         | 000: Input<br>010: LCD0_D10<br>100: Reserved<br>110: Reserved                     |
| 7            | /          | /       | /                                                                                 |
| 6:4          | R/W        | 0       | <b>PD9_SELECT</b><br>000: Input<br>010: LCD0_D9<br>100: Reserved<br>110: Reserved |
| 3            | /          | /       | /                                                                                 |
| 2:0          | R/W        | 0       | <b>PD8_SELECT</b><br>000: Input<br>010: LCD0_D8<br>100: Reserved<br>110: Reserved |

#### 1.19.4.30. PD CONFIGURE REGISTER 2

| Offset: 0x74 |            |         | Register Name: PD_CFG2                                                              |
|--------------|------------|---------|-------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                         |
| 31           | /          | /       | /                                                                                   |
| 30:28        | R/W        | 0       | <b>PD23_SELECT</b><br>000: Input<br>010: LCD0_D23<br>100: Reserved<br>110: Reserved |
| 27           | /          | /       | /                                                                                   |
| 26:24        | R/W        | 0       | <b>PD22_SELECT</b><br>000: Input<br>010: LCD0_D22                                   |
|              |            |         | 001: Output<br>011: SMC_DET<br>101: Reserved<br>111: Reserved                       |
|              |            |         | 001: Output<br>011: SMC_VPPPP                                                       |

| Offset: 0x74 |            |         | Register Name: PD_CFG2                                                                                                                                                                              |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                         |
|              |            |         | 100: Reserved                    101: Reserved<br>110: Reserved                    111: Reserved                                                                                                    |
| 23           | /          | /       | /                                                                                                                                                                                                   |
| 22:20        | R/W        | 0       | PD21_SELECT<br>000: Input                    001: Output<br>010: LCD0_D21                011: SMC_VPPEN<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |
| 19           | /          | /       | /                                                                                                                                                                                                   |
| 18:16        | R/W        | 0       | PD20_SELECT<br>000: Input                    001: Output<br>010: LCD0_D20                011: CSI1_MCLK<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |
| 15           | /          | /       | /                                                                                                                                                                                                   |
| 14:12        | R/W        | 0       | PD19_SELECT<br>000: Input                    001: Output<br>010: LCD0_D19                011: LVDS1_VN3<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |
| 11           | /          | /       | /                                                                                                                                                                                                   |
| 10:8         | R/W        | 0       | PD18_SELECT<br>000: Input                    001: Output<br>010: LCD0_D18                011: LVDS1_VP3<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |
| 7            | /          | /       | /                                                                                                                                                                                                   |
| 6:4          | R/W        | 0       | PD17_SELECT<br>000: Input                    001: Output<br>010: LCD0_D17                011: LVDS1_VNC<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |
| 3            | /          | /       | /                                                                                                                                                                                                   |

| Offset: 0x74               |            |         | Register Name: PD_CFG2                                                       |
|----------------------------|------------|---------|------------------------------------------------------------------------------|
| Default Value: 0x0000_0000 |            |         |                                                                              |
| Bit                        | Read/Write | Default | Description                                                                  |
| 2:0                        | R/W        | 0       | PD16_SELECT<br>000: Input<br>010: LCD0_D16<br>100: Reserved<br>110: Reserved |
|                            |            |         | 001: Output<br>011: LVDS1_VPC<br>101: Reserved<br>111: Reserved              |

#### 1.19.4.31. PD CONFIGURE REGISTER 3

| Offset: 0x78               |            |         | Register Name: PD_CFG3                                                         |
|----------------------------|------------|---------|--------------------------------------------------------------------------------|
| Default Value: 0x0000_0000 |            |         |                                                                                |
| Bit                        | Read/Write | Default | Description                                                                    |
| 31:15                      | /          | /       | /                                                                              |
| 14:12                      | R/W        | 0       | PD27_SELECT<br>000: Input<br>010: LCD0_VSYNC<br>100: Reserved<br>110: Reserved |
|                            |            |         | 001: Output<br>011: SMC_SDA<br>101: Reserved<br>111: Reserved                  |
| 11                         | /          | /       | Reserved                                                                       |
| 10:8                       | R/W        | 0       | PD26_SELECT<br>000: Input<br>010: LCD0_HSYNC<br>100: Reserved<br>110: Reserved |
|                            |            |         | 001: Output<br>011: SMC_SLK<br>101: Reserved<br>111: Reserved                  |
| 7                          | /          | /       | /                                                                              |
| 6:4                        | R/W        | 0       | PD25_SELECT<br>000: Input<br>010: LCD0_DE<br>100: Reserved<br>110: Reserved    |
|                            |            |         | 001: Output<br>011: SMC_RST<br>101: Reserved<br>111: Reserved                  |
| 3                          | /          | /       | /                                                                              |
| 2:0                        | R/W        | 0       | PD24_SELECT<br>000: Input<br>001: Output                                       |

|                                   |                   |                |                                                                                                                                               |
|-----------------------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Offset: 0x78</b>               |                   |                | <b>Register Name: PD_CFG3</b>                                                                                                                 |
| <b>Default Value: 0x0000_0000</b> |                   |                |                                                                                                                                               |
| <b>Bit</b>                        | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                            |
|                                   |                   |                | 010: LCD0_CLK                  011: SMC_VCCEN<br>100: Reserved                  101: Reserved<br>110: Reserved                  111: Reserved |
|                                   |                   |                |                                                                                                                                               |

#### 1.19.4.32. PD DATA REGISTER

|                                   |                   |                |                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Offset: 0x7C</b>               |                   |                | <b>Register Name: PD_DAT</b>                                                                                                                                                                                                                                                                                     |
| <b>Default Value: 0x0000_0000</b> |                   |                |                                                                                                                                                                                                                                                                                                                  |
| <b>Bit</b>                        | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
| 31:28                             | /                 | /              | /                                                                                                                                                                                                                                                                                                                |
| 27:0                              | R/W               | 0              | PD_DAT<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 1.19.4.33. PD MULTI-DRIVING REGISTER 0

|                                   |                   |                |                                                                                                                                         |
|-----------------------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| <b>Offset: 0x80</b>               |                   |                | <b>Register Name: PD_DRV0</b>                                                                                                           |
| <b>Default Value: 0x5555_5555</b> |                   |                |                                                                                                                                         |
| <b>Bit</b>                        | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                      |
| [2i+1:2i]<br>(i=0~15)             | R/W               | 0x1            | PD_DRV<br>PD[n] Multi-Driving Select (n = 0~15)<br>00: Level 0                  01: Level 1<br>10: Level 2                  11: Level 3 |

#### 1.19.4.34. PD MULTI-DRIVING REGISTER 1

|                     |                                   |
|---------------------|-----------------------------------|
| <b>Offset: 0x84</b> | <b>Register Name: PD_DRV1</b>     |
|                     | <b>Default Value: 0x0055_5555</b> |

| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                           |
|-----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24                 | /                 | /              | /                                                                                                                                                            |
| [2i+1:2i]<br>(i=0~11) | R/W               | 0x1            | PD_DRV<br>PD[n] Multi-Driving Select (n = 16~27)<br>00: Level 0                            01: Level 1<br>10: Level 2                            11: Level 3 |

#### 1.19.4.35. PD PULL REGISTER 0

| <b>Offset: 0x88</b>   |                   |                | <b>Register Name: PD_PULL0</b><br><b>Default Value: 0x0000_0000</b>                                                                                     |
|-----------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                      |
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x0            | PD_PULL<br>PD[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable            01: Pull-up<br>10: Pull-down                        11: Reserved |

#### 1.19.4.36. PD PULL REGISTER 1

| <b>Offset: 0x8C</b>   |                   |                | <b>Register Name: PD_PULL1</b><br><b>Default Value: 0x0000_0000</b>                                                                                     |
|-----------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                      |
| 31:24                 | /                 | /              | /                                                                                                                                                       |
| [2i+1:2i]<br>(i=0~11) | R/W               | 0x0            | PD_PULL<br>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 |

#### 1.19.4.37. PE CONFIGURE REGISTER 0

|                     |                                                                    |
|---------------------|--------------------------------------------------------------------|
| <b>Offset: 0x90</b> | <b>Register Name: PE_CFG0</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|--------------------------------------------------------------------|

| <b>Bit</b> | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                          |                                                                  |
|------------|-------------------|----------------|-----------------------------------------------------------------------------|------------------------------------------------------------------|
| 31         | /                 | /              | /                                                                           |                                                                  |
| 30:28      | R/W               | 0              | PE7_SELECT<br>000: Input<br>010: TS0_D3<br>100: Reserved<br>110: Reserved   | 001: Output<br>011: CSI0_D3<br>101: Reserved<br>111: Reserved    |
| 27         | /                 | /              | /                                                                           |                                                                  |
| 26:24      | R/W               | 0              | PE6_SELECT<br>000: Input<br>010: TS0_D2<br>100: Reserved<br>110: Reserved   | 001: Output<br>011: CSI0_D2<br>101: Reserved<br>111: Reserved    |
| 23         | /                 | /              | /                                                                           |                                                                  |
| 22:20      | R/W               | 0              | PE5_SELECT<br>000: Input<br>010: TS0_D1<br>100: SMC_VPPEN<br>110: Reserved  | 001: Output<br>011: CSI0_D1<br>101: Reserved<br>111: Reserved    |
| 19         | /                 | /              | /                                                                           |                                                                  |
| 18:16      | R/W               | 0              | PE4_SELECT<br>000: Input<br>010: TS0_D0<br>100: Reserved<br>110: Reserved   | 001: Output<br>011: CSI0_D0<br>101: Reserved<br>111: Reserved    |
| 15         | /                 | /              | /                                                                           |                                                                  |
| 14:12      | R/W               | 0              | PE3_SELECT<br>000: Input<br>010: TS0_DVLD<br>100: Reserved<br>110: Reserved | 001: Output<br>011: CSI0_VSYNC<br>101: Reserved<br>111: Reserved |
| 11         | /                 | /              | /                                                                           |                                                                  |
| 10:8       | R/W               | 0              | PE2_SELECT<br>000: Input<br>010: TS0_SYNC<br>100: Reserved                  | 001: Output<br>011: CSI0_HSYNC<br>101: Reserved                  |

| Offset: 0x90 |            |         | Register Name: PE_CFG0                                                                                                                               |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                          |
|              |            |         | 110: Reserved      111: Reserved                                                                                                                     |
| 7            | /          | /       | /                                                                                                                                                    |
| 6:4          | R/W        | 0       | PE1_SELECT<br>000: Input      001: Output<br>010: TS0_ERR      011: CSI0_CK<br>100: Reserved      101: Reserved<br>110: Reserved      111: Reserved  |
| 3            | /          | /       | /                                                                                                                                                    |
| 2:0          | R/W        | 0       | PE0_SELECT<br>000: Input      001: Output<br>010: TS0_CLK      011: CSI0_PCK<br>100: Reserved      101: Reserved<br>110: Reserved      111: Reserved |

#### 1.19.4.38. PE CONFIGURE REGISTER 1

| Offset: 0x94 |            |         | Register Name: PE_CFG1                                                                                                                              |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                         |
| 31:15        | /          | /       | /                                                                                                                                                   |
| 14:12        | R/W        | 0       | PE11_SELECT<br>000: Input      001: Output<br>010: TS0_D7      011: CSI0_D7<br>100: Reserved      101: Reserved<br>110: Reserved      111: Reserved |
| 11           | /          | /       | /                                                                                                                                                   |
| 10:8         | R/W        | 0       | PE10_SELECT<br>000: Input      001: Output<br>010: TS0_D6      011: CSI0_D6<br>100: Reserved      101: Reserved<br>110: Reserved      111: Reserved |
| 7            | /          | /       | /                                                                                                                                                   |

| <b>Offset: 0x94</b> |                   |                | <b>Register Name: PE_CFG1</b><br><b>Default Value: 0x0000_0000</b>        |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                        |
| 6:4                 | R/W               | 0              | PE9_SELECT<br>000: Input<br>010: TS0_D5<br>100: Reserved<br>110: Reserved |
| 3                   | /                 | /              | /                                                                         |
| 2:0                 | R/W               | 0              | PE8_SELECT<br>000: Input<br>010: TS0_D4<br>100: Reserved<br>110: Reserved |

#### 1.19.4.39. PE CONFIGURE REGISTER 2

| <b>Offset: 0x98</b> |                   |                | <b>Register Name: PE_CFG2</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                | /                 | /              | /                                                                  |

#### 1.19.4.40. PE CONFIGURE REGISTER 3

| <b>Offset: 0x98</b> |                   |                | <b>Register Name: PE_CFG2</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                | /                 | /              | /                                                                  |

#### 1.19.4.41. PE DATA REGISTER

|                     |                                                                   |
|---------------------|-------------------------------------------------------------------|
| <b>Offset: 0xA0</b> | <b>Register Name: PE_DAT</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------------------------------------------------------|

| <b>Bit</b> | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                 |
|------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | /                 | /              | /                                                                                                                                                                                                                                                                                                                                  |
| 11:0       | R/W               | 0              | <p><b>PE_DAT</b></p> <p>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.</p> |

#### 1.19.4.42. PE MULTI-DRIVING REGISTER 0

| <b>Offset: 0xA4</b>   |                   |                | <b>Register Name: PE_DRV0</b><br><b>Default Value: 0x0055_5555</b>                                                                                                                           |             |             |             |             |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|-------------|-------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                           |             |             |             |             |
| 31:24                 | /                 | /              | /                                                                                                                                                                                            |             |             |             |             |
| [2i+1:2i]<br>(i=0~11) | R/W               | 0x1            | <p><b>PE_DRV</b></p> <p>PE[n] Multi-Driving Select (n = 0~15)</p> <table> <tr> <td>00: Level 0</td> <td>01: Level 1</td> </tr> <tr> <td>10: Level 2</td> <td>11: Level 3</td> </tr> </table> | 00: Level 0 | 01: Level 1 | 10: Level 2 | 11: Level 3 |
| 00: Level 0           | 01: Level 1       |                |                                                                                                                                                                                              |             |             |             |             |
| 10: Level 2           | 11: Level 3       |                |                                                                                                                                                                                              |             |             |             |             |

#### 1.19.4.43. PE MULTI-DRIVING REGISTER 1

| <b>Offset: 0xA8</b> |                   |                | <b>Register Name: PE_DRV1</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                | /                 | /              | /                                                                  |

#### 1.19.4.44. PE PULL REGISTER 0

| <b>Offset: 0xAC</b> |                   |                | <b>Register Name: PE_PULL0</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:24               | /                 | /              | /                                                                   |

| <b>Offset: 0xAC</b>   |                   |                | <b>Register Name: PE_PULL0</b><br><b>Default Value: 0x0000_0000</b>                                                   |
|-----------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                    |
| [2i+1:2i]<br>(i=0~11) | R/W               | 0x0            | PE_PULL<br>PE[n] Pull-up/down Select (n = 0~11)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |

#### 1.19.4.45. PE PULL REGISTER 1

| <b>Offset: 0xB0</b> |                   |                | <b>Register Name: PE_PULL1</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:0                | /                 | /              | /                                                                   |

#### 1.19.4.46. PF CONFIGURE REGISTER 0

| <b>Offset: 0xB4</b> |                   |                | <b>Register Name: PF_CFG0</b><br><b>Default Value: 0x0040_4044</b>                                                               |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                               |
| 31:23               | /                 | /              | /                                                                                                                                |
| 22:20               | R/W               | 0x4            | PF5_SELECT<br>000: Input 001: Output<br>010: SDC0_D2 011: Reserved<br>100: JTAG_CK1 101: Reserved<br>110: Reserved 111: Reserved |
| 19                  | /                 | /              | /                                                                                                                                |
| 18:16               | R/W               | 0              | PF4_SELECT<br>000: Input 001: Output<br>010: SDC0_D3 011: Reserved<br>100: UART0_RX 101: Reserved<br>110: Reserved 111: Reserved |
| 15                  | /                 | /              | /                                                                                                                                |
| 14:12               | R/W               | 0x4            | PF3_SELECT                                                                                                                       |

| Offset: 0xB4 |            |         | Register Name: PF_CFG0                                                             |
|--------------|------------|---------|------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                        |
|              |            |         | 000: Input<br>010: SDC0_CMD<br>100: JTAG_DO1<br>110: Reserved                      |
| 11           | /          | /       | /                                                                                  |
| 10:8         | R/W        | 0       | <b>PF2_SELECT</b><br>000: Input<br>010: SDC0_CLK<br>100: UART0_TX<br>110: Reserved |
| 7            | /          | /       | /                                                                                  |
| 6:4          | R/W        | 0x4     | <b>PF1_SELECT</b><br>000: Input<br>010: SDC0_D0<br>100: JTAG_DI1<br>110: Reserved  |
| 3            | /          | /       | /                                                                                  |
| 2:0          | R/W        | 0x4     | <b>PF0_SELECT</b><br>000: Input<br>010: SDC0_D1<br>100: JTAG_MS1<br>110: Reserved  |

#### 1.19.4.47. PF CONFIGURE REGISTER 1

| Offset: 0xB8 |            |         | Register Name: PF_CFG1 |
|--------------|------------|---------|------------------------|
| Bit          | Read/Write | Default | Description            |
| 31:0         | /          | /       | /                      |

#### 1.19.4.48. PF CONFIGURE REGISTER 2

| <b>Offset: 0xBC</b> |                   |                | <b>Register Name: PF_CFG2</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                | /                 | /              | /                                                                  |

#### 1.19.4.49. PF CONFIGURE REGISTER 3

| <b>Offset: 0xC0</b> |                   |                | <b>Register Name: PF_CFG3</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                | /                 | /              | /                                                                  |

#### 1.19.4.50. PF DATA REGISTER

| <b>Offset: 0xC4</b> |                   |                | <b>Register Name: PF_DAT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                       |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
| 31:6                | /                 | /              | /                                                                                                                                                                                                                                                                                                                       |
| 5:0                 | R/W               | 0              | <b>PF_DAT</b><br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 1.19.4.51. PF MULTI-DRIVING REGISTER 0

| <b>Offset: 0xC8</b> |                   |                | <b>Register Name: PF_DRV0</b><br><b>Default Value: 0x0000_0555</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:12               | /                 | /              | /                                                                  |

| <b>Offset: 0xC8</b>  |                   |                | <b>Register Name: PF_DRV0</b><br><b>Default Value: 0x0000_0555</b>                                                                         |
|----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                         |
| [2i+1:2i]<br>(i=0~5) | R/W               | 0x1            | PF_DRV<br>PF[n] Multi-Driving Select (n = 0~5)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 1.19.4.52. PF MULTI-DRIVING REGISTER 1

| <b>Offset: 0xCC</b> |                   |                | <b>Register Name: PF_DRV1</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:24               | /                 | /              | /                                                                  |

#### 1.19.4.53. PF PULL REGISTER 0

| <b>Offset: 0xD0</b>  |                   |                | <b>Register Name: PF_PULL0</b><br><b>Default Value: 0x0000_0000</b>                                                                     |
|----------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                      |
| 31:12                | /                 | /              | /                                                                                                                                       |
| [2i+1:2i]<br>(i=0~5) | R/W               | 0x0            | PF_PULL<br>PF[n] Pull-up/down Select (n = 0~5)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down                    11: Reserved |

#### 1.19.4.54. PF PULL REGISTER 1

| <b>Offset: 0xD4</b> |                   |                | <b>Register Name: PF_PULL1</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:0                | /                 | /              | /                                                                   |

#### 1.19.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: TS1_D3<br>100: UART3_RX<br>110: Reserved |
| 27           | /          | /       | /                                                                         |
| 26:24        | R/W        | 0       | PG6_SELECT<br>000: Input<br>010: TS1_D2<br>100: UART3_TX<br>110: Reserved |
| 23           | /          | /       | /                                                                         |
| 22:20        | R/W        | 0       | PG5_SELECT<br>000: Input<br>010: TS1_D1<br>100: SDC1_D3<br>110: Reserved  |
| 19           | /          | /       | /                                                                         |
| 18:16        | R/W        | 0       | PG4_SELECT<br>000: Input<br>010: TS1_D0<br>100: SDC1_D2<br>110: Reserved  |
| 15           | /          | /       | /                                                                         |
| 14:12        | R/W        | 0       | PG3_SELECT<br>000: Input<br>010: TS1_DVLD<br>100: SDC1_D1                 |

| <b>Offset: 0xD8</b> |                   |                | <b>Register Name: PG_CFG0</b>                                                                                                                          |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                     |
|                     |                   |                | 110: Reserved      111: Reserved                                                                                                                       |
| 11                  | /                 | /              | /                                                                                                                                                      |
| 10:8                | R/W               | 0              | PG2_SELECT<br>000: Input      001: Output<br>010: TS1_SYNC      011: CSI1_HSYNC<br>100: SDC1_D0      101: Reserved<br>110: Reserved      111: Reserved |
| 7                   | /                 | /              | /                                                                                                                                                      |
| 6:4                 | R/W               | 0              | PG1_SELECT<br>000: Input      001: Output<br>010: TS1_ERR      011: CSI1_CK<br>100: SDC1_CLK      101: Reserved<br>110: Reserved      111: Reserved    |
| 3                   | /                 | /              | /                                                                                                                                                      |
| 2:0                 | R/W               | 0              | PG0_SELECT<br>000: Input      001: Output<br>010: TS1_CLK      011: CSI1_PCK<br>100: SDC1_CMD      101: Reserved<br>110: Reserved      111: Reserved   |

#### 1.19.4.56. PG CONFIGURE REGISTER 1

| <b>Offset: 0xDC</b> |                   |                | <b>Register Name: PG_CFG1</b>                                                                                                                       |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                  |
| 31:15               | /                 | /              | /                                                                                                                                                   |
| 14:12               | R/W               | 0              | PG11_SELECT<br>000: Input      001: Output<br>010: TS1_D7      011: CSI1_D7<br>100: UART4_RX      101: CSI0_D15<br>110: Reserved      111: Reserved |
| 11                  | /                 | /              | /                                                                                                                                                   |

| <b>Offset: 0xDC</b> |                   |                | <b>Register Name: PG_CFG1</b><br><b>Default Value: 0x0000_0000</b>         |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                         |
| 10:8                | R/W               | 0              | PG10_SELECT<br>000: Input<br>010: TS1_D6<br>100: UART4_TX<br>110: Reserved |
| 7                   | /                 | /              | /                                                                          |
| 6:4                 | R/W               | 0              | PG9_SELECT<br>000: Input<br>010: TS1_D5<br>100: UART3_CTS<br>110: Reserved |
| 3                   | /                 | /              | /                                                                          |
| 2:0                 | R/W               | 0              | PG8_SELECT<br>000: Input<br>010: TS1_D4<br>100: UART3_RTS<br>110: Reserved |

#### 1.19.4.57. PG CONFIGURE REGISTER 2

| <b>Offset: 0xE0</b> |                   |                | <b>Register Name: PG_CFG2</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                | /                 | /              | /                                                                  |

#### 1.19.4.58. PG CONFIGURE REGISTER 3

| <b>Offset: 0xE4</b> |                   |                | <b>Register Name: PG_CFG3</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |

| <b>Offset: 0xE4</b> |                   |                | <b>Register Name: PG_CFG3</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                | /                 | /              | /                                                                  |

#### 1.19.4.59. PG DATA REGISTER

| <b>Offset: 0xE8</b> |                   |                | <b>Register Name: PG_DAT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                       |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
| 31:12               | /                 | /              | /                                                                                                                                                                                                                                                                                                                       |
| 11:0                | R/W               | 0              | <b>PG_DAT</b><br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 1.19.4.60. PG MULTI-DRIVING REGISTER 0

| <b>Offset: 0xEC</b>   |                   |                | <b>Register Name: PG_DRV0</b><br><b>Default Value: 0x0555_5555</b>                                                                                 |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                 |
| 31:20                 | /                 | /              | /                                                                                                                                                  |
| [2i+1:2i]<br>(i=0~11) | R/W               | 0x1            | <b>PG_DRV</b><br>PG[n] Multi-Driving Select (n = 0~11)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 1.19.4.61. PG MULTI-DRIVING REGISTER 1

|                     |                                                                    |
|---------------------|--------------------------------------------------------------------|
| <b>Offset: 0xF0</b> | <b>Register Name: PG_DRV1</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|--------------------------------------------------------------------|

| <b>Bit</b> | <b>Read/Write</b> | <b>Default</b> | <b>Description</b> |
|------------|-------------------|----------------|--------------------|
| 31:24      | /                 | /              | /                  |

#### 1.19.4.62. PG PULL REGISTER 0

| <b>Offset: 0xF4</b>   |                   |                | <b>Register Name: PG_PULL0</b><br><b>Default Value: 0x0000_0000</b>                                                          |
|-----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                           |
| 31:24                 | /                 | /              | /                                                                                                                            |
| [2i+1:2i]<br>(i=0~11) | R/W               | 0x0            | <b>PG_PULL</b><br>PG[n] Pull-up/down Select (n = 0~11)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |

#### 1.19.4.63. PG PULL REGISTER 1

| <b>Offset: 0xF8</b> |                   |                | <b>Register Name: PG_PULL1</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:0                | /                 | /              | /                                                                   |

#### 1.19.4.64. PH CONFIGURE REGISTER 0

| <b>Offset: 0xFC</b> |                   |                | <b>Register Name: PH_CFG0</b><br><b>Default Value: 0x0000_0000</b>                                     |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                     |
| 31                  | /                 | /              | /                                                                                                      |
| 30:28               | R/W               | 0              | <b>PH7_SELECT</b><br>000: Input 001: Output<br>010: LCD1_D7 011: Reserved<br>100: UART5_RX 101: MS_CLK |

| Offset: 0xFC |            |         | Register Name: PH_CFG0                                                                                                                                                                                                                    |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                               |
|              |            |         | 110: EINT7                          111: CSI1_D7                                                                                                                                                                                          |
| 27           | /          | /       | /                                                                                                                                                                                                                                         |
| 26:24        | R/W        | 0       | PH6_SELECT<br>000: Input                          001: Output<br>010: LCD1_D6                          011: Reserved<br>100: UART5_TX                          101: MS_BS<br>110: EINT6                                  111: CSI1_D6     |
| 23           | /          | /       | /                                                                                                                                                                                                                                         |
| 22:20        | R/W        | 0       | PH5_SELECT<br>000: Input                          001: Output<br>010: LCD1_D5                          011: Reserved<br>100: UART4_RX                          101: Reserved<br>110: EINT5                                  111: CSI1_D5  |
| 19           | /          | /       | /                                                                                                                                                                                                                                         |
| 18:16        | R/W        | 0       | PH4_SELECT<br>000: Input                          001: Output<br>010: LCD1_D4                          011: Reserved<br>100: UART4_TX                          101: Reserved<br>110: EINT4                                  111: CSI1_D4  |
| 15           | /          | /       | /                                                                                                                                                                                                                                         |
| 14:12        | R/W        | 0       | PH3_SELECT<br>000: Input                          001: Output<br>010: LCD1_D3                          011: Reserved<br>100: UART3_CTS                          101: Reserved<br>110: EINT3                                  111: CSI1_D3 |
| 11           | /          | /       | /                                                                                                                                                                                                                                         |
| 10:8         | R/W        | 0       | PH2_SELECT<br>000: Input                          001: Output<br>010: LCD1_D2                          011: Reserved<br>100: UART3_RTS                          101: Reserved<br>110: EINT2                                  111: CSI1_D2 |
| 7            | /          | /       | /                                                                                                                                                                                                                                         |
| 6:4          | R/W        | 0       | PH1_SELECT                                                                                                                                                                                                                                |

| <b>Offset: 0xFC</b> |                   |                | <b>Register Name: PH_CFG0</b>                                                                                                            |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                       |
|                     |                   |                | 000: Input<br>010: LCD1_D1<br>100: UART3_RX<br>110: EINT1<br>001: Output<br>011: Reserved<br>101: Reserved<br>111: CSI1_D1               |
| 3                   | /                 | /              | /                                                                                                                                        |
| 2:0                 | R/W               | 0              | PH0_SELECT<br>000: Input<br>010: LCD1_D0<br>100: UART3_TX<br>110: EINT0<br>001: Output<br>011: Reserved<br>101: Reserved<br>111: CSI1_D0 |

#### 1.19.4.65. PH CONFIGURE REGISTER 1

| <b>Offset: 0x100</b> |                   |                | <b>Register Name: PH_CFG1</b>                                                                                                            |
|----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                       |
| 31                   | /                 | /              | /                                                                                                                                        |
| 30:28                | R/W               | 0              | PH15_SELECT<br>000: Input<br>010: LCD1_D15<br>100: KP_IN5<br>110: EINT15<br>001: Output<br>011: ETXD2<br>101: SMC_VPPPP<br>111: CSI1_D15 |
| 27                   | /                 | /              | /                                                                                                                                        |
| 26:24                | R/W               | 0              | PH14_SELECT<br>000: Input<br>010: LCD1_D14<br>100: KP_IN4<br>110: EINT14<br>001: Output<br>011: ETXD3<br>101: SMC_VPEN<br>111: CSI1_D14  |
| 23                   | /                 | /              | /                                                                                                                                        |
| 22:20                | R/W               | 0              | PH13_SELECT<br>000: Input<br>010: LCD1_D13<br>001: Output<br>011: Reserved                                                               |

| Offset: 0x100 |            |         | Register Name: PH_CFG1                                                                                                                                                                               |
|---------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default | Description                                                                                                                                                                                          |
|               |            |         | 100: PS2_SDA1                  101: SMC_RST<br>110: EINT13                  111: CSI1_D13                                                                                                            |
| 19            | /          | /       | /                                                                                                                                                                                                    |
| 18:16         | R/W        | 0       | PH12_SELECT<br>000: Input                  001: Output<br>010: LCD1_D12                  011: Reserved<br>100: PS2_SCK1                  101: Reserved<br>110: EINT12                  111: CSI1_D12 |
| 15            | /          | /       | /                                                                                                                                                                                                    |
| 14:12         | R/W        | 0       | PH11_SELECT<br>000: Input                  001: Output<br>010: LCD1_D11                  011: ERXD0<br>100: KP_IN3                  101: MS_D3<br>110: EINT11                  111: CSI1_D11         |
| 11            | /          | /       | /                                                                                                                                                                                                    |
| 10:8          | R/W        | 0       | PH10_SELECT<br>000: Input                  001: Output<br>010: LCD1_D10                  011: ERXD1<br>100: KP_IN2                  101: MS_D2<br>110: EINT10                  111: CSI1_D10         |
| 7             | /          | /       | /                                                                                                                                                                                                    |
| 6:4           | R/W        | 0       | PH9_SELECT<br>000: Input                  001: Output<br>010: LCD1_D9                  011: ERXD2<br>100: KP_IN1                  101: MS_D1<br>110: EINT9                  111: CSI1_D9             |
| 3             | /          | /       | /                                                                                                                                                                                                    |
| 2:0           | R/W        | 0       | PH8_SELECT<br>000: Input                  001: Output<br>010: LCD1_D8                  011: ERXD3<br>100: KP_IN0                  101: MS_D0<br>110: EINT8                  111: CSI1_D8             |

#### 1.19.4.66. PH CONFIGURE REGISTER 2

| Offset: 0x104 |            |         | Register Name: PH_CFG2<br>Default Value: 0x0000_0000                        |
|---------------|------------|---------|-----------------------------------------------------------------------------|
| Bit           | Read/Write | Default | Description                                                                 |
| 31            | /          | /       | /                                                                           |
| 30:28         | R/W        | 0       | PH23_SELECT<br>000: Input<br>010: LCD1_D23<br>100: KP_OUT3<br>110: Reserved |
| 27            | /          | /       | /                                                                           |
| 26:24         | R/W        | 0       | PH22_SELECT<br>000: Input<br>010: LCD1_D22<br>100: KP_OUT2<br>110: Reserved |
| 23            | /          | /       | /                                                                           |
| 22:20         | R/W        | 0       | PH21_SELECT<br>000: Input<br>010: LCD1_D21<br>100: CAN_RX<br>110: EINT21    |
| 19            | /          | /       | /                                                                           |
| 18:16         | R/W        | 0       | PH20_SELECT<br>000: Input<br>010: LCD1_D20<br>100: CAN_TX<br>110: EINT20    |
| 15            | /          | /       | /                                                                           |
| 14:12         | R/W        | 0       | PH19_SELECT<br>000: Input<br>010: LCD1_D19<br>100: KP_OUT1<br>110: EINT19   |
| 11            | /          | /       | /                                                                           |
| 10:8          | R/W        | 0       | PH18_SELECT                                                                 |

| <b>Offset: 0x104</b> |                   |                | <b>Register Name: PH_CFG2</b>                                                                                                            |
|----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                       |
|                      |                   |                | 000: Input<br>010: LCD1_D18<br>100: KP_OUT0<br>110: EINT18<br>001: Output<br>011: ERXCK<br>101: SMC_SCK<br>111: CSI1_D18                 |
| 7                    | /                 | /              | /                                                                                                                                        |
| 6:4                  | R/W               | 0              | PH17_SELECT<br>000: Input<br>010: LCD1_D17<br>100: KP_IN7<br>110: EINT17<br>001: Output<br>011: ETXD0<br>101: SMC_VCCEN<br>111: CSI1_D17 |
| 3                    | /                 | /              | /                                                                                                                                        |
| 2:0                  | R/W               | 0              | PH16_SELECT<br>000: Input<br>010: LCD1_D16<br>100: KP_IN6<br>110: EINT16<br>001: Output<br>011: ETXD1<br>101: Reserved<br>111: CSI1_D16  |

#### 1.19.4.67. PH CONFIGURE REGISTER 3

| <b>Offset: 0x108</b> |                   |                | <b>Register Name: PH_CFG3</b>                                                                                                                  |
|----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                             |
| 31:15                | /                 | /              | /                                                                                                                                              |
| 14:12                | R/W               | 0              | PH27_SELECT<br>000: Input<br>010: LCD1_VSYNC<br>100: KP_OUT7<br>110: Reserved<br>001: Output<br>011: ETXERR<br>101: SDC1_D3<br>111: CSI1_VSYNC |
| 11                   | /                 | /              | Reserved                                                                                                                                       |
| 10:8                 | R/W               | 0              | PH26Select<br>000: Input<br>010: LCD1_HSYNC<br>001: Output<br>011: ECOL                                                                        |

| <b>Offset: 0x108</b> |                   |                | <b>Register Name: PH_CFG3</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                          |
|----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                          |
|                      |                   |                | 100: KP_OUT6                    101: SDC1_D2<br>110: Reserved                    111: CSI1_HSYNC                                                                                                            |
| 7                    | /                 | /              | /                                                                                                                                                                                                           |
| 6:4                  | R/W               | 0              | PH25_SELECT<br>000: Input                      001: Output<br>010: LCD1_DE                    011: ECRS<br>100: KP_OUT5                    101: SDC1_D1<br>110: Reserved                    111: CSI1_FIELD |
| 3                    | /                 | /              | /                                                                                                                                                                                                           |
| 2:0                  | R/W               | 0              | PH24_SELECT<br>000: Input                      001: Output<br>010: LCD1_CLK                  011: ETXCK<br>100: KP_OUT4                    101: SDC1_D0<br>110: Reserved                    111: CSI1_PCLK  |

#### 1.19.4.68. PH DATA REGISTER

| <b>Offset: 0x10C</b> |                   |                | <b>Register Name: PH_DAT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                |
|----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
| 31:28                | /                 | /              | /                                                                                                                                                                                                                                                                                                                |
| 27:0                 | R/W               | 0              | PH_DAT<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 1.19.4.69. PH MULTI-DRIVING REGISTER 0

|                      |                                                                    |
|----------------------|--------------------------------------------------------------------|
| <b>Offset: 0x110</b> | <b>Register Name: PH_DRV0</b><br><b>Default Value: 0x5555_5555</b> |
|----------------------|--------------------------------------------------------------------|

| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                          |
|-----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x1            | PH_DRV<br>PH[n] Multi-Driving Select (n = 0~15)<br>00: Level 0                            01: Level 1<br>10: Level 2                            11: Level 3 |

#### PH MULTI-DRIVING REGISTER 1

| <b>Offset: 0x114</b>  |                   |                | <b>Register Name: PH_DRV1</b><br><b>Default Value: 0x0055_5555</b>                                                                                           |
|-----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                           |
| 31:24                 | /                 | /              | /                                                                                                                                                            |
| [2i+1:2i]<br>(i=0~11) | R/W               | 0x1            | PH_DRV<br>PH[n] Multi-Driving Select (n = 16~27)<br>00: Level 0                            01: Level 1<br>10: Level 2                            11: Level 3 |

#### 1.19.4.70. PH PULL REGISTER 0

| <b>Offset: 0x118</b>  |                   |                | <b>Register Name: PH_PULL0</b><br><b>Default Value: 0x0000_0000</b>                                                                              |
|-----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                               |
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x0            | PH_PULL<br>PH[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down                            11: Reserved |

#### 1.19.4.71. PH PULL REGISTER 1

| <b>Offset: 0x11C</b> |                   |                | <b>Register Name: PH_PULL1</b><br><b>Default Value: 0x0000_0000</b> |
|----------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:24                | /                 | /              | /                                                                   |

| <b>Offset: 0x11C</b>  |                   |                | <b>Register Name: PH_PULL1</b><br><b>Default Value: 0x0000_0000</b>                                                           |
|-----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                            |
| [2i+1:2i]<br>(i=0~11) | R/W               | 0x0            | PH_PULL<br>PH[n] Pull-up/down Select (n = 16~27)<br>00: Pull-up/down disable 01: Pull-up enable<br>10: Pull-down 11: Reserved |

#### 1.19.4.72. PI CONFIGURE REGISTER 0

| <b>Offset: 0x120</b> |                   |                | <b>Register Name: PI_CFG0</b><br><b>Default Value: 0x0000_0000</b>                                                                |
|----------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                |
| 31                   | /                 | /              | /                                                                                                                                 |
| 30:28                | R/W               | 0              | PI7_SELECT<br>000: Input 001: Output<br>010: SDC3_D1 011: Reserved<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved  |
| 27                   | /                 | /              | /                                                                                                                                 |
| 26:24                | R/W               | 0              | PI6_SELECT<br>000: Input 001: Output<br>010: SDC3_D0 011: Reserved<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved  |
| 23                   | /                 | /              | /                                                                                                                                 |
| 22:20                | R/W               | 0              | PI5_SELECT<br>000: Input 001: Output<br>010: SDC3_CLK 011: Reserved<br>100: Reserved 101: Reserved<br>110: Reserved 111: Reserved |
| 19                   | /                 | /              | /                                                                                                                                 |
| 18:16                | R/W               | 0              | PI4_SELECT<br>000: Input 001: Output<br>010: SDC3_CMD 011: Reserved                                                               |

| <b>Offset: 0x120</b> |                   |                | <b>Register Name: PI_CFG0</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                |
|----------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                |
|                      |                   |                | 100: Reserved                    101: Reserved<br>110: Reserved                    111: Reserved                                                                                                  |
| 15                   | /                 | /              | /                                                                                                                                                                                                 |
| 14:12                | R/W               | 0              | PI3_SELECT<br>000: Input                    001: Output<br>010: PWM1                    011: TWI4_SDA<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |
| 11                   | /                 | /              | /                                                                                                                                                                                                 |
| 10:8                 | R/W               | 0              | PI2_SELECT<br>000: Input                    001: Output<br>010: Reserved                011: TWI4_SCK<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |
| 7                    | /                 | /              | /                                                                                                                                                                                                 |
| 6:4                  | R/W               | 0              | PI1_SELECT<br>000: Input                    001: Output<br>010: Reserved                011: TWI3_SDA<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |
| 3                    | /                 | /              | /                                                                                                                                                                                                 |
| 2:0                  | R/W               | 0              | PI0_SELECT<br>000: Input                    001: Output<br>010: Reserved                011: TWI3_SCK<br>100: Reserved                101: Reserved<br>110: Reserved                111: Reserved |

#### 1.19.4.73. PI CONFIGURE REGISTER 1

| <b>Offset: 0x124</b> |                   |                | <b>Register Name: PI_CFG1</b><br><b>Default Value: 0x0000_0000</b> |
|----------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |

| Offset: 0x124 |            |         | Register Name: PI_CFG1                                                       |
|---------------|------------|---------|------------------------------------------------------------------------------|
| Bit           | Read/Write | Default | Description                                                                  |
| 31            | /          | /       | /                                                                            |
| 30:28         | R/W        | 0       | PI15_SELECT<br>000: Input<br>010: SPI1_CS1<br>100: TCLKIN1<br>110: EINT27    |
| 27            | /          | /       | /                                                                            |
| 26:24         | R/W        | 0       | PI14_SELECT<br>000: Input<br>010: SPI0_CS1<br>100: TCLKIN0<br>110: EINT26    |
| 23            | /          | /       | /                                                                            |
| 22:20         | R/W        | 0       | PI13_SELECT<br>000: Input<br>010: SPI0_MISO<br>100: CLK_OUT_B<br>110: EINT25 |
| 19            | /          | /       | /                                                                            |
| 18:16         | R/W        | 0       | PI12_SELECT<br>000: Input<br>010: SPI0_MOSI<br>100: CLK_OUT_A<br>110: EINT24 |
| 15            | /          | /       | /                                                                            |
| 14:12         | R/W        | 0       | PI11_SELECT<br>000: Input<br>010: SPI0_CLK<br>100: Reserved<br>110: EINT23   |
| 11            | /          | /       | /                                                                            |
| 10:8          | R/W        | 0       | PI10_SELECT<br>000: Input<br>001: Output                                     |

| Offset: 0x124 |            |         | Register Name: PI_CFG1                                                                                                                                                                                                                         |
|---------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default | Description                                                                                                                                                                                                                                    |
|               |            |         | 010: SPI0_CS0                          011: UART5_TX<br>100: Reserved                            101: Reserved<br>110: EINT22                              111: Reserved                                                                       |
| 7             | /          | /       | /                                                                                                                                                                                                                                              |
| 6:4           | R/W        | 0       | PI9_SELECT<br>000: Input                              001: Output<br>010: SDC3_D3                            011: Reserved<br>100: Reserved                            101: Reserved<br>110: Reserved                            111: Reserved |
| 3             | /          | /       | /                                                                                                                                                                                                                                              |
| 2:0           | R/W        | 0       | PI8_SELECT<br>000: Input                              001: Output<br>010: SDC3_D2                            011: Reserved<br>100: Reserved                            101: Reserved<br>110: Reserved                            111: Reserved |

#### 1.19.4.74. PI CONFIGURE REGISTER 2

| Offset: 0x128 |            |         | Register Name: PI_CFG2                                                                                                                                                                                                                           |
|---------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default | Description                                                                                                                                                                                                                                      |
| 31:23         | /          | /       | /                                                                                                                                                                                                                                                |
| 22:20         | R/W        | 0       | PI21_SELECT<br>000: Input                              001: Output<br>010: PS2_SDA0                            011: UART7_RX<br>100: HSDA                                101: Reserved<br>110: Reserved                            111: Reserved |
| 19            | /          | /       | /                                                                                                                                                                                                                                                |
| 18:16         | R/W        | 0       | PI20_SELECT<br>000: Input                              001: Output<br>010: PS2_SCK0                            011: UART7_TX<br>100: HSCL                                101: Reserved                                                           |

| <b>Offset: 0x128</b>              |                   |                | <b>Register Name: PI_CFG2</b>                                                                                                                         |
|-----------------------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Default Value: 0x0000_0000</b> |                   |                |                                                                                                                                                       |
| <b>Bit</b>                        | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                    |
|                                   |                   |                | 110: Reserved      111: Reserved                                                                                                                      |
| 15                                | /                 | /              | /                                                                                                                                                     |
| 14:12                             | R/W               | 0              | PI19_SELECT<br>000: Input      001: Output<br>010: SPI1_MISO      011: UART2_RX<br>100: Reserved      101: Reserved<br>110: EINT31      111: Reserved |
| 11                                | /                 | /              | /                                                                                                                                                     |
| 10:8                              | R/W               | 0              | PI18_SELECT<br>000: Input      001: Output<br>010: SPI1_MOSI      011: UART2_TX<br>100: Reserved      101: Reserved<br>110: EINT30      111: Reserved |
| 7                                 | /                 | /              | /                                                                                                                                                     |
| 6:4                               | R/W               | 0              | PI17_SELECT<br>000: Input      001: Output<br>010: SPI1_CLK      011: UART2_CTS<br>100: Reserved      101: Reserved<br>110: EINT29      111: Reserved |
| 3                                 | /                 | /              | /                                                                                                                                                     |
| 2:0                               | R/W               | 0              | PI16_SELECT<br>000: Input      001: Output<br>010: SPI1_CS0      011: UART2_RTS<br>100: Reserved      101: Reserved<br>110: EINT28      111: Reserved |

#### 1.19.4.75. PI CONFIGURE REGISTER 3

| <b>Offset: 0x12C</b>              |                   |                | <b>Register Name: PI_CFG3</b> |
|-----------------------------------|-------------------|----------------|-------------------------------|
| <b>Default Value: 0x0000_0000</b> |                   |                |                               |
| <b>Bit</b>                        | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>            |
| 31:0                              | /                 | /              | /                             |

#### 1.19.4.76. PI DATA REGISTER

| <b>Offset: 0x130</b> |                   |                | <b>Register Name: PI_DAT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                       |
|----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
| 31:22                | /                 | /              | /                                                                                                                                                                                                                                                                                                                       |
| 21:0                 | R/W               | 0              | <b>PI_DAT</b><br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 1.19.4.77. PI MULTI-DRIVING REGISTER 0

| <b>Offset: 0x134</b>  |                   |                | <b>Register Name: PI_DRV0</b><br><b>Default Value: 0x5555_5555</b>                                                                                 |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                 |
| [2i+1:2i]<br>(i=0~15) | R/W               | 0x1            | <b>PI_DRV</b><br>PI[n] Multi-Driving Select (n = 0~15)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 1.19.4.78. PI MULTI-DRIVING REGISTER 1

| <b>Offset: 0x138</b> |                   |                | <b>Register Name: PI_DRV1</b><br><b>Default Value: 0x0000_0000</b>                                    |
|----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                    |
| 31:12                | /                 | /              | Reserved                                                                                              |
| [2i+1:2i]<br>(i=0~5) | R/W               | 0x1            | <b>PI_DRV</b><br>PI[n] Multi-Driving Select (n = 16~21)<br>00: Level 0                    01: Level 1 |

| <b>Offset: 0x138</b> |                   |                | <b>Register Name: PI_DRV1</b><br><b>Default Value: 0x0000_0000</b> |
|----------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
|                      |                   |                | 10: Level 2      11: Level 3                                       |

#### 1.19.4.79. PI PULL REGISTER 0

| <b>Offset: 0x13C</b>  |                   |                | <b>Register Name: PI_PULL0</b><br><b>Default Value: 0x0000_0000</b>                                                        |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                         |
| 31:26                 | /                 | /              | /                                                                                                                          |
| [2i+1:2i]<br>(i=0~12) | R/W               | 0x0            | PI_PULL<br>PI[n] Pull-up/down Select (n = 0~12)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down      11: Reserved |

#### 1.19.4.80. PI PULL REGISTER 1

| <b>Offset: 0x140</b> |                   |                | <b>Register Name: PI_PULL1</b><br><b>Default Value: 0x0000_0000</b> |
|----------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:0                 | /                 | /              | /                                                                   |

#### 1.19.4.81. PIO INTERRUPT CONFIGURE REGISTER 0

| <b>Offset: 0x200</b> |                   |                | <b>Register Name: PIO_INT_CFG0</b><br><b>Default Value: 0x0000_0000</b>                 |
|----------------------|-------------------|----------------|-----------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                      |
| [4i+3:4i]<br>(i=0~7) | R/W               | 0              | PIO_INT_CFG<br>External INTn Mode (n = 0~7)<br>0x0: Positive Edge<br>0x1: Negative Edge |

| <b>Offset: 0x200</b> |                   |                | <b>Register Name: PIO_INT_CFG0</b><br><b>Default Value: 0x0000_0000</b>                        |
|----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                             |
|                      |                   |                | 0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |

#### 1.19.4.82. PIO INTERRUPT CONFIGURE REGISTER 1

| <b>Offset: 0x204</b> |                   |                | <b>Register Name: PIO_INT_CFG1</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                    |
|----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                         |
| [4i+3:4i]<br>(i=0~7) | R/W               | 0              | PIO_INT_CFG<br>External INTn Mode (n = 8~15)<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 |

#### 1.19.4.83. PIO INTERRUPT CONFIGURE REGISTER 2

| <b>Offset: 0x208</b> |                   |                | <b>Register Name: PIO_INT_CFG2</b><br><b>Default Value: 0x0000_0000</b>                                                                                                 |
|----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                      |
| [4i+3:4i]<br>(i=0~7) | R/W               | 0              | PIO_INT_CFG<br>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) |

| <b>Offset: 0x208</b> |                   |                | <b>Register Name: PIO_INT_CFG2</b><br><b>Default Value: 0x0000_0000</b> |
|----------------------|-------------------|----------------|-------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                      |
|                      |                   |                | Others: Reserved                                                        |

#### 1.19.4.84. PIO INTERRUPT CONFIGURE REGISTER 3

| <b>Offset: 0x20C</b> |                   |                | <b>Register Name: PIO_INT_CFG3</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                     |
|----------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                          |
| [4i+3:4i]<br>(i=0~7) | R/W               | 0              | PIO_INT_CFG<br>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 |

#### 1.19.4.85. PIO INTERRUPT CONTROL REGISTER

| <b>Offset: 0x210</b> |                        |                | <b>Register Name: PIO_INT_CTL</b><br><b>Default Value: 0x0000_0000</b>    |
|----------------------|------------------------|----------------|---------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Wri<br/>te</b> | <b>Default</b> | <b>Description</b>                                                        |
| [n]<br>(n=0~31)      | R/W                    | 0              | PIO_INT_CTL<br>External INTn Enable (n = 0~31)<br>0: Disable<br>1: Enable |

#### 1.19.4.86. PIO INTERRUPT STATUS REGISTER

| <b>Offset: 0x214</b> |                   |                | <b>Register Name: PIO_INT_STATUS</b><br><b>Default Value: 0x0000_0000</b>                                           |
|----------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                  |
| [n]<br>(n=0~31)      | R/W               | 0              | PIO_INT_STATUS<br>External INTn Pending Bit (n = 0~31)<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 1.19.4.87. PIO INTERRUPT DEBOUNCE REGISTER

| <b>Offset: 0x218</b> |                   |                | <b>Register Name: PIO_INT_DEB</b><br><b>Default Value: 0x0000_0000</b>                               |
|----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                   |
| 31:7                 | /                 | /              | /                                                                                                    |
| 6:4                  | R/W               | 0              | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre-scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1                  | /                 | /              | /                                                                                                    |
| 0                    | R/W               | 0              | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32Khz<br>1: HOSC 24Mhz                   |

For Allwinnertech Only

## Chapter 2 Memory

This chapter details the A20 memory subsystem:

- DRAM
- NAND FLASH

## 2.1. DRAM

### 2.1.1. Overview

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

It features:

- Support DDR3L/DDR3/DDR2 SDRAM
- Support different memory device's power of 1.35V, 1.5V and 1.8V
- Support memory capacity up to 16G bits (2GB)
- 16 address lines and 3 bank address lines
- Data IO size can up to 32-bit for DDR2 and DDR3 (x8, x16)
- Automatically generates 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
- Random read or write operations

## 2.2. NAND Flash

### 2.2.1. Overview

The NFC is the NAND Flash Controller which supports all NAND/MLC flash memory available in the market. New type flash can be supported by software reconfiguration. The NFC can support 8 NAND flash with 1.8/3.3 V voltage supply. There are 8 separate chip select lines (CE#) for connecting up to 8 flash chips with 2 R/B signals.

The On-the-fly error correction code (ECC) is built-in NFC for enhancing reliability. BCH is implemented and it can 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 for reading or writing external Flash. The NFC maintains the proper relativity for CLE, CE# and ALE control signal lines. Three kind of modes are supported for serial read access. The conventional serial access is mode 0 and mode 1 is for EDO type and mode 2 for extension EDO type. NFC can monitor the status of R/B# signal line.

Block management and wear leveling management are implemented in software.

It features:

- Comply to ONFI 2.3 and Toggle 1.0
- Support 64-bit ECC per 512 bytes or 1024 bytes
- Support 8bits data bus width
- Support 1.8V/3.3V signal voltage
- Support 1K/2K/4K/8K/16K page size
- Support up to 8 CE and 2 RB
- Support system boot from NAND flash
- Support SLC/MLC NAND and EF-NAND
- Support SDR/DDR NAND interface

## 2.2.2. Nand Flash Block Diagram



### 2.2.3. NFC Timing Diagram

Typically, there are two kinds of serial access method. One method is conventional method which fetching data at the rise edge of NFC\_RE# signal line. Another one is EDO type which fetching data at the next fall edge of NFC\_RE# signal line.

Conventional Serial Access after Read Cycle (SAM0)



EDO type Serial Access after Read Cycle (SAM1)



### Extending EDO type Serial Access Mode (SAM2)



### Command Latch Cycle



### Address Latch Cycle



### Write Data to Flash Cycle



Waiting R/B# ready Diagram



WE# high to RE# low Timing Diagram



### RE# high to WE# low Timing Diagram



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

| ID  | Parameter                    | Timing | Notes                                                  |
|-----|------------------------------|--------|--------------------------------------------------------|
| 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) |

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

## 2.2.4. NFC Operation Guide



Page Read Command Diagram



Page Program Diagram



EF-NAND Page Read Diagram



Interleave Page Read Diagram

# Chapter 3 Graphic

This chapter mainly details the mixer processor in A20.

## 3.1. Mixer Processor

### 3.1.1. Overview

The mixer processor features:

- support multiple color formats
  - ARGB 8888/4444/1555
  - RGB565
  - MONO 1/2/4/8 bpp
  - Palette 1/2/4/8 bpp (input only)
  - YUV 444/422/420
- Buffer block size up to 8192x8192 pixels
- Memory scan order option support
- Clipping support
- ROP2
  - Line / Rectangle / Point
  - Block fill
- ROP3
  - BitBLT
  - PatBLT
  - StretchBLT
- ROP4
  - MaskBLT
- Support 90/180/270 degree rotation
- Mirror support
- Alpha blending
  - Plane & Pixel alpha support
  - Output alpha configurable support
- Color key support
- Scaling
  - 4x4 taps
  - 32 phase
- Color space convert support

### 3.1.2. Mixer Processor Block Diagram



### 3.1.3. MP Register List

| Module name | Base address |
|-------------|--------------|
| MP          | 0x01e80000   |

| Register name     | Offset | Description                      |
|-------------------|--------|----------------------------------|
| MP_CTL_REG        | 0x0    | Mixer control register           |
| MP_STS_REG        | 0x4    | Mixer Status register            |
| MP_IDMAGLBCTL_REG | 0x8    | Input DMA globe control register |

| <b>Register name</b>   | <b>Offset</b> | <b>Description</b>                                   |
|------------------------|---------------|------------------------------------------------------|
| MP_IDMA_H4ADD_REG      | 0xC           | Input DMA start address high 4bits register          |
| MP_IDMA_L32ADD_REG     | 0x10 – 0x1C   | Input DMA start address low 32bits register          |
| MP_IDMALINEWIDTH_REG   | 0x20 – 0x2C   | Input DMA line width register                        |
| MP_IDMASIZE_REG        | 0x30 – 0x3C   | Input DMA memory block size register                 |
| MP_IDMACOOR_REG        | 0x40 – 0x4C   | Input DMA memory block coordinate control register   |
| MP_IDMASET_REG         | 0x50 – 0x5C   | Input DMA setting register                           |
| MP_IDMAFILLCOLOR_REG   | 0x60 – 0x6C   | Input DMA fill-color register                        |
| MP_IDMASORT_REG        | 0x70          | Input DMA channel sorter register                    |
| MP_CSC0CTL_REG         | 0x74          | Color space converter 0 control register             |
| MP_CSC1CTL_REG         | 0x78          | Color space converter 1 control register             |
| MP_SCACTL_REG          | 0x80          | Scaler control register                              |
| MP_SCAOUTSIZE_REG      | 0x84          | Scaling output size register                         |
| MP_SCAHORFCT_REG       | 0x88          | Scaler horizontal scaling factor register            |
| MP_SCAVERFCT_REG       | 0x8C          | Scaler vertical scaling factor register              |
| MP_SCAHORPHASE_REG     | 0x90          | Scaler horizontal start phase setting register       |
| MP_SCAVERPHASE_REG     | 0x94          | Scaler vertical start phase setting register         |
| MP_ROPCTL_REG          | 0xB0          | ROP control register                                 |
| MP_ROPIDX0CTL_REG      | 0xB8          | ROP channel 3 index 0 control table setting register |
| MP_ROPIDX1CTL_REG      | 0xBC          | ROP channel 3 index 1 control table setting register |
| MP_ALPHACKCTL_REG      | 0xC0          | Alpha / Color key control register                   |
| MP_CKMIN_REG           | 0xC4          | Color key min color register                         |
| MP_CKMAX_REG           | 0xC8          | Color key max color register                         |
| MP_ROPOUTFILLCOLOR_REG | 0xCC          | Fill color of ROP output setting register            |
| MP_CSC2CTL_REG         | 0xD0          | Color space converter 2 control register             |
| MP_OUTCTL_REG          | 0xE0          | Output control register                              |
| MP_OUTSIZE_REG         | 0xE8          | Output size register                                 |
| MP_OUTH4ADD_REG        | 0xEC          | Output address high 4bits register                   |
| MP_OUTL32ADD_REG       | 0xF0 – 0xF8   | Output address low 32bits register                   |
| MP_OUTLINEWIDTH_REG    | 0x100 – 0x108 | Output line width register                           |

| <b>Register name</b> | <b>Offset</b> | <b>Description</b>                                 |
|----------------------|---------------|----------------------------------------------------|
| MP_OUTALPHACTL_REG   | 0x120         | Output alpha control register                      |
| MP_ICSCYGYCOEF_REG   | 0x180 – 0x188 | CSC0/1 Y/G coefficient register                    |
| MP_ICSCYGCNS_REG     | 0x18C         | CSC0/1 Y/G constant register                       |
| MP_ICSCURCOEF_REG    | 0x190 – 0x198 | CSC0/1 U/R coefficient register                    |
| MP_ICSCURCONS_REG    | 0x19C         | CSC0/1 U/R constant register                       |
| MP_ICSCVBCOEF_REG    | 0x1A0 – 0x1A8 | CSC0/1 V/B coefficient register                    |
| MP_ICSCVBCONS_REG    | 0x1AC         | CSC0/1 V/B constant register                       |
| MP_OCSCYGYCOEF_REG   | 0x1C0 – 0x1C8 | CSC2 Y/G coefficient register                      |
| MP_OCSCYGCNS_REG     | 0x1CC         | CSC2 Y/G constant register                         |
| MP_OCSCURCOEF_REG    | 0x1D0 – 0x1D8 | CSC2 U/R coefficient register                      |
| MP_OCSCURCONS_REG    | 0x1DC         | CSC2 U/R constant register                         |
| MP_OCSCVBCOEF_REG    | 0x1E0 – 0x1E8 | CSC2 V/B coefficient register                      |
| MP_OCSCVBCONS_REG    | 0x1EC         | CSC2 V/B constant register                         |
| <b>Memory</b>        |               |                                                    |
|                      | 0x200 – 0x27C | Scaling horizontal filtering coefficient RAM block |
|                      | 0x280 – 0x2FC | Scaling vertical filtering coefficient RAM block   |
|                      | 0x400 – 0x7FF | Palette table                                      |

### 3.1.4. MP Register Description

#### 3.1.4.1. MIXER CONTROL REGISTER

| Offset: 0x0 |                |                | Register Name: MP_CTL_REG                                            |
|-------------|----------------|----------------|----------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/H<br>e | Description                                                          |
| 31:10       | /              | /              | /                                                                    |
| 9           | R/W            | 0              | <b>HWERRIRQ_EN</b><br>Hardware error IRQ enable control<br>0:disable |

| Offset: 0x0 |                |                 | Register Name: MP_CTL_REG                                                                                      |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/H<br>ex | Description                                                                                                    |
|             |                |                 | 1:enable                                                                                                       |
| 8           | R/W            | 0               | <b>FINISHIRQ_EN</b><br>Mission finish IRQ enable control<br>0:disable<br>1:enable                              |
| 7:2         | /              | /               | /                                                                                                              |
| 1           | R/W            | 0               | <b>START_CTL</b><br>Start control<br>If the bit is set, the module will start 1 frame operation and stop auto. |
| 0           | R/W            | 0               | <b>MP_EN</b><br>Enable control<br>0:disable<br>1:enable                                                        |

### 3.1.4.2. MIXER STATUS REGISTER

| Offset: 0x4 |                |                 | Register Name: MP_STS_REG                                                                                         |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/H<br>ex | Description                                                                                                       |
| 31:14       | /              | /               | /                                                                                                                 |
| 13          | R              | 0               | <b>HWERR_FLAG</b><br>Hardware error status                                                                        |
| 12          | R              | 0               | <b>BUSY_FLAG</b><br>Module working status<br>0:idle<br>1:running                                                  |
| 11:10       | /              | /               | /                                                                                                                 |
| 9           | R/W            | 0               | <b>HWERRIRQ_FLAG</b><br>Hardware error IRQ<br>It will be set when hardware error occur, and cleared by writing 1. |
| 8           | R/W            | 0               | <b>FINISHIRQ_FLAG</b>                                                                                             |

| Offset: 0x4 |                |                 | Register Name: MP_STS_REG                                                                           |
|-------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/H<br>ex | Description                                                                                         |
|             |                |                 | Mission finish IRQ<br>It will be set when 1 frame operation accomplished, and cleared by writing 1. |
| 7:0         | /              | /               | /                                                                                                   |

### 3.1.4.3. INPUT DMA GLOBE CONTROL REGISTER

| Offset: 0x8 |                |                 | Register Name: MP_IDMAGLBCTL_REG                                                                                                                                                                                                                                                                                                                                                          |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                               |
| 31:10       | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                         |
| 9:8         | R/W            | 0               | <b>MEMSCANORDER</b><br>Memory scan order selection<br>0:<br>Top to down<br>Left to right<br>1:<br>Top to down<br>Right to left<br>2:<br>Down to top<br>Left to right<br>3:<br>Down to top<br>Right to left<br><br>Note:<br>----Four input DMA channel use the same scan rule.<br>----The each output DMA channel should match the same memory scan order rule with the input DMA channel. |
| 7:0         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                         |

### 3.1.4.4. INPUT DMA START ADDRESS HIGH 4BITS REGISTER

| Offset: 0xC |                |                 | Register Name: MP_IDMA_H4ADD_REG                          |
|-------------|----------------|-----------------|-----------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/H<br>ex | Description                                               |
| 31:28       | /              | /               | /                                                         |
| 27:24       | R/W            | 0               | <b>IDMA3_H4ADD</b><br>iDMA3<br>High 4bits address in bits |
| 23:20       | /              | /               | /                                                         |
| 19:16       | R/W            | 0               | <b>IDMA2_H4ADD</b><br>iDMA2<br>High 4bits address in bits |
| 15:12       | /              | /               | /                                                         |
| 11:8        | R/W            | 0               | <b>IDMA1_H4ADD</b><br>iDMA1<br>High 4bits address in bits |
| 7:4         | /              | /               | /                                                         |
| 3:0         | R/W            | 0               | <b>IDMA0_H4ADD</b><br>iDMA0<br>High 4bits address in bits |

### 3.1.4.5. INPUT DMA START ADDRESS LOW 32BITS REGISTER

| Offset:<br><br><b>iDMA0:0x10</b><br><b>iDMA1:0x14</b><br><b>iDMA2:0x18</b><br><b>iDMA3:0x1C</b> |                |                 | Register Name: MP_IDMA_L32ADD_REG                        |
|-------------------------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------|
| Bit                                                                                             | Read/W<br>rite | Default/<br>Hex | Description                                              |
| 31:0                                                                                            | R/W            | 0               | <b>IDMA_L32ADD</b><br>iDMA<br>Low 32bits address in bits |

### 3.1.4.6. INPUT DMA LINE WIDTH REGISTER

| <b>Offset:</b><br><b>iDMA0:0x20</b><br><b>iDMA1:0x24</b><br><b>iDMA2:0x28</b><br><b>iDMA3:0x2C</b> |                        |                         | <b>Register Name: MP_IDMALINEWIDTH_REG</b>          |
|----------------------------------------------------------------------------------------------------|------------------------|-------------------------|-----------------------------------------------------|
| <b>Bit</b>                                                                                         | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                  |
| 31:0                                                                                               | R/W                    | 0                       | <b>IDMA_LINEWIDTH</b><br>iDMA<br>Line width in bits |

### 3.1.4.7. INPUT DMA MEMORY BLOCK SIZE REGISTER

| <b>Offset:</b><br><b>iDMA0:0x30</b><br><b>iDMA1:0x34</b><br><b>iDMA2:0x38</b><br><b>iDMA3:0x3C</b> |                        |                         | <b>Register Name: MP_IDMASIZE_REG</b>                                                             |
|----------------------------------------------------------------------------------------------------|------------------------|-------------------------|---------------------------------------------------------------------------------------------------|
| <b>Bit</b>                                                                                         | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                |
| 31:29                                                                                              | /                      | /                       | /                                                                                                 |
| 28:16                                                                                              | R/W                    | 0                       | <b>IDMA_HEIGHT</b><br>Memory block height in pixels<br>The height = The value of these bits add 1 |
| 15:13                                                                                              | /                      | /                       | /                                                                                                 |
| 12:0                                                                                               | R/W                    | 0                       | <b>IDMA_WIDTH</b><br>Memory block width in pixels<br>The width = The value of these bits add 1    |

### 3.1.4.8. INPUT DMA MEMORY BLOCK COORDINATE CONTROL REGISTER

| <b>Offset:</b><br><b>iDMA0:0x40</b><br><b>iDMA1:0x44</b><br><b>iDMA2:0x48</b><br><b>iDMA3:0x4C</b> |                        |                         | <b>Register Name: MP_IDMACOOR_REG</b>                                                                                                           |
|----------------------------------------------------------------------------------------------------|------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                                                                                         | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                              |
| 31:16                                                                                              | R/W                    | 0                       | <b>IDMA_YCOOR</b><br>Y coordinate<br>Y is the left-top y coordinate of layer on output window in pixels<br>The Y represent the two's complement |
| 15:0                                                                                               | R/W                    | 0                       | <b>IDMA_XCOOR</b><br>X coordinate<br>X is left-top x coordinate of the layer on output window in pixels<br>The X represent the two's complement |

### 3.1.4.9. INPUT DMA SETTING REGISTER

| <b>Offset:</b><br><b>iDMA0:0x50</b><br><b>iDMA1:0x54</b><br><b>iDMA2:0x58</b><br><b>iDMA3:0x5C</b> |                        |                         | <b>Register Name: MP_IDMASET_REG</b>                                             |
|----------------------------------------------------------------------------------------------------|------------------------|-------------------------|----------------------------------------------------------------------------------|
| <b>Bit</b>                                                                                         | <b>Read/W<br/>rite</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                               |
| 31:24                                                                                              | R/W                    | 0                       | <b>IDMA_GLBALPHA</b><br>Globe alpha value                                        |
| 23:17                                                                                              | /                      | /                       | /                                                                                |
| 16                                                                                                 | R/W                    | 0                       | <b>IDMA_FCMODEN</b><br>Fill color mode enable control<br>0: disable<br>1: enable |
| 15:12                                                                                              | R/W                    | 0                       | <b>IDMA_PS</b><br>Input data pixel sequence                                      |

| <b>Offset:</b><br><b>iDMA0:0x50</b><br><b>iDMA1:0x54</b><br><b>iDMA2:0x58</b><br><b>iDMA3:0x5C</b> |                |                 | <b>Register Name: MP_IDMASET_REG</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                    |                |                 | Reference input pixel sequence table                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 11:8                                                                                               | R/W            | 0               | <p><b>IDMA_FMT</b><br/> Input data format<br/> 0x0:32bpp – A8R8G8B8 or interleaved AYUV8888<br/> 0x1:16bpp – A4R4G4B4<br/> 0x2:16bpp – A1R5G5B5<br/> 0x3:16bpp – R5G6B5<br/> 0x4:16bpp – interleaved YUV422<br/> 0x5:16bpp – U8V8<br/> 0x6:8bpp – Y8<br/> 0x7:8bpp – MONO or palette<br/> 0x8:4bpp – MONO or palette<br/> 0x9:2bpp – MONO or palette<br/> 0xa:1bpp – MONO or palette<br/> Other: reserved</p> <p>Note: if the input data format is 16 or 32bpp, and the work mode is palette mode, only the low 8 bits input data is valid.</p> |
| 7:4                                                                                                | R/W            | 0               | <p><b>IDMA_ROTMIRCTL</b><br/> Rotation and mirroring control<br/> 0:normal<br/> 1:X<br/> 2:Y<br/> 3:XY<br/> 4:A<br/> 5:AX<br/> 6:AY<br/> 7:AXY<br/> Other: reserved</p>                                                                                                                                                                                                                                                                                                                                                                         |
| 3:2                                                                                                | R/W            | 0               | <p><b>IDMA_ALPHACTL</b><br/> Alpha control</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Offset:</b><br><b>iDMA0:0x50</b><br><b>iDMA1:0x54</b><br><b>iDMA2:0x58</b><br><b>iDMA3:0x5C</b> |                |                 | <b>Register Name: MP_IDMASET_REG</b>                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                    |                |                 | 0:Ignore<br>Output alpha value = pixels alpha, if no pixel alpha, the alpha value equal 0xff<br><br>1:Globe alpha enable<br>Ignore pixel alpha value<br>Output alpha value = globe alpha value<br><br>2: Globe alpha mix pixel alpha<br>Output alpha value = globe alpha value * pixels alpha value<br><br>3:Reserved<br>Note: the output alpha value here means the input alpha value of the ALU following the DMA controller. |
| 1                                                                                                  | R/W            | 0               | <b>IDMA_WORKMOD</b><br>Work mode selection<br>0: normal mode ( non-palette mode )<br>1: palette mode                                                                                                                                                                                                                                                                                                                            |
| 0                                                                                                  | R/W            | 0               | <b>IDMA_EN</b><br>Input DMA enable control<br>0:disable input DMA channel, the respective fill-color value will instead of the input data.<br>1:enable                                                                                                                                                                                                                                                                          |

### 3.1.4.10. INPUT DMA FILL-COLOR REGISTER

|                                                                                                    |                                            |
|----------------------------------------------------------------------------------------------------|--------------------------------------------|
| <b>Offset:</b><br><b>iDMA0:0x60</b><br><b>iDMA1:0x64</b><br><b>iDMA2:0x68</b><br><b>iDMA3:0x6C</b> | <b>Register Name: MP_IDMAFILLCOLOR_REG</b> |
|----------------------------------------------------------------------------------------------------|--------------------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/H<br/>ex</b> | <b>Description</b>           |
|------------|------------------------|-------------------------|------------------------------|
| 31:24      | R/W                    | 0                       | <b>IDMA_FCALPHA</b><br>Alpha |
| 23:16      | R/W                    | 0                       | <b>IDMA_FCRED</b><br>Red     |
| 15:8       | R/W                    | 0                       | <b>IDMA_FCGREEN</b><br>Green |
| 7:0        | R/W                    | 0                       | <b>IDMA_FCBLUE</b><br>Blue   |

### 3.1.4.11. COLOR SPACE CONVERTER 0 CONTROL REGISTER

| <b>Offset: 0x74</b> |                        |                         | <b>Register Name: MP_CSC0CTL_REG</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------|------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/W<br/>rite</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31:8                | /                      | /                       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:4                 | R/W                    | 0                       | <p><b>CSC0_DATAMOD</b><br/> Data mode control<br/> 0:<br/> Interleaved AYUV8888 mode<br/> 1:<br/> Interleaved YUV422 mode</p> <p>In mode 0 and mode 1, only the channel 0 data path is valid for this module, the channel 1 data flow will by-pass the csc0 module, and direct to input formatter 1.</p> <p>2:<br/> Planar YUV422 mode (UV combined only)<br/> 3:<br/> Planar YUV420 mode (UV combined only)<br/> 4:<br/> Planar YUV411 mode (UV combined only)</p> <p>In mode 2/3/4, following rule:<br/> ----Y component data transfer through channel 0, and UV component data transfer through channel 1.</p> |

| Offset: 0x74 |                |                     | Register Name: MP_CSC0CTL_REG                                                                                                                                                                                              |
|--------------|----------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>e<br>x | Description                                                                                                                                                                                                                |
|              |                |                     | ----In this mode, the output data of the input formatter 1 will be instead of the respective fill-color value.                                                                                                             |
| 3:1          | /              | /                   | /                                                                                                                                                                                                                          |
| 0            | R/W            | 0                   | <p><b>CSC0_EN</b></p> <p>Enable control</p> <p>0:</p> <p>Disable color space function, ignore the control setting, and the data flow will by-pass the module.</p> <p>1:</p> <p>Enable color space converting function.</p> |

### 3.1.4.12. COLOR SPACE CONVERTER 1 CONTROL REGISTER

| Offset: 0x78 |                |                     | Register Name: MP_CSC1CTL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|----------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>e<br>x | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:8         | /              | /                   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:4          | R/W            | 0                   | <p><b>CSC1_DATAMOD</b></p> <p>Data mode control</p> <p>0:</p> <p>Interleaved AYUV8888 mode</p> <p>1:</p> <p>Interleaved YUV422 mode</p> <p>In mode 0 and mode 1, only the channel 3 data path is valid for this module, the channel 2 data flow will by-pass the csc1 module, and direct to input formatter 2.</p> <p>2:</p> <p>Planar YUV422 mode (UV combined only)</p> <p>3:</p> <p>Planar YUV420 mode (UV combined only)</p> <p>4:</p> <p>Planar YUV411 mode (UV combined only)</p> |

| Offset: 0x78 |                |                     | Register Name: MP_CSC1CTL_REG                                                                                                                                                                                                                          |
|--------------|----------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>e<br>x | Description                                                                                                                                                                                                                                            |
|              |                |                     | In mode 2/3/4, following rule:<br>----Y component data transfer through channel 3, and UV component data transfer through channel 2.<br>----In this mode, the output data of the input formatter 2 will be instead of the respective fill-color value. |
| 3:1          | /              | /                   | /                                                                                                                                                                                                                                                      |
|              |                |                     | <b>CSC1_EN</b><br>Enable control<br>0:<br>Disable color space function, ignore the control setting, and the data flow will by-pass the module.<br>1:<br>Enable color space converting function.                                                        |

### 3.1.4.13. SCALER CONTROL REGISTER

| Offset: 0x80 |                |                     | Register Name: MP_SCACTL_REG                                                                                                                                                                                                                                                                                             |
|--------------|----------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>e<br>x | Description                                                                                                                                                                                                                                                                                                              |
| 31:6         | /              | /                   | /                                                                                                                                                                                                                                                                                                                        |
|              |                |                     | <b>SCA_ALGSEL</b><br>Scaling algorithm selection<br>0: bi-cubic(4 taps in vertical and horizontal)<br>1: linear in vertical and bi-linear in horizontal(2 taps in vertical and 4 taps in horizontal)<br>2: extractive in vertical and bi-linear in horizontal(1 tap in vertical and 4 taps in horizontal)<br>3: reserved |
| 3:1          | /              | /                   | /                                                                                                                                                                                                                                                                                                                        |
|              |                |                     | <b>SCA_EN</b><br>Enable control<br>0:<br>Disable scaler, ignore the whole scaling setting, and the data flow will by-pass the module.<br>1:                                                                                                                                                                              |

| Offset: 0x80 |                |                     | Register Name: MP_SCACTL_REG |
|--------------|----------------|---------------------|------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>e<br>x | Description                  |
|              |                |                     | Enable scaling function.     |

### 3.1.4.14. SCALING OUTPUT SIZE REGISTER

| Offset: 0x84 |                |                     | Register Name: MP_SCAOUTSIZE_REG                                                                                                                                                |
|--------------|----------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>e<br>x | Description                                                                                                                                                                     |
| 31:29        | /              | /                   | /                                                                                                                                                                               |
| 28:16        | R/W            | 0                   | <p><b>SCA_OUTHEIGHT</b><br/>           Output height<br/>           The output height = The value of these bits add 1<br/>           The minimum output height is 8 pixels.</p> |
| 15:13        | /              | /                   | /                                                                                                                                                                               |
| 12:0         | R/W            | 0                   | <p><b>SCA_OUTWIDTH</b><br/>           Output width<br/>           The output width = The value of these bits add 1<br/>           The minimum output width is 16 pixels.</p>    |

### 3.1.4.15. SCALER HORIZONTAL SCALING FACTOR REGISTER

| Offset: 0x88 |                |                     | Register Name: MP_SCAHORFCT_REG                                                                                                                                       |
|--------------|----------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>e<br>x | Description                                                                                                                                                           |
| 31:24        | /              | /                   | /                                                                                                                                                                     |
| 23:16        | R/W            | 0                   | <p><b>SCA_HORINTFCT</b><br/>           The integer part of the horizontal scaling ratio<br/>           the horizontal scaling ratio = input width/output width</p>    |
| 15:00        | R/W            | 0                   | <p><b>SCA_HORFRAFCT</b><br/>           The fractional part of the horizontal scaling ratio<br/>           the horizontal scaling ratio = input width/output width</p> |

| Offset: 0x88 |                |             | Register Name: MP_SCAHORFCT_REG                                       |
|--------------|----------------|-------------|-----------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/Hex | Description                                                           |
|              |                |             | The input width is the memory block width of respective iDMA channel. |

### 3.1.4.16. SCALER VERTICAL SCALING FACTOR REGISTER

| Offset: 0x8C |                |             | Register Name: MP_SCAVERFCT_REG                                                                                                                                                                                      |
|--------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                          |
| 31:24        | /              | /           | /                                                                                                                                                                                                                    |
| 23:16        | R/W            | 0           | <b>SCA_VERINTFCT</b><br>The integer part of the vertical scaling ratio<br>the vertical scaling ratio = input height/output height                                                                                    |
| 15:00        | R/W            | 0           | <b>SCA_VERFRAFCT</b><br>The fractional part of the vertical scaling ratio<br>the vertical scaling ratio = input height /output height<br><br>The input height is the memory block height of respective iDMA channel. |

### 3.1.4.17. SCALER HORIZONTAL START PHASE SETTING REGISTER

| Offset: 0x90 |                |             | Register Name: MP_SCAHORPHASE_REG                                                                            |
|--------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/Hex | Description                                                                                                  |
| 31:20        | /              | /           | /                                                                                                            |
| 19:00        | R/W            | 0           | <b>SCA_HORPHASE</b><br>Start phase in horizontal (complement)<br>This value equals to start phase * $2^{16}$ |

### 3.1.4.18. SCALER VERTICAL START PHASE SETTING REGISTER

| Offset: 0x94 |                |                 | Register Name: MP_SCAVERPHASE_REG                                                                   |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                                                                                         |
| 31:20        | /              | /               | /                                                                                                   |
| 19:00        | R/W            | 0               | SCA_VERPHASE<br>Start phase in vertical (complement)<br>This value equals to start phase * $2^{16}$ |

### 3.1.4.19. ROP CONTROL REGISTER

| Offset: 0xB0 |                |                 | Register Name: MP_ROPCTL_REG                                                                                                                                                                      |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                       |
| 31:16        | /              | /               | /                                                                                                                                                                                                 |
| 15:14        | R/W            | 0               | <b>ROP_ALPHABYPASSSEL</b><br>ROP output Alpha channel selection<br>0: channel 0<br>1: channel 1<br>2: channel 2<br>3:reserved<br><br>Note: the bit is only valid in by-pass mode of Alpha channel |
| 13:12        | R/W            | 0               | <b>ROP_REDYPASSSEL</b><br>ROP output Red channel selection<br>0: channel 0<br>1: channel 1<br>2: channel 2<br>3:reserved<br><br>Note: the bit is only valid in by-pass mode of Red channel        |
| 11:10        | R/W            | 0               | <b>ROP_GREENBYPASSSEL</b><br>ROP output Green channel selection<br>0: channel 0<br>1: channel 1                                                                                                   |

| Offset: 0xB0 |                |                 | Register Name: MP_ROPCTL_REG                                                                                                                                                                               |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                |
|              |                |                 | <p>2: channel 2<br/>3:reserved</p> <p>Note: the bit is only valid in by-pass mode of Green channel</p>                                                                                                     |
| 9:8          | R/W            | 0               | <p><b>ROP_BLUEBYPASSSEL</b><br/>ROP output Blue channel selection<br/>0: channel 0<br/>1: channel 1<br/>2: channel 2<br/>3:reserved</p> <p>Note: the bit is only valid in by-pass mode of Blue channel</p> |
| 7            | R/W            | 0               | <p><b>ROP_ALPHABYPASSEN</b><br/>ROP Alpha channel by-pass enable control<br/>0:pass through<br/>1:by-pass</p>                                                                                              |
| 6            | R/W            | 0               | <p><b>ROP_REDDBYPASSEN</b><br/>ROP Red channel by-pass enable control<br/>0:pass through<br/>1:by-pass</p>                                                                                                 |
| 5            | R/W            | 0               | <p><b>ROP_GREENBYPASSEN</b><br/>ROP Green channel by-pass enable control<br/>0:pass through<br/>1:by-pass</p>                                                                                              |
| 4            | R/W            | 0               | <p><b>ROP_BLUEBYPASSEN</b><br/>ROP Blue channel by-pass enable control<br/>0:pass through<br/>1:by-pass</p>                                                                                                |
| 3:1          | /              | /               | /                                                                                                                                                                                                          |
| 0            | R/W            | 0               | <p><b>ROP_MOD</b><br/>ROP type selection<br/>0:ROP3<br/>1:ROP4</p> <p>----In ROP3 mode, only the value of 'channel 3 index 0 control</p>                                                                   |

| Offset: 0xB0 |                |                 | Register Name: MP_ROPCTL_REG                                                                                                                                                                                                                                                                                              |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                               |
|              |                |                 | <p>table setting register' will be selected.</p> <p>----In ROP3 mode, the channel 3 data will by-pass the ROP module.</p> <p>----In ROP3 mode, the channel 3 data will direct to Alpha/CK module.</p> <p>----In ROP4 mode, the respective input DMA channel fill color of channel 3 will transfer to Alpha/CK module.</p> |

### 3.1.4.20. ROP CHANNEL 3 INDEX 0 CONTROL TABLE SETTING REGISTER

| Offset: 0xB8 |                |                 | Register Name: MP_ROPIDX0CTL_REG                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:16        | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                |
| 15           | R/W            | 0               | <p><b>NOD7_CTL</b></p> <p>Index 0 node7 setting ( channel 0' and channel 1' and channel 2' mix not logic )</p> <p>0:by-pass<br/>1:not</p>                                                                                                                                                                                                                                                        |
| 14:11        | R/W            | 0               | <p><b>NOD6_CTL</b></p> <p>Index 0 node6 setting ( channel 0' and channel 1' and channel 2' mix logic )</p> <p>0:and<br/>1:or<br/>2:xor<br/>3:add in byte<br/>4:add in word (32bit)<br/>5:multiply in byte<br/>6:multiply in word (32bit)<br/>7:channel 0' mix channel 1' then sub channel 2' in byte<br/>8:channel 0' mix channel 1' then sub channel 2' in word (32bit)<br/>Other: Reserved</p> |
| 10           | R/W            | 0               | <p><b>NOD5_CTL</b></p> <p>Index 0 node5 setting ( channel 0' and channel 1' mix not logic )</p> <p>0:by-pass<br/>1:not</p>                                                                                                                                                                                                                                                                       |

| Offset: 0xB8 |                |                 | Register Name: MP_ROPIDX0CTL_REG                                                                                                                                                                                                                                                                                  |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                       |
| 9:6          | R/W            | 0               | <b>NOD4_CTL</b><br>Index 0 node4 setting ( channel 0' and channel 1' mix logic )<br>0:and<br>1:or<br>2:xor<br>3:add in byte<br>4:add in word (32bit)<br>5:multiply in byte<br>6:multiply in word (32bit)<br>7:channel 0' sub channel 1' in byte<br>8:channel 0' sub channel 1' in word (32bit)<br>Other: Reserved |
| 5            | R/W            | 0               | <b>NOD3_CTL</b><br>Index 0 node3 setting ( channel 2' not logic )<br>0:by-pass<br>1:not                                                                                                                                                                                                                           |
| 4            | R/W            | 0               | <b>NOD2_CTL</b><br>Index 0 node2 setting ( channel 1' not logic )<br>0:by-pass<br>1:not                                                                                                                                                                                                                           |
| 3            | R/W            | 0               | <b>NOD1_CTL</b><br>Index 0 node1 setting ( channel 0' not logic)<br>0:by-pass<br>1:not                                                                                                                                                                                                                            |
| 2:0          | R/W            | 0               | <b>NOD0_CTL</b><br>Index 0 node0 setting ( sorting control )<br>0:012<br>1:021<br>2:102<br>3:120<br>4:201<br>5:210<br>Other: Reserved                                                                                                                                                                             |

Note: the result of the add or multiply operation will select the high 8 (byte operation) or 32bits (word operation).

### 3.1.4.21. ROP CHANNEL 3 INDEX 1 CONTROL TABLE SETTING REGISTER

| Offset: 0xBC |                |                 | Register Name: MP_ROPIDX1CTL_REG                                                                                                                                                                                                                                                                                                                                         |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                              |
| 31:16        | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                        |
| 15           | R/W            | 0               | <b>NOD7_CTL</b><br>Index 1 node7 setting ( channel 0' and channel 1' and channel 2' mix not logic )<br>0:by-pass<br>1:not                                                                                                                                                                                                                                                |
| 14:11        | R/W            | 0               | <b>NOD6_CTL</b><br>Index 1 node6 setting ( channel 0' and channel 1' and channel 2' mix logic )<br>0:and<br>1:or<br>2:xor<br>3:add in byte<br>4:add in word (32bit)<br>5:multiply in byte<br>6:multiply in word (32bit)<br>7:channel 0' mix channel 1' then sub channel 2' in byte<br>8:channel 0' mix channel 1' then sub channel 2' in word (32bit)<br>Other: Reserved |
| 10           | R/W            | 0               | <b>NOD5_CTL</b><br>Index 1 node5 setting ( channel 0' and channel 1' mix not logic )<br>0:by-pass<br>1:not                                                                                                                                                                                                                                                               |
| 9:6          | R/W            | 0               | <b>NOD4_CTL</b><br>Index 1 node4 setting ( channel 0' and channel 1' mix logic )<br>0:and<br>1:or<br>2:xor<br>3:add in byte<br>4:add in word (32bit)<br>5:multiply in byte<br>6:multiply in word (32bit)                                                                                                                                                                 |

| Offset: 0xBC |                |                 | Register Name: MP_ROPIDX1CTL_REG                                                                                                      |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                           |
|              |                |                 | 7:channel 0' sub channel 1' in byte<br>8:channel 0' sub channel 1' in word (32bit)<br>Other: Reserved                                 |
| 5            | R/W            | 0               | <b>NOD3_CTL</b><br>Index 1 node3 setting ( channel 2' not logic )<br>0:by-pass<br>1:not                                               |
| 4            | R/W            | 0               | <b>NOD2_CTL</b><br>Index 1 node2 setting ( channel 1' not logic )<br>0:by-pass<br>1:not                                               |
| 3            | R/W            | 0               | <b>NOD1_CTL</b><br>Index 1 node1 setting ( channel 0' not logic)<br>0:by-pass<br>1:not                                                |
| 2:0          | R/W            | 0               | <b>NOD0_CTL</b><br>Index 1 node0 setting ( sorting control )<br>0:012<br>1:021<br>2:102<br>3:120<br>4:201<br>5:210<br>Other: Reserved |

Note: the result of the add or multiply operation will select the high 8 (byte operation) or 32bits (word operation).

### 3.1.4.22. ALPHA / COLOR KEY CONTROL REGISTER

| Offset: 0xC0 |                |                 | Register Name: MP_ALPHACKCTL_REG |
|--------------|----------------|-----------------|----------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>ex | Description                      |
| 31:11        | /              | /               | /                                |
| 10           | R/W            | 0               | <b>CK_REDCON</b>                 |

| Offset: 0xC0 |                |                 | Register Name: MP_ALPHACKCTL_REG                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|              |                |                 | <p>Red control condition</p> <p>0: if (R value of ck min color) &lt;= (R value of layer0) &lt;= (R value of ck max color),<br/> The red control condition is true, else the condition is false.</p> <p>1: if (R value of ck min color) &gt; (R value of layer0) or<br/> (R value of layer0) &gt; (R value of ck max color),<br/> The red control condition is true, else the condition is false.</p>                                 |
| 9            | R/W            | 0               | <p><b>CK_GREENCON</b></p> <p>Green control condition</p> <p>0: if (G value of ck min color) &lt;= (G value of layer0) &lt;= (G value of ck max color),<br/> The green control condition is true, else the condition is false.</p> <p>1: if (G value of ck min color) &gt; (G value of layer0) or<br/> (G value of layer0) &gt; (G value of ck max color),<br/> The green control condition is true, else the condition is false.</p> |
| 8            | R/W            | 0               | <p><b>CK_BLUECON</b></p> <p>Blue control condition</p> <p>0: if (B value of ck min color) &lt;= (B value of layer0) &lt;= (B value of ck max color),<br/> The blue control condition is true, else the condition is false.</p> <p>1: if (B value of ck min color) &gt; (B value of layer0) or<br/> (B value of layer0) &gt; (B value of ck max color),<br/> The blue control condition is true, else the condition is false.</p>     |
| 7:5          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4            | R/W            | 0               | <p><b>PRI</b></p> <p>Priority selection</p> <p>0: ROP output channel is higher than channel 3<br/> 1: Channel 3 is higher than ROP output channel</p>                                                                                                                                                                                                                                                                                |
| 3            | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2:1          | R/W            | 0               | <p><b>ALPHACK_MOD</b></p> <p>Alpha / Color key mode selection</p> <p>0: alpha mode<br/> 1: color key mode, using the high priority layer as matching</p>                                                                                                                                                                                                                                                                             |

| Offset: 0xC0 |                |                 | Register Name: MP_ALPHACKCTL_REG                                                                                                                                                                                                                      |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                           |
|              |                |                 | <p>condition, if it is true, the low priority layer pass.</p> <p>2: color key mode, using the low priority layer as matching condition, if it is true, the high priority layer pass.</p> <p>3: Reserved</p>                                           |
| 0            | R/W            | 0               | <p><b>ALPHACK_EN</b><br/>Enable control<br/>0: the ROP data will by-pass the alpha/ck module<br/>1: enable</p> <p>Note: if the module is disabled, the data of channel 3 will be ignored, and only the ROP data will pass through to CSC2 module.</p> |

### 3.1.4.23. COLOR KEY MIN COLOR REGISTER

| Offset: 0xC4 |                |                 | Register Name: MP_CKMIN_REG |
|--------------|----------------|-----------------|-----------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                 |
| 31:24        | /              | /               | /                           |
| 23:16        | R/W            | 0               | <b>CKMIN_R</b><br>Red       |
| 15:8         | R/W            | 0               | <b>CKMIN_G</b><br>Green     |
| 7:0          | R/W            | 0               | <b>CKMIN_B</b><br>Blue      |

### 3.1.4.24. COLOR KEY MAX COLOR REGISTER

| Offset: 0xC8 |                |                 | Register Name: MP_CKMAX_REG |
|--------------|----------------|-----------------|-----------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                 |
| 31:24        | /              | /               | /                           |
| 23:16        | R/W            | 0               | <b>CKMAX_R</b>              |

| Offset: 0xC8 |                |                 | Register Name: MP_CKMAX_REG |
|--------------|----------------|-----------------|-----------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                 |
|              |                |                 | Red                         |
| 15:8         | R/W            | 0               | <b>CKMAX_G</b><br>Green     |
| 7:0          | R/W            | 0               | <b>CKMAX_B</b><br>Blue      |

### 3.1.4.25. FILL COLOR OF ROP OUTPUT SETTING REGISTER

| Offset: 0xCC |                |                 | Register Name: MP_ROPOUTFILLCOLOR_REG |
|--------------|----------------|-----------------|---------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                           |
| 31:24        | R/W            | 0               | Alpha                                 |
| 23:16        | R/W            | 0               | Red                                   |
| 15:8         | R/W            | 0               | Green                                 |
| 7:0          | R/W            | 0               | Blue                                  |

### 3.1.4.26. COLOR SPACE CONVERTER 2 CONTROL REGISTER

| Offset: 0xD0 |                |                 | Register Name: MP_CSC2CTL_REG                                                                                                                                                                   |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                     |
| 31:1         | /              | /               | /                                                                                                                                                                                               |
| 0            | R/W            | 0               | <b>CSC2_EN</b><br>Enable control<br>0:<br>Disable color space function, ignore the control setting, and the data flow will by-pass the module.<br>1:<br>Enable color space converting function. |

### 3.1.4.27. OUTPUT CONTROL REGISTER

| Offset: 0xE0                                                                                                               |                |                 | Register Name: MP_OUTCTL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                                        | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:12                                                                                                                      | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11:8                                                                                                                       | R/W            | 0               | <b>OUT_PS</b><br>Output data pixel sequence<br>Reference output pixel sequence table                                                                                                                                                                                                                                                                                                                                                                                               |
| 7                                                                                                                          | R/W            | 0               | <b>RND_EN</b><br>Round enable<br>0:disabled<br>1:enabled                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6:4                                                                                                                        | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0                                                                                                                        | R/W            | 0               | <b>OUT_FMT</b><br>Output data format<br>0x0: 32bpp – A8R8G8B8 or interleaved AYUV8888<br>0x1: 16bpp – A4R4G4B4<br>0x2: 16bpp – A1R5G5B5<br>0x3: 16bpp – R5G6B5<br>0x4: 16bpp – interleaved YUV422<br>0x5: planar YUV422 (UV combined)<br>0x6: planar YUV422<br>0x7: 8bpp – MONO<br>0x8: 4bpp – MONO<br>0x9: 2bpp – MONO<br>0xa: 1bpp – MONO<br>0xb: planar YUV420 (UV combined)<br>0xc: planar YUV420<br>0xd: planar YUV411 (UV combined)<br>0xe: planar YUV411<br>Other: reserved |
| Note: In all YUV output data format, the CSC2 must be enabled, otherwise the output data mode will be 32bpp A8R8G8B8 mode. |                |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Output data mode and output data ports mapping:

| Output data mode                 | Output data channel selection |           |           |
|----------------------------------|-------------------------------|-----------|-----------|
|                                  | Channel 0                     | Channel 1 | Channel 2 |
| A8R8G8B8 or interleaved AYUV8888 | ARGB or AYUV                  | Ignore    | Ignore    |
| A4R4G4B4                         | ARGB                          | Ignore    | Ignore    |
| A1R5G5B5                         | ARGB                          | Ignore    | Ignore    |
| R5G6B5                           | RGB                           | Ignore    | Ignore    |
| interleaved YUV422               | YUV                           | Ignore    | Ignore    |
| planar YUV422 (UV combined)      | Y                             | UV        | Ignore    |
| planar YUV422                    | Y                             | U         | V         |
| 8bpp – MONO                      | MONO                          | Ignore    | Ignore    |
| 4bpp – MONO                      | MONO                          | Ignore    | Ignore    |
| 2bpp – MONO                      | MONO                          | Ignore    | Ignore    |
| 1bpp – MONO                      | MONO                          | Ignore    | Ignore    |
| planar YUV420 (UV combined)      | Y                             | UV        | Ignore    |
| planar YUV420                    | Y                             | U         | V         |
| planar YUV411 (UV combined)      | Y                             | UV        | Ignore    |
| planar YUV411                    | Y                             | U         | V         |

### 3.1.4.28. OUTPUT SIZE REGISTER

| Offset: 0xE8 |                |             | Register Name: MP_OUTSIZE_REG                                                       |
|--------------|----------------|-------------|-------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/Hex | Description                                                                         |
| 31:29        | /              | /           | /                                                                                   |
| 28:16        | R/W            | 0           | <b>OUT_HEIGHT</b><br>Height<br>The value add 1 equal the actual output image height |
| 15:11        | /              | /           | /                                                                                   |
| 12:0         | R/W            | 0           | <b>OUT_WIDTH</b><br>Width<br>The value add 1 equal the actual output image width    |

### 3.1.4.29. OUTPUT ADDRESS HIGH 4BITS REGISTER

| Offset: 0xEC |                |             | Register Name: MP_OUTH4ADD_REG |
|--------------|----------------|-------------|--------------------------------|
| Bit          | Read/W<br>rite | Default/Hex | Description                    |
| 31:20        | /              | /           | /                              |
| 19:16        | R/W            | 0           | <b>OUTCH2_H4ADD</b>            |

| Offset: 0xEC |                |                     | Register Name: MP_OUTH4ADD_REG                                        |
|--------------|----------------|---------------------|-----------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/H<br>e<br>x | Description                                                           |
|              |                |                     | Output channel 2<br>High 4bits address in bits                        |
| 15:12        | /              | /                   | /                                                                     |
| 11:8         | R/W            | 0                   | <b>OUTCH1_H4ADD</b><br>Output channel 1<br>High 4bits address in bits |
| 7:4          | /              | /                   | /                                                                     |
| 3:0          | R/W            | 0                   | <b>OUTCH0_H4ADD</b><br>Output channel 0<br>High 4bits address in bits |

### 3.1.4.30. OUTPUT ADDRESS LOW 32BITS REGISTER

| Offset:<br><br>Out channel 0:0xF0<br>Out channel 1:0xF4<br>Out channel 2:0xF8 |                |                     | Register Name: MP_OUTL32ADD_REG                                   |
|-------------------------------------------------------------------------------|----------------|---------------------|-------------------------------------------------------------------|
| Bit                                                                           | Read/W<br>rite | Default/H<br>e<br>x | Description                                                       |
| 31:0                                                                          | R/W            | 0                   | <b>OUT_L32ADD</b><br>Output channel<br>Low 32bits address in bits |

### 3.1.4.31. OUTPUT LINE WIDTH REGISTER

| Offset:<br><br>Out channel 0:0x100<br>Out channel 1:0x104<br>Out channel 2:0x108 |                |                     | Register Name: MP_OUTLINEWIDTH_REG     |
|----------------------------------------------------------------------------------|----------------|---------------------|----------------------------------------|
| Bit                                                                              | Read/W<br>rite | Default/H<br>e<br>x | Description                            |
| 31:0                                                                             | R/W            | 0                   | <b>OUT_LINEWIDTH</b><br>Output channel |

| <b>Offset:</b><br><b>Out channel 0:0x100</b><br><b>Out channel 1:0x104</b><br><b>Out channel 2:0x108</b> |                |                 | <b>Register Name: MP_OUTLINEWIDTH_REG</b> |
|----------------------------------------------------------------------------------------------------------|----------------|-----------------|-------------------------------------------|
| Bit                                                                                                      | Read/W<br>rite | Default/H<br>ex | Description                               |
|                                                                                                          |                |                 | Line width in bits                        |

### 3.1.4.32. OUTPUT ALPHA CONTROL REGISTER

| <b>Offset: 0x120</b> |                |                 | <b>Register Name: MP_OUTALPHACTL_REG</b>                                                                                                                                                                                                   |
|----------------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                |
| 31:24                | R/W            | 0               | <b>IMG_ALPHA</b><br>Output image area alpha value, the image area include A0,A1 and overlapping area A2.                                                                                                                                   |
| 23:16                | R/W            | 0               | <b>NONIMG_ALPHA</b><br>Output non-image area alpha value, the non-image area means the pure fill color area.                                                                                                                               |
| 15:8                 | /              | /               | /                                                                                                                                                                                                                                          |
| 7:6                  | R/W            | 0               | <b>A2ALPHACTL</b><br>A2 area alpha value control<br>0: using A0 self pixel alpha (A0pA)<br>1: using A1 self pixel alpha (A1pA)<br>2: the alpha value = A0pA + A1pA * ( 1 - A0pA )<br>3: using the Output image area alpha value (bit31:24) |
| 5:4                  | R/W            | 0               | <b>A3ALPHACTL</b><br>A3 area alpha value control<br>0: 0xff<br>1: using the Output non-image area alpha value (bit23:16)<br>Other: reserved                                                                                                |
| 3:2                  | R/W            | 0               | <b>A1ALPHACTL</b><br>A1 area alpha value control<br>0: using A1 self pixel alpha<br>1: using the Output image area alpha value (bit31:24)<br>Other: reserved                                                                               |
| 1:0                  | R/W            | 0               | <b>A0ALPHACTL</b>                                                                                                                                                                                                                          |

| Offset: 0x120 |                |                     | Register Name: MP_OUTALPHACTL_REG                                                                                                       |
|---------------|----------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/H<br>e<br>x | Description                                                                                                                             |
|               |                |                     | A0 area alpha value control<br>0: using A0 self pixel alpha<br>1: using the Output image area alpha value (bit31:24)<br>Other: reserved |

Description:

There is some area in output memory block:

The alpha / color key module is enabled:

Only the high priority image area is called A0

Only the low priority image area is called A1

The high priority and low priority mixed image area is called A2

The other area is called A3

And the A0,A1,A2 is called image area, the A3 is called non-image area.

The alpha / color key module is disabled:

Only the ROP output image area is called A0, A0 is called image area.

The other area is called A3, A3 is called non-image area.

Note: the register setting is only valid in ARGB or AYUV mode.

### 3.1.4.33. CSC0/1 Y/G COEFFICIENT REGISTER

| Offset:<br><br><b>G/Y component: 0x180</b><br><b>R/U component: 0x184</b><br><b>B/V component: 0x188</b> |                |                           | Register Name: MP_ICSCYGCOEF_REG                                                                |
|----------------------------------------------------------------------------------------------------------|----------------|---------------------------|-------------------------------------------------------------------------------------------------|
| Bit                                                                                                      | Read/W<br>rite | Default/H<br>e<br>x       | Description                                                                                     |
| 31:29                                                                                                    | /              | /                         | /                                                                                               |
| 28:16                                                                                                    | R/W            | 0x4a7<br>0x1e6f<br>0x1cbf | <b>CSC1_YGCOEF</b><br>the Y/G coefficient for CSC1<br>the value equals to coefficient* $2^{10}$ |
| 15:13                                                                                                    | /              | /                         | /                                                                                               |

| <b>Offset:</b><br><b>G/Y component: 0x180</b><br><b>R/U component: 0x184</b><br><b>B/V component: 0x188</b> |                |                           | <b>Register Name: MP_ICSCYGCOEF_REG</b>                                                         |
|-------------------------------------------------------------------------------------------------------------|----------------|---------------------------|-------------------------------------------------------------------------------------------------|
| Bit                                                                                                         | Read/W<br>rite | Default/H<br>ex           | Description                                                                                     |
| 12:00                                                                                                       | R/W            | 0x4a7<br>0x1e6f<br>0x1cbf | <b>CSC0_YGCOEF</b><br>the Y/G coefficient for CSC0<br>the value equals to coefficient* $2^{10}$ |

### 3.1.4.34. CSC0/1 Y/G CONSTANT REGISTER

| <b>Offset: 0x18C</b> |                |                 | <b>Register Name: MP_ICSCYGCONS_REG</b>                                                   |
|----------------------|----------------|-----------------|-------------------------------------------------------------------------------------------|
| Bit                  | Read/W<br>rite | Default/H<br>ex | Description                                                                               |
| 31:30                | /              | /               | /                                                                                         |
| 29:16                | R/W            | 0x877           | <b>CSC1_YGCONS</b><br>the Y/G constant for CSC1<br>the value equals to coefficient* $2^4$ |
| 15:14                | /              | /               | /                                                                                         |
| 13:00                | R/W            | 0x877           | <b>CSC0_YGCONS</b><br>the Y/G constant for CSC0<br>the value equals to coefficient* $2^4$ |

### 3.1.4.35. CSC0/1 U/R COEFFICIENT REGISTER

| <b>Offset:</b><br><b>G/Y component: 0x190</b><br><b>R/U component: 0x194</b><br><b>B/V component: 0x198</b> |                |                 | <b>Register Name: MP_ICSCURCOEF_REG</b>            |
|-------------------------------------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------|
| Bit                                                                                                         | Read/W<br>rite | Default/H<br>ex | Description                                        |
| 31:29                                                                                                       | /              | /               | /                                                  |
| 28:16                                                                                                       | R/W            | 0x4a7<br>0x00   | <b>CSC1_URCOEF</b><br>the U/R coefficient for CSC1 |

| <b>Offset:</b><br><b>G/Y component: 0x190</b><br><b>R/U component: 0x194</b><br><b>B/V component: 0x198</b> |                        |                         | <b>Register Name: MP_ICSCURCOEF_REG</b>                                                         |
|-------------------------------------------------------------------------------------------------------------|------------------------|-------------------------|-------------------------------------------------------------------------------------------------|
| <b>Bit</b>                                                                                                  | <b>Read/W<br/>rite</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                                              |
|                                                                                                             |                        | 0x662                   | the value equals to coefficient* $2^{10}$                                                       |
| 15:13                                                                                                       | /                      | /                       | /                                                                                               |
| 12:00                                                                                                       | R/W                    | 0x4a7<br>0x00<br>0x662  | <b>CSC0_URCOEF</b><br>the U/R coefficient for CSC0<br>the value equals to coefficient* $2^{10}$ |

### 3.1.4.36. CSC0/1 U/R CONSTANT REGISTER

| <b>Offset: 0x19C</b> |                        |                         | <b>Register Name: MP_ICSCURCONS_REG</b>                                                   |
|----------------------|------------------------|-------------------------|-------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/W<br/>rite</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                                        |
| 31:30                | /                      | /                       | /                                                                                         |
| 29:16                | R/W                    | 0x3211                  | <b>CSC1_URCONS</b><br>the U/R constant for CSC1<br>the value equals to coefficient* $2^4$ |
| 15:14                | /                      | /                       | /                                                                                         |
| 13:00                | R/W                    | 0x3211                  | <b>CSC0_URCONS</b><br>the U/R constant for CSC0<br>the value equals to coefficient* $2^4$ |

### 3.1.4.37. CSC0/1 V/B COEFFICIENT REGISTER

| <b>Offset:</b><br><b>G/Y component: 0x1A0</b><br><b>R/U component: 0x1A4</b><br><b>B/V component: 0x1A8</b> |                        |                         | <b>Register Name: MP_ICSCVBCOEF_REG</b> |
|-------------------------------------------------------------------------------------------------------------|------------------------|-------------------------|-----------------------------------------|
| <b>Bit</b>                                                                                                  | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                      |
| 31:29                                                                                                       | /                      | /                       | /                                       |
| 28:16                                                                                                       | R/W                    | 0x4a7                   | <b>CSC1_VBCOEF</b>                      |

| <b>Offset:</b><br><b>G/Y component: 0x1A0</b><br><b>R/U component: 0x1A4</b><br><b>B/V component: 0x1A8</b> |                |                        | <b>Register Name: MP_ICSCVBCOEF_REG</b>                                                         |
|-------------------------------------------------------------------------------------------------------------|----------------|------------------------|-------------------------------------------------------------------------------------------------|
| Bit                                                                                                         | Read/W<br>rite | Default/<br>Hex        | Description                                                                                     |
|                                                                                                             |                | 0x812<br>0x00          | the V/B coefficient for CSC1<br>the value equals to coefficient* $2^{10}$                       |
| 15:13                                                                                                       | /              | /                      | /                                                                                               |
| 12:00                                                                                                       | R/W            | 0x4a7<br>0x812<br>0x00 | <b>CSC0_VBCOEF</b><br>the V/B coefficient for CSC0<br>the value equals to coefficient* $2^{10}$ |

### 3.1.4.38. CSC0/1 V/B CONSTANT REGISTER

| <b>Offset: 0x1AC</b> |                |                 | <b>Register Name: MP_ICSCVBCONS_REG</b>                                                   |
|----------------------|----------------|-----------------|-------------------------------------------------------------------------------------------|
| Bit                  | Read/W<br>rite | Default/<br>Hex | Description                                                                               |
| 31:30                | /              | /               | /                                                                                         |
| 29:16                | R/W            | 0x2eb1          | <b>CSC1_VBCONS</b><br>the V/B constant for CSC1<br>the value equals to coefficient* $2^4$ |
| 15:14                | /              | /               | /                                                                                         |
| 13:00                | R/W            | 0x2eb1          | <b>CSC0_VBCONS</b><br>the V/B constant for CSC0<br>the value equals to coefficient* $2^4$ |

### 3.1.4.39. CSC2 Y/G COEFFICIENT REGISTER

| <b>Offset:</b><br><b>G/Y component: 0x1C0</b><br><b>R/U component: 0x1C4</b><br><b>B/V component: 0x1C8</b> |                |                 | <b>Register Name: MP_OCSCYGCoeff_REG</b> |
|-------------------------------------------------------------------------------------------------------------|----------------|-----------------|------------------------------------------|
| Bit                                                                                                         | Read/W<br>rite | Default/<br>Hex | Description                              |
| 31:13                                                                                                       | /              | /               | /                                        |

| <b>Offset:</b><br><b>G/Y component: 0x1C0</b><br><b>R/U component: 0x1C4</b><br><b>B/V component: 0x1C8</b> |                |                 | <b>Register Name: MP_OCSCYGCOEF_REG</b>                                                |
|-------------------------------------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------------------|
| Bit                                                                                                         | Read/W<br>rite | Default/<br>Hex | Description                                                                            |
| 12:00                                                                                                       | R/W            |                 | <b>CSC2_YGCOEF</b><br>the Y/G coefficient<br>the value equals to coefficient* $2^{10}$ |

### 3.1.4.40. CSC2 Y/G CONSTANT REGISTER

| <b>Offset: 0x1CC</b> |                |                 | <b>Register Name: MP_OCSCYGCONS_REG</b>                                          |
|----------------------|----------------|-----------------|----------------------------------------------------------------------------------|
| Bit                  | Read/<br>Write | Default/He<br>x | Description                                                                      |
| 31:14                | /              | /               | /                                                                                |
| 13:00                | R/W            |                 | <b>CSC2_YGCONS</b><br>the Y/G constant<br>the value equals to coefficient* $2^4$ |

### 3.1.4.41. CSC2 U/R COEFFICIENT REGISTER

| <b>Offset:</b><br><b>G/Y component: 0x1D0</b><br><b>R/U component: 0x1D4</b><br><b>B/V component: 0x1D8</b> |                |                 | <b>Register Name: MP_OCSURCOEF_REG</b>                                                 |
|-------------------------------------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------------------|
| Bit                                                                                                         | Read/W<br>rite | Default/<br>Hex | Description                                                                            |
| 31:13                                                                                                       | /              | /               | /                                                                                      |
| 12:00                                                                                                       | R/W            |                 | <b>CSC2_URCOEF</b><br>the U/R coefficient<br>the value equals to coefficient* $2^{10}$ |

### 3.1.4.42. CSC2 U/R CONSTANT REGISTER

| Offset: 0x1DC |                |                 | Register Name: MP_OCSCURCONS_REG                                                         |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                              |
| 31:14         | /              | /               | /                                                                                        |
| 13:00         | R/W            |                 | <b>CSC2_URCONS</b><br>the U/R constant<br>the value equals to coefficient*2 <sup>4</sup> |

### 3.1.4.43. CSC2 V/B COEFFICIENT REGISTER

| Offset:<br><br><b>G/Y component: 0x1E0</b><br><b>R/U component: 0x1E4</b><br><b>B/V component: 0x1E8</b> | Register Name: MP_OCSCVBCOEF_REG |                 |                                                                                              |
|----------------------------------------------------------------------------------------------------------|----------------------------------|-----------------|----------------------------------------------------------------------------------------------|
| Bit                                                                                                      | Read/W<br>rite                   | Default/<br>Hex | Description                                                                                  |
| 31:13                                                                                                    | /                                | /               | /                                                                                            |
| 12:00                                                                                                    | R/W                              |                 | <b>CSC2_VBCOEF</b><br>the V/B coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

### 3.1.4.44. CSC2 V/B CONSTANT REGISTER

| Offset: 0x1EC |                |                 | Register Name: MP_OCSCVBCONS_REG                                                         |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                              |
| 31:30         | /              | /               | /                                                                                        |
| 13:00         | R/W            |                 | <b>CSC2_VBCONS</b><br>the V/B constant<br>the value equals to coefficient*2 <sup>4</sup> |

### 3.1.4.45. SCALING HORIZONTAL FILTERING COEFFICIENT RAM BLOCK

| Offset:<br><b>0x200 – 0x27C</b> |                |                 |                                                                       |
|---------------------------------|----------------|-----------------|-----------------------------------------------------------------------|
| Bit                             | Read/W<br>rite | Default/<br>Hex | Description                                                           |
| 31:24                           | R/W            | 0               | Horizontal tap3 coefficient<br>The value equals to coefficient* $2^6$ |
| 23:16                           | R/W            | 0               | Horizontal tap2 coefficient<br>The value equals to coefficient* $2^6$ |
| 15:08                           | R/W            | 0               | Horizontal tap1 coefficient<br>The value equals to coefficient* $2^6$ |
| 07:00                           | R/W            | 0               | Horizontal tap0 coefficient<br>The value equals to coefficient* $2^6$ |

### 3.1.4.46. SCALING VERTICAL FILTERING COEFFICIENT RAM BLOCK

| Offset:<br><b>0x280 – 0x2FC</b> |                |                 |                                                                     |
|---------------------------------|----------------|-----------------|---------------------------------------------------------------------|
| Bit                             | Read/W<br>rite | Default/<br>Hex | Description                                                         |
| 31:24                           | R/W            | 0               | Vertical tap3 coefficient<br>The value equals to coefficient* $2^6$ |
| 23:16                           | R/W            | 0               | Vertical tap2 coefficient<br>The value equals to coefficient* $2^6$ |
| 15:08                           | R/W            | 0               | Vertical tap1 coefficient<br>The value equals to coefficient* $2^6$ |
| 07:00                           | R/W            | 0               | Vertical tap0 coefficient<br>The value equals to coefficient* $2^6$ |

### 3.1.4.47. PALETTE TABLE

| Offset:<br><b>0x400-0x7FF</b> |                |                 |             |
|-------------------------------|----------------|-----------------|-------------|
| Bit                           | Read/W<br>rite | 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  |

### 3.1.4.48. INPUT DATA PIXEL SEQUENCE TABLE

#### 1-bpp mode

PS=xx00

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

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

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

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  |

**2-bpp mode**

PS=xx00

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

PS=xx01

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

PS=xx10

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

PS=xx11

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

**4-bpp mode**

PS=xx00

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 |    |
| P03 |    | P02 |    | P01 |    | P00 |    | P07 |    | P06 |    | P05 |    | P04 |    |

PS=xx01

Bit

|     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |
|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|
| 31  | 30 | 29  | 28 | 27  | 26 | 25  | 24 | 23  | 22 | 21  | 20 | 19  | 18 | 17  | 16 |
| P06 |    | P07 |    | P04 |    | P05 |    | P03 |    | P00 |    | P01 |    | P02 |    |
| P02 |    | P03 |    | P00 |    | P01 |    | P00 |    | P01 |    | P02 |    | P03 |    |

PS=xx10

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

PS=xx11

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

### 8-bpp mode

PS=xx00 / xx11

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| P3 |    |    |    |    |    |    |    | P2 |    |    |    |    |    |    |    |
| P1 |    |    |    |    |    |    |    | P0 |    |    |    |    |    |    |    |

PS=xx01 / xx10

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| P0 |    |    |    |    |    |    |    | P1 |    |    |    |    |    |    |    |
| P2 |    |    |    |    |    |    |    | P3 |    |    |    |    |    |    |    |

### 16-bpp @ A4R4G4B4 mode

PS=0x00

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| A1 |    |    |    | R1 |    |    |    | G1 |    |    |    | B1 |    |    |    |
| A0 |    |    |    | R0 |    |    |    | G0 |    |    |    | B0 |    |    |    |

PS=0x01

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| A0 |    |    |    | R0 |    |    |    | G0 |    |    |    | B0 |    |    |    |
| A1 |    |    |    | R1 |    |    |    | G1 |    |    |    | B1 |    |    |    |

PS=0x10

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| B1 |    |    |    | G1 |    |    |    | R1 |    |    |    | A1 |    |    |    |
| B0 |    |    |    | G0 |    |    |    | R0 |    |    |    | A0 |    |    |    |

PS=0x11

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| B0 |    |    |    | G0 |    |    |    | R0 |    |    |    | A0 |    |    |    |
| B1 |    |    |    | G1 |    |    |    | R1 |    |    |    | A1 |    |    |    |

PS=1xxx, the R component is swapped with B component

### 16-bpp @ A1R5G5B5 mode

PS=0x00

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| A1 |    |    |    | R1 |    |    |    | G1 |    |    |    | B1 |    |    |    |
| A0 |    |    |    | R0 |    |    |    | G0 |    |    |    | B0 |    |    |    |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

PS=0x01

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| A0 |    |    |    | R0 |    |    |    | G0 |    |    |    | B0 |    |    |    |
| A1 |    |    |    | R1 |    |    |    | G1 |    |    |    | B1 |    |    |    |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

PS=0x10

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| B1 |    |    |    | G1 |    |    |    | R1 |    |    |    | A1 |    |    |    |
| B0 |    |    |    | G0 |    |    |    | R0 |    |    |    | A0 |    |    |    |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

PS=0x11

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| B0 |    |    |    | G0 |    |    |    | R0 |    |    |    | A0 |    |    |    |

| B1 | G1 |    |    |    |    |    |    |    | R1 |    |    |    |    |    |    |  | A1 |  |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|----|--|--|--|
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |  |    |  |  |  |

PS=1xxx, the R component is swapped with B component

### 16-bpp @ R5G6B5 mode

PS=0x00

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R1 | G1 |    |    |    |    |    |    |    |    |    | B1 |    |    |    |    |
| R0 | G0 |    |    |    |    |    |    |    |    |    | B0 |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |

PS=0x01

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R0 | G0 |    |    |    |    |    |    |    |    |    | B0 |    |    |    |    |
| R1 | G1 |    |    |    |    |    |    |    |    |    | B1 |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |

PS=1xxx, the R component is swapped with B component

### 16-bpp @ interleaved YUV422 mode

PS=xx00 / xx11

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| V0 | Y1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| U0 | Y0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |

PS=xx01 / xx10

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Y1 | V0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Y0 | U0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |

### 16-bpp @ U8V8 mode

PS=xxxx

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| V1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| V0                                              | U0 |
|-------------------------------------------------|----|
| 15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 |    |

### 32-bpp ARGB or AYUV mode

PS=xx00 / xx01

Bit

|       |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|
| 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| A     |    |    |    |    |    |    |    | R (Y) |    |    |    |    |    |    |    |
| G (U) |    |    |    |    |    |    |    | B (V) |    |    |    |    |    |    |    |
| 15    | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07    | 06 | 05 | 04 | 03 | 02 | 01 | 00 |

PS=xx10 / xx11

Bit

|       |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|
| 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| B (V) |    |    |    |    |    |    |    | G (U) |    |    |    |    |    |    |    |
| R (Y) |    |    |    |    |    |    |    | A     |    |    |    |    |    |    |    |
| 15    | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07    | 06 | 05 | 04 | 03 | 02 | 01 | 00 |

PS=1xxx, the R component is swapped with B component

### 3.1.4.49. OUTPUT DATA PIXEL SEQUENCE

32bpp – A8R8G8B8 or interleaved AYUV8888

16bpp – A4R4G4B4

16bpp – A1R5G5B5

16bpp – R5G6B5

16bpp – interleaved YUV422

Planar YUV422 (UV combined)

8bpp – MONO

4bpp – MONO

2bpp – MONO

1bpp – MONO

Planar YUV420 (UV combined)

Planar YUV411 (UV combined)

The above 13 kinds of output format is same as respective input format PS.

Planar YUV422

Planar YUV420

Planar YUV411

The above 3 kinds of output format are the same as input 8bpp format PS.

For Allwinnertech Only

# Chapter 4 Image

This chapter introduces the image section of A20 processor, including:

- CSI0
- CSI1

Here is the CMOS sensor and TV decoder with YUV data process diagram:



## 4.1. CSI0

### 4.1.1. Overview

CSI0 features:

- 8 bits input data
- Support CCIR656 protocol for NTSC and PAL
- 3 parallel data paths for image stream parsing
- Received data double buffer support
- Parsing bayer data into planar R, G, B output to memory
- Parsing interlaced data into planar or tiled Y, Cb, Cr output to memory
- Pass raw data direct to memory
- All data transmit timing can be adjusted by software
- Support multi-channel ITU-R BT656 time-multiplexed format
- Luminance statistical value
- Support 8-bit raw data input
- Support 16-bit YUV422 data input

## 4.1.2. CSI0 Block Diagram



## 4.1.3. CSI0 Description

### 4.1.3.1. CSI DATA PORTS

|       | <b>Bayer</b>     | <b>YCbCr (YUV)</b> | <b>Interlaced</b>      | <b>Pass-through</b> |
|-------|------------------|--------------------|------------------------|---------------------|
| FIFO0 | Red pixel data   | Y pixel data       | All field 1 pixel data | All pixel data      |
| FIFO1 | Green pixel data | Cb (U) pixel data  | All field 2 pixel data | -                   |
| FIFO2 | Blue pixel data  | Cr (V) pixel data  | -                      | -                   |

### 4.1.3.2. TIMING DIAGRAM

CSI timing



Vref= positive; Href= positive



**vertical size setting**



horizontal start clock = n  
horizontal active clocks length = m

**horizontal size setting and pixel clock timing(Href= positive)**



**16bit YUV422 Timing**



**CCIR656 2 channel Timing**



CCIR656 4 channel Timing

CCIR656 Header Code

CCIR656 Header Data Bit Definition

| Data Bit      | First Word(0xFF) | Second Word(0x00) | Third Word(0x00) | Fourth Word |
|---------------|------------------|-------------------|------------------|-------------|
| CS D[9] (MSB) | 1                | 0                 | 0                | 1           |
| CS D[8]       | 1                | 0                 | 0                | F           |
| CS D[7]       | 1                | 0                 | 0                | V           |
| CS D[6]       | 1                | 0                 | 0                | H           |
| CS D[5]       | 1                | 0                 | 0                | P3          |
| CS D[4]       | 1                | 0                 | 0                | P2          |
| CS D[3]       | 1                | 0                 | 0                | P1          |
| CS D[2]       | 1                | 0                 | 0                | P0          |
| CS D[1]       | x                | x                 | x                | x           |
| CS D[0]       | x                | x                 | x                | x           |

For compatibility with an 8-bit interface, CS D[1] and CS D[0] are not defined.

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

| Decode                         | F | V | H | P3 | P2 | P1 | P0 |
|--------------------------------|---|---|---|----|----|----|----|
| 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  |

Multi-Channel:

| Condition |        |        | 656 FVH Value |   |   | SAV-EAV Code |        |       |        |      |      |      |  |
|-----------|--------|--------|---------------|---|---|--------------|--------|-------|--------|------|------|------|--|
| Field     | V-time | H-time | F             | V | H | First        | Second | Third | Fourth |      |      |      |  |
|           |        |        |               |   |   |              |        |       | Ch1    | Ch2  | Ch3  | Ch4  |  |
| EVEN      | BLANK  | EAV    | 1             | 1 | 1 | 0xFF         | 0x00   | 0x00  | 0xF0   | 0xF1 | 0xF2 | 0xF3 |  |
| EVEN      | BLANK  | SAV    | 1             | 1 | 0 | 0xFF         | 0x00   | 0x00  | 0xE0   | 0xE1 | 0xE2 | 0xE3 |  |
| EVEN      | ACTIVE | EAV    | 1             | 0 | 1 | 0xFF         | 0x00   | 0x00  | 0xD0   | 0xD1 | 0xD2 | 0xD3 |  |
| EVEN      | ACTIVE | SAV    | 1             | 0 | 0 | 0xFF         | 0x00   | 0x00  | 0xC0   | 0xC1 | 0xC2 | 0xC3 |  |
| ODD       | BLANK  | EAV    | 0             | 1 | 1 | 0xFF         | 0x00   | 0x00  | 0xB0   | 0xB1 | 0xB2 | 0xB3 |  |
| ODD       | BLANK  | SAV    | 0             | 1 | 0 | 0xFF         | 0x00   | 0x00  | 0xA0   | 0xA1 | 0xA2 | 0xA3 |  |
| ODD       | ACTIVE | EAV    | 0             | 0 | 1 | 0xFF         | 0x00   | 0x00  | 0x90   | 0x91 | 0x92 | 0x93 |  |
| ODD       | ACTIVE | SAV    | 0             | 0 | 0 | 0xFF         | 0x00   | 0x00  | 0x80   | 0x81 | 0x82 | 0x83 |  |

#### 4.1.4. CSI0 Register List

| Module Name | Base Address |
|-------------|--------------|
| CSI0        | 0x01C09000   |

| Register Name       | Offset | Description                                           |
|---------------------|--------|-------------------------------------------------------|
| CSI0_EN_REG         | 0X000  | CSI enable register                                   |
| CSI0_CFG_REG        | 0X004  | CSI configuration register                            |
| CSI0_CAP_REG        | 0X008  | CSI capture control register                          |
| CSI0_SCALE_REG      | 0X00C  | CSI scale register                                    |
| CSI0_C0_F0_BUFA_REG | 0X010  | CSI Channel_0 FIFO 0 output buffer-A address register |
| CSI0_C0_F0_BUFB_REG | 0X014  | CSI Channel_0 FIFO 0 output buffer-B address register |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                                    |
|----------------------|---------------|-------------------------------------------------------|
| CSI0_C0_F1_BUFA_REG  | 0X018         | CSI Channel_0 FIFO 1 output buffer-A address register |
| CSI0_C0_F1_BUFB_REG  | 0X01C         | CSI Channel_0 FIFO 1 output buffer-B address register |
| CSI0_C0_F2_BUFA_REG  | 0X020         | CSI Channel_0 FIFO 2 output buffer-A address register |
| CSI0_C0_F2_BUFB_REG  | 0X024         | CSI Channel_0 FIFO 2 output buffer-B address register |
| CSI0_C0_BUF_CTL_REG  | 0X028         | CSI Channel_0 output buffer control register          |
| CSI0_C0_BUF_STA_REG  | 0X02C         | CSI Channel_0 status register                         |
| CSI0_C0_INT_EN_REG   | 0X030         | CSI Channel_0 interrupt enable register               |
| CSI0_C0_INT_STA_REG  | 0X034         | CSI Channel_0 interrupt status register               |
| CSI0_C0_HSIZE_REG    | 0X040         | CSI Channel_0 horizontal size register                |
| CSI0_C0_VSIZE_REG    | 0X044         | CSI Channel_0 vertical size register                  |
| CSI0_C0_BUF_LEN_REG  | 0X048         | CSI Channel_0 line buffer length register             |
| CSI0_C1_F0_BUFA_REG  | 0X110         | CSI Channel_1 FIFO 0 output buffer-A address register |
| CSI0_C1_F0_BUFB_REG  | 0X114         | CSI Channel_1 FIFO 0 output buffer-B address register |
| CSI0_C1_F1_BUFA_REG  | 0X118         | CSI Channel_1 FIFO 1 output buffer-A address register |
| CSI0_C1_F1_BUFB_REG  | 0X11C         | CSI Channel_1 FIFO 1 output buffer-B address register |
| CSI0_C1_F2_BUFA_REG  | 0X120         | CSI Channel_1 FIFO 2 output buffer-A address register |
| CSI0_C1_F2_BUFB_REG  | 0X124         | CSI Channel_1 FIFO 2 output buffer-B address register |
| CSI0_C1_BUF_CTL_REG  | 0X128         | CSI Channel_1 output buffer control register          |
| CSI0_C1_BUF_STA_REG  | 0X12C         | CSI Channel_1 status register                         |
| CSI0_C1_INT_EN_REG   | 0X130         | CSI Channel_1 interrupt enable register               |
| CSI0_C1_INT_STA_REG  | 0X134         | CSI Channel_1 interrupt status register               |
| CSI0_C1_HSIZE_REG    | 0X140         | CSI Channel_1 horizontal size register                |
| CSI0_C1_VSIZE_REG    | 0X144         | CSI Channel_1 vertical size register                  |
| CSI0_C1_BUF_LEN_REG  | 0X148         | CSI Channel_1 line buffer length register             |
| CSI0_C2_F0_BUFA_REG  | 0X210         | CSI Channel_2 FIFO 0 output buffer-A address register |
| CSI0_C2_F0_BUFB_REG  | 0X214         | CSI Channel_2 FIFO 0 output buffer-B address register |
| CSI0_C2_F1_BUFA_REG  | 0X218         | CSI Channel_2 FIFO 1 output buffer-A address register |
| CSI0_C2_F1_BUFB_REG  | 0X21C         | CSI Channel_2 FIFO 1 output buffer-B address register |
| CSI0_C2_F2_BUFA_REG  | 0X220         | CSI Channel_2 FIFO 2 output buffer-A address register |
| CSI0_C2_F2_BUFB_REG  | 0X224         | CSI Channel_2 FIFO 2 output buffer-B address register |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                                    |
|----------------------|---------------|-------------------------------------------------------|
| CSI0_C2_BUF_CTL_REG  | 0X228         | CSI Channel_2 output buffer control register          |
| CSI0_C2_BUF_STA_REG  | 0X22C         | CSI Channel_2 status register                         |
| CSI0_C2_INT_EN_REG   | 0X230         | CSI Channel_2 interrupt enable register               |
| CSI0_C2_INT_STA_REG  | 0X234         | CSI Channel_2 interrupt status register               |
| CSI0_C2_HSIZE_REG    | 0X240         | CSI Channel_2 horizontal size register                |
| CSI0_C2_VSIZE_REG    | 0X244         | CSI Channel_2 vertical size register                  |
| CSI0_C2_BUF_LEN_REG  | 0X248         | CSI Channel_2 line buffer length register             |
| CSI0_C3_F0_BUFA_REG  | 0X310         | CSI Channel_3 FIFO 0 output buffer-A address register |
| CSI0_C3_F0_BUFB_REG  | 0X314         | CSI Channel_3 FIFO 0 output buffer-B address register |
| CSI0_C3_F1_BUFA_REG  | 0X318         | CSI Channel_3 FIFO 1 output buffer-A address register |
| CSI0_C3_F1_BUFB_REG  | 0X31C         | CSI Channel_3 FIFO 1 output buffer-B address register |
| CSI0_C3_F2_BUFA_REG  | 0X320         | CSI Channel_3 FIFO 2 output buffer-A address register |
| CSI0_C3_F2_BUFB_REG  | 0X324         | CSI Channel_3 FIFO 2 output buffer-B address register |
| CSI0_C3_BUF_CTL_REG  | 0X328         | CSI Channel_3 output buffer control register          |
| CSI0_C3_BUF_STA_REG  | 0X32C         | CSI Channel_3 status register                         |
| CSI0_C3_INT_EN_REG   | 0X330         | CSI Channel_3 interrupt enable register               |
| CSI0_C3_INT_STA_REG  | 0X334         | CSI Channel_3 interrupt status register               |
| CSI0_C3_HSIZE_REG    | 0X340         | CSI Channel_3 horizontal size register                |
| CSI0_C3_VSIZE_REG    | 0X344         | CSI Channel_3 vertical size register                  |
| CSI0_C3_BUF_LEN_REG  | 0X348         | CSI Channel_3 line buffer length register             |

## 4.1.5. CSI0 Register Description

### 4.1.5.1. CSI ENABLE REGISTER

| Offset: 0x0000 |                |             | Register Name: CSI0_EN_REG |
|----------------|----------------|-------------|----------------------------|
| Bit            | Read/<br>Write | Default/Hex | Description                |
| 31:1<br>0      | /              | /           | /                          |

| Offset: 0x0000 |                |                 | Register Name: CSI0_EN_REG                                                          |
|----------------|----------------|-----------------|-------------------------------------------------------------------------------------|
| Bit            | Read/<br>Write | Default/He<br>x | Description                                                                         |
| 9              | R/W            | 0               | PCLK_CNT<br>Pclk count per frame                                                    |
| 8              | R/W            | 0               | LUMA_EN<br>Luma enable                                                              |
| 7:5            | /              | /               | /                                                                                   |
| 4              | R/W            | 0               | NON16_ADD<br>Non-16 add 0x00                                                        |
| 3              | R/W            | 0               | RD_FIFO_EN<br>Read fifo [3]fifo enable, fifo address[01c09800~01c09ffc]             |
| 2              | R/W            | 0               | FIELD_REV<br>Ccir656 field_reverse                                                  |
| 1              | /              | /               | /                                                                                   |
| 0              | R/W            | 0               | CSI_EN<br>Enable<br>0: Reset and disable the CSI module<br>1: Enable the CSI module |

#### 4.1.5.2. CSI CONFIGURATION REGISTER

| Offset Address: 0X0004 |                |                 | Register Name: CSI0_CFG_REG                                                                                                                                                                                            |
|------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                            |
| 31:23                  | /              | /               | /                                                                                                                                                                                                                      |
| 22:20                  | R/W            | 3               | INPUT_FMT<br>Input data format<br>000: RAW stream<br>001: reserved<br>010: CCIR656(one channel)<br>011: YUV422<br>100: YUV422 16bit data bus<br>101: two channel CCIR656<br>110: reserved<br>111: four channel CCIR656 |

| Offset Address: 0X0004 |                |                 | Register Name: CSI0_CFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 19:16                  | R/W            | 0               | <p>OUTPUT_FMT<br/>           Output data format<br/>           When the input format is set RAW stream<br/>           0000: pass-through</p> <p>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<br/>           0110: frame planar YCbCr 420 UV combined<br/>           0111: frame planar YCbCr 422 UV combined</p> <p>1111: interlaced interleaved YCbCr422. In this mode, capturing interlaced input and output the interlaced fields from individual ports. Field 1 data will be wrote to FIFO0 output buffer and field 2 data will be wrote to FIFO1 output buffer.</p> <p>1000: field tiled YCbCr 422<br/>           1001: field tiled YCbCr 420<br/>           1010: frame tiled YCbCr 420<br/>           1011: frame tiled 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: tiled YUV 422<br/>           1001: tiled YUV 420</p> |
| 15:12                  | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11:10                  | R/W            | 0               | <p><b>FIELD_SEL</b><br/>           Field selection. Applies to CCIR656 interface only.<br/>           00: start capturing with field 1.<br/>           01: start capturing with field 2.<br/>           10: start capturing with either field.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset Address: 0X0004 |                |                 | Register Name: CSI0_CFG_REG                                                                                 |
|------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                 |
|                        |                |                 | 11: reserved                                                                                                |
| 09:08                  | R/W            | 2               | INPUT_SEQ<br>Input data sequence, only valid for YUV422 mode.                                               |
| 07:03                  | /              | /               | /                                                                                                           |
| 02                     | R/W            | 1               | VREF_POL<br>Vref polarity<br>0: negative<br>1: positive<br>This register is not apply to CCIR656 interface. |
| 01                     | R/W            | 0               | HERF_POL<br>Href polarity<br>0: negative<br>1: positive<br>This register is not apply to CCIR656 interface. |
| 00                     | R/W            | 1               | CLK_POL<br>Data clock type<br>0: active in falling edge<br>1: active in rising edge                         |

#### 4.1.5.3. CSI CAPTURE CONTROL REGISTER

| Offset Address: 0X0008 |                |                 | Register Name: CSI0_CAP_REG                                                                                                                                                                                                                                                                                                                                             |
|------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                             |
| 31:02                  | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                       |
| 01                     | R/W            | 0               | VCAP_ON<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 wrote to output FIFO.<br>1: Enable video capture<br>The CSI starts capturing image data at the start of the next frame. |

| Offset Address: 0X0008 |                |                 | Register Name: CSI0_CAP_REG                                                                                                                                                                                                                                                                                                                 |
|------------------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                 |
| 00                     | W              | 0               | <p>SCAP_ON</p> <p>Still capture control: Capture a single still image frame.</p> <p>0: Disable still capture.</p> <p>1: Enable still capture</p> <p>The CSI module starts capturing image data at the start of the next frame. The CSI module captures only one frame of image data. This bit is self clearing and always reads as a 0.</p> |

#### 4.1.5.4. CSI HORIZONTAL SCALE REGISTER

| Offset Address: 0X000C |                |                 | Register Name: CSI0_SCALE_REG                                                                                                                                                                                      |
|------------------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                        |
| 31:28                  | /              | /               | /                                                                                                                                                                                                                  |
| 27:24                  | R/W            | F               | <p>VER_MASK</p> <p>Vertical (line) mask. Every 4-line is a mask group. Bit 24 mask the first line, bit 25 mask the second line, and so on. Mask bit = 0 means discarding this line data.</p>                       |
| 23:16                  | /              | /               | /                                                                                                                                                                                                                  |
| 15:00                  | R/W            | FFFF            | <p>HOR_MASK</p> <p>Horizontal (datastream) mask. Every 16-byte is a mask group. Bit 0 mask the first byte, bit 1 mask the second byte, and so on. Mask bit = 0 means discarding this byte from the datastream.</p> |

#### 4.1.5.5. CSI CHANNEL\_0 FIFO 0 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0010 |                |                 | Register Name: CSI0_C0_F0_BUFA_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C0F0_BUFA<br>FIFO 0 output buffer-A address |

#### 4.1.5.6. CSI CHANNEL\_0 FIFO 0 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X0014 |                |                 | Register Name: CSI0_C0_F0_BUFB_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C0F0_BUFB<br>FIFO 0 output buffer-B address |

#### 4.1.5.7. CSI CHANNEL\_0 FIFO 1 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0018 |                |                 | Register Name: CSI0_C0_F1_BUFA_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C0F1_BUFA<br>FIFO 1 output buffer-A address |

#### 4.1.5.8. CSI CHANNEL\_0 FIFO 1 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X001C |                |                 | Register Name: CSI0_C0_F1_BUFB_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C0F1_BUFB<br>FIFO 1 output buffer-B address |

#### 4.1.5.9. CSI CHANNEL\_0 FIFO 2 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0020 |                |                 | Register Name: CSI0_C0_F2_BUFA_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C0F2_BUFA<br>FIFO 2 output buffer-A address |

#### 4.1.5.10. CSI CHANNEL\_0 FIFO 2 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X0024 | Register Name: CSI0_C0_F2_BUFB_REG |
|------------------------|------------------------------------|
|------------------------|------------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                          |
|------------|------------------------|-------------------------|---------------------------------------------|
| 31:00      | R/W                    | 0                       | C0F2_BUFB<br>FIFO 2 output buffer-B address |

#### 4.1.5.11. CSI CHANNEL\_0 OUTPUT BUFFER CONTROL REGISTER

| <b>Offset Address: 0X0028</b> |                        |                         | <b>Register Name: CSI0_C0_BUF_CTL_REG</b>                                                                                                                 |
|-------------------------------|------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                        |
| 31:03                         | /                      | /                       | /                                                                                                                                                         |
| 02                            | R/W                    | 0                       | DBN<br>Buffer selected at next storing for CSI<br>0: Next buffer selection is buffer-A<br>1: Next buffer selection is buffer-B                            |
| 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. |

#### 4.1.5.12. CSI CHANNEL\_0 STATUS REGISTER

| <b>Offset Address: 0X002C</b> |                        |                         | <b>Register Name: CSI0_C0_BUF_STA_REG</b>                                                                                             |
|-------------------------------|------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                    |
| 31:08                         | R                      | 0                       | LUM_STATIS<br>luminance statistical value<br>When frame done interrupt flag come, value is ready and will last until next frame done. |

| Offset Address: 0X002C |                |                 | Register Name: CSI0_C0_BUF_STA_REG                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|                        |                |                 | For raw data, value = (G>>1+R+G)>>8<br>For yuv422, value = Y>>8                                                                                                                                                                                                                                                                                                                                                           |
| 07:02                  | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 01                     | R              | 0               | VCAP_STA<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.                                                                                                                    |
| 00                     | R              | 0               | SCAP_STA<br>Still capture in progress<br>Indicates the CSI is capturing still image data (single frame). The bit is set at the start of the first frame after enabling still frame capture. It clears itself after the last pixel of the first frame is captured.<br>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means filed end. |

#### 4.1.5.13. CSI CHANNEL\_0 INTERRUPT ENABLE REGISTER

| Offset Address: 0X0030 |                |                 | Register Name: CSI0_C0_INT_EN_REG                                                                                                                                                                        |
|------------------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/Wr<br>ite | Default/H<br>ex | Description                                                                                                                                                                                              |
| 31:08                  | /              | /               | /                                                                                                                                                                                                        |
| 07                     | R/W            | 0               | VS_INT_EN<br>vsync flag<br>The bit is set when vsync come. And at this time load the buffer address for the coming frame. So after this irq come, change the buffer address could only effect next frame |
| 06                     | R/W            | 0               | HB_OF_INT_EN<br>Hblank FIFO overflow<br>The bit is set when 3 FIFOs still overflow after the hblank.                                                                                                     |
| 05                     | R/W            | /               | PRTC_ERR_INT_EN                                                                                                                                                                                          |
| 04                     | R/W            | 0               | FIFO2_OF_INT_EN<br>FIFO 2 overflow                                                                                                                                                                       |

| Offset Address: 0X0030 |             |              | Register Name: CSI0_C0_INT_EN_REG                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/Wr ite | Default/H ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                        |             |              | The bit is set when the FIFO 2 become overflow.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 03                     | R/W         | 0            | FIFO1_OF_INT_EN<br>FIFO 1 overflow<br>The bit is set when the FIFO 1 become overflow.                                                                                                                                                                                                                                                                                                                                                                      |
| 02                     | R/W         | 0            | FIFO0_OF_INT_EN<br>FIFO 0 overflow<br>The bit is set when the FIFO 0 become overflow.                                                                                                                                                                                                                                                                                                                                                                      |
| 01                     | R/W         | 0            | FD_INT_EN<br>Frame done<br>Indicates the CSI has finished capturing an image frame. Applies to video capture mode. The bit is set after each completed frame capturing data is wrote to buffer as long as video capture remains enabled.                                                                                                                                                                                                                   |
| 00                     | R/W         | 0            | CD_INT_EN<br>Capture done<br>Indicates the CSI has completed capturing the image data.<br>For still capture, the bit is set when one frame data has been wrote to buffer.<br>For video capture, the bit is set when the last frame has been wrote to buffer after video capture has been disabled.<br>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means field end. |

#### 4.1.5.14. CSI CHANNEL\_0 INTERRUPT STATUS REGISTER

| Offset Address: 0X0034 |             |              | Register Name: CSI0_C0_INT_STA_REG |
|------------------------|-------------|--------------|------------------------------------|
| Bit                    | Read/Wr ite | Default/H ex | Description                        |
| 31:08                  | /           | /            | /                                  |
| 07                     | R/W         | 0            | VS_PD<br>vsync flag                |
| 06                     | R/W         | 0            | HB_OF_PD<br>Hblank FIFO overflow   |
| 05                     | R/W         | /            | PRTC_ERR_PD                        |

| Offset Address: 0X0034 |                |                 | Register Name: CSI0_C0_INT_STA_REG |
|------------------------|----------------|-----------------|------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                        |
| 04                     | R/W            | 0               | FIFO2_OF_PD<br>FIFO 2 overflow     |
| 03                     | R/W            | 0               | FIFO1_OF_PD<br>FIFO 1 overflow     |
| 02                     | R/W            | 0               | FIFO0_OF_PD<br>FIFO 0 overflow     |
| 01                     | R/W            | 0               | FD_PD<br>Frame done                |
| 00                     | R/W            | 0               | CD_PD<br>Capture done              |

#### 4.1.5.15. CSI CHANNEL\_0 HORIZONTAL SIZE REGISTER

| Offset Address: 0X0040 |                |                 | Register Name: CSI0_C0_HSIZE_REG                                                |
|------------------------|----------------|-----------------|---------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                     |
| 31:29                  | /              | /               | /                                                                               |
| 28:16                  | R/W            | 500             | HOR_LEN<br>Horizontal pixel clock length. Valid pixel clocks of a line.         |
| 15:13                  | /              | /               | /                                                                               |
| 12:00                  | R/W            | 0               | HOR_START<br>Horizontal pixel clock start. Pixel data is valid from this clock. |

#### 4.1.5.16. CSI CHANNEL\_0 VERTICAL SIZE REGISTER

| Offset Address: 0X0044 |                |                 | Register Name: CSI0_C0_VSIZE_REG |
|------------------------|----------------|-----------------|----------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                      |
|                        |                |                 |                                  |

| Offset Address: 0X0044 |                |                 | Register Name: CSI0_C0_VSIZE_REG                                |
|------------------------|----------------|-----------------|-----------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                     |
| 31:29                  | /              | /               | /                                                               |
| 28:16                  | R/W            | 1E0             | VER_LEN<br>Vertical line length. Valid line number of a frame.  |
| 15:13                  | /              | /               | /                                                               |
| 12:00                  | R/W            | 0               | VER_START<br>Vertical line start. data is valid from this line. |

#### 4.1.5.17. CSI CHANNEL\_0 BUFFER LENGTH REGISTER

| Offset Address: 0X0048 |                |                 | Register Name: CSI0_C0_BUF_LEN_REG                                             |
|------------------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
| 31:13                  | /              | /               | /                                                                              |
| 12:00                  | R/W            | 280             | BUF_LEN<br>Buffer length of a line. Unit is byte. It is the max of the 3 FIFOs |

#### 4.1.5.18. CSI CHANNEL\_1 FIFO 0 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0110 |                |                 | Register Name: CSI0_C1_F0_BUFA_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C1F0_BUFA<br>FIFO 0 output buffer-A address |

#### 4.1.5.19. CSI CHANNEL\_1 FIFO 0 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X0114 |                |                 | Register Name: CSI0_C1_F0_BUFB_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C1F0_BUFB<br>FIFO 0 output buffer-B address |

#### 4.1.5.20. CSI CHANNEL\_1 FIFO 1 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0118 |                |                 | Register Name: CSI0_C1_F1_BUFA_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C1F1_BUFA<br>FIFO 1 output buffer-A address |

#### 4.1.5.21. CSI CHANNEL\_1 FIFO 1 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X011C |                |                 | Register Name: CSI0_C1_F1_BUFB_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C1F1_BUFB<br>FIFO 1 output buffer-B address |

#### 4.1.5.22. CSI CHANNEL\_1 FIFO 2 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0120 |                |                 | Register Name: CSI0_C1_F2_BUFA_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C1F2_BUFA<br>FIFO 2 output buffer-A address |

#### 4.1.5.23. CSI CHANNEL\_1 FIFO 2 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X0124 |                |                 | Register Name: CSI0_C1_F2_BUFB_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C1F2_BUFB<br>FIFO 2 output buffer-B address |

#### 4.1.5.24. CSI CHANNEL\_1 OUTPUT BUFFER CONTROL REGISTER

| Offset Address: 0X0128 | Register Name: CSI0_C1_BUF_CTL_REG |
|------------------------|------------------------------------|
|------------------------|------------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:03      | /                      | /                       | /                                                                                                                                                                                                                       |
| 02         | R/W                    | 0                       | <p><b>DBN</b><br/>           Buffer selected at next storing for CSI<br/>           0: Next buffer selection is buffer-A<br/>           1: Next buffer selection is buffer-B</p>                                        |
| 01         | R                      | 0                       | <p><b>DBS</b><br/>           output buffer selected status<br/>           0: Selected output buffer-A<br/>           1: Selected output buffer-B</p>                                                                    |
| 00         | R/W                    | 0                       | <p><b>DBE</b><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.</p> |

#### 4.1.5.25. CSI CHANNEL\_1 STATUS REGISTER

| <b>Offset Address: 0X012C</b> |                        |                         | <b>Register Name: CSI0_C1_BUF_STA_REG</b>                                                                                                                                                                                                                                                                                                    |
|-------------------------------|------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                           |
| 31:08                         | R                      | 0                       | <p><b>LUM_STATIS</b><br/>           luminance statistical value<br/>           When frame done interrupt flag come, value is ready and will last until next frame done.<br/>           For raw data, value = <math>(G&gt;&gt;1+R+G)&gt;&gt;8</math><br/>           For yuv422, value = <math>Y&gt;&gt;8</math></p>                           |
| 07:02                         | /                      | /                       | /                                                                                                                                                                                                                                                                                                                                            |
| 01                            | R                      | 0                       | <p><b>VCAP_STA</b><br/>           Video capture in progress<br/>           Indicates the CSI is capturing video image data (multiple frames). The bit is set at the start of the first frame after enabling video capture. When software disables video capture, it clears itself after the last pixel of the current frame is captured.</p> |
| 00                            | R                      | 0                       | <p><b>SCAP_STA</b><br/>           Still capture in progress</p>                                                                                                                                                                                                                                                                              |

| Offset Address: 0X012C |                |                 | Register Name: CSI0_C1_BUF_STA_REG                                                                                                                                                                                                                                                                                                                                                          |
|------------------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|                        |                |                 | <p>Indicates the CSI is capturing still image data (single frame). The bit is set at the start of the first frame after enabling still frame capture. It clears itself after the last pixel of the first frame is captured.</p> <p>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means filed end.</p> |

#### 4.1.5.26. CSI CHANNEL\_1 INTERRUPT ENABLE REGISTER

| Offset Address: 0X0130 |                |                 | Register Name: CSI0_C1_INT_EN_REG                                                                                                                                                                                    |
|------------------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                          |
| 31:08                  | /              | /               | /                                                                                                                                                                                                                    |
| 07                     | R/W            | 0               | <p>VS_INT_EN<br/>vsync flag</p> <p>The bit is set when vsync come. And at this time load the buffer address for the coming frame. So after this irq come, change the buffer address could only effect next frame</p> |
| 06                     | R/W            | 0               | <p>HB_OF_INT_EN<br/>Hblank FIFO overflow</p> <p>The bit is set when 3 FIFOs still overflow after the hblank.</p>                                                                                                     |
| 05                     | R/W            | 0               | PRTC_ERR_INT_EN                                                                                                                                                                                                      |
| 04                     | R/W            | 0               | <p>FIFO2_OF_INT_EN<br/>FIFO 2 overflow</p> <p>The bit is set when the FIFO 2 become overflow.</p>                                                                                                                    |
| 03                     | R/W            | 0               | <p>FIFO1_OF_INT_EN<br/>FIFO 1 overflow</p> <p>The bit is set when the FIFO 1 become overflow.</p>                                                                                                                    |
| 02                     | R/W            | 0               | <p>FIFO0_OF_INT_EN<br/>FIFO 0 overflow</p> <p>The bit is set when the FIFO 0 become overflow.</p>                                                                                                                    |
| 01                     | R/W            | 0               | <p>FD_INT_EN<br/>Frame done</p> <p>Indicates the CSI has finished capturing an image frame. Applies to video capture mode. The bit is set after each completed frame</p>                                             |

| Offset Address: 0X0130 |                |                 | Register Name: CSI0_C1_INT_EN_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                        |                |                 | capturing data is wrote to buffer as long as video capture remains enabled.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 00                     | R/W            | 0               | <p>CD_INT_EN<br/>Capture done</p> <p>Indicates the CSI has completed capturing the image data.</p> <p>For still capture, the bit is set when one frame data has been wrote to buffer.</p> <p>For video capture, the bit is set when the last frame has been wrote to buffer after video capture has been disabled.</p> <p>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means field end.</p> |

#### 4.1.5.27. CSI CHANNEL\_1 INTERRUPT STATUS REGISTER

| Offset Address: 0X0134 |                |                 | Register Name: CSI0_C1_INT_STA_REG |
|------------------------|----------------|-----------------|------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                        |
| 31:08                  | /              | /               | /                                  |
| 07                     | R/W            | 0               | VS_PD<br>vsync flag                |
| 06                     | R/W            | 0               | HB_OF_PD<br>Hblank FIFO overflow   |
| 05                     | R/W            | 0               | PRTC_ERR_PD                        |
| 04                     | R/W            | 0               | FIFO2_OF_PD<br>FIFO 2 overflow     |
| 03                     | R/W            | 0               | FIFO1_OF_PD<br>FIFO 1 overflow     |
| 02                     | R/W            | 0               | FIFO0_OF_PD<br>FIFO 0 overflow     |
| 01                     | R/W            | 0               | FD_PD<br>Frame done                |
| 00                     | R/W            | 0               | CD_PD<br>Capture done              |

#### 4.1.5.28. CSI CHANNEL\_1 HORIZONTAL SIZE REGISTER

| Offset Address: 0X0140 |                |                 | Register Name: CSI0_C1_HSIZE_REG                                                |
|------------------------|----------------|-----------------|---------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                                                     |
| 31:29                  | /              | /               | /                                                                               |
| 28:16                  | R/W            | 500             | HOR_LEN<br>Horizontal pixel clock length. Valid pixel clocks of a line.         |
| 15:13                  | /              | /               | /                                                                               |
| 12:00                  | R/W            | 0               | HOR_START<br>Horizontal pixel clock start. Pixel data is valid from this clock. |

#### 4.1.5.29. CSI CHANNEL\_1 VERTICAL SIZE REGISTER

| Offset Address: 0X0144 |                |                 | Register Name: CSI0_C1_VSIZE_REG                                |
|------------------------|----------------|-----------------|-----------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                                     |
| 31:29                  | /              | /               | /                                                               |
| 28:16                  | R/W            | 1E0             | VER_LEN<br>Vertical line length. Valid line number of a frame.  |
| 15:13                  | /              | /               | /                                                               |
| 12:00                  | R/W            | 0               | VER_START<br>Vertical line start. data is valid from this line. |

#### 4.1.5.30. CSI CHANNEL\_1 BUFFER LENGTH REGISTER

| Offset Address: 0X0148 |                |                 | Register Name: CSI0_C1_BUF_LEN_REG                                             |
|------------------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
| 31:13                  | /              | /               | /                                                                              |
| 12:00                  | R/W            | 280             | BUF_LEN<br>Buffer length of a line. Unit is byte. It is the max of the 3 FIFOs |

#### 4.1.5.31. CSI CHANNEL\_2 FIFO 0 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0210 |                |                 | Register Name: CSI0_C2_F0_BUFA_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C2F0_BUFA<br>FIFO 0 output buffer-A address |

#### 4.1.5.32. CSI CHANNEL\_2 FIFO 0 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X0214 |                |                 | Register Name: CSI0_C2_F0_BUFB_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C2F0_BUFB<br>FIFO 0 output buffer-B address |

#### 4.1.5.33. CSI CHANNEL\_2 FIFO 1 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0218 |                |                 | Register Name: CSI0_C2_F1_BUFA_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C2F1_BUFA<br>FIFO 1 output buffer-A address |

#### 4.1.5.34. CSI CHANNEL\_2 FIFO 1 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X021C |                |                 | Register Name: CSI0_C2_F1_BUFB_REG          |
|------------------------|----------------|-----------------|---------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:00                  | R/W            | 0               | C2F1_BUFB<br>FIFO 1 output buffer-B address |

#### 4.1.5.35. CSI CHANNEL\_2 FIFO 2 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0220 |                |             | Register Name: CSI0_C2_F2_BUFA_REG          |
|------------------------|----------------|-------------|---------------------------------------------|
| Bit                    | Read/<br>Write | Default/Hex | Description                                 |
| 31:00                  | R/W            | 0           | C2F2_BUFA<br>FIFO 2 output buffer-A address |

#### 4.1.5.36. CSI CHANNEL\_2 FIFO 2 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X0224 |                |             | Register Name: CSI0_C2_F2_BUFB_REG          |
|------------------------|----------------|-------------|---------------------------------------------|
| Bit                    | Read/<br>Write | Default/Hex | Description                                 |
| 31:00                  | R/W            | 0           | C2F2_BUFB<br>FIFO 2 output buffer-B address |

#### 4.1.5.37. CSI CHANNEL\_2 OUTPUT BUFFER CONTROL REGISTER

| Offset Address: 0X0228 |                |                 | Register Name: CSI0_C2_BUF_CTL_REG                                                                                                |
|------------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                       |
| 31:03                  | /              | /               | /                                                                                                                                 |
| 02                     | R/W            | 0               | DBN<br>Buffer selected at next storing for CSI<br>0: Next buffer selection is buffer-A<br>1: Next buffer selection is buffer-B    |
| 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 |

| Offset Address: 0X0228 |                |                 | Register Name: CSI0_C2_BUF_CTL_REG |
|------------------------|----------------|-----------------|------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                        |
|                        |                |                 | selected by CSI module.            |

#### 4.1.5.38. CSI CHANNEL\_2 STATUS REGISTER

| Offset Address: 0X022C |                |                 | Register Name: CSI0_C2_BUF_STA_REG                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:08                  | R              | 0               | <p>LUM_STATIS<br/>luminance statistical value<br/>When frame done interrupt flag come, value is ready and will last until next frame done.<br/>For raw data, value = (G&gt;&gt;1+R+G)&gt;&gt;8<br/>For yuv422, value = Y&gt;&gt;8</p>                                                                                                                                                                                               |
| 07:02                  | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 01                     | R              | 0               | <p>VCAP_STA<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>SCAP_STA<br/>Still capture in progress<br/>Indicates the CSI is capturing still image data (single frame). The bit is set at the start of the first frame after enabling still frame capture. It clears itself after the last pixel of the first frame is captured.<br/>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means filed end.</p> |

#### 4.1.5.39. CSI CHANNEL\_2 INTERRUPT ENABLE REGISTER

| Offset Address: 0X0230 |                |                 | Register Name: CSI0_C2_INT_EN_REG |
|------------------------|----------------|-----------------|-----------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                       |
|                        |                |                 |                                   |

| Offset Address: 0X0230 |                |                 | Register Name: CSI0_C2_INT_EN_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:08                  | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 07                     | R/W            | 0               | <p>VS_INT_EN<br/>vsync flag</p> <p>The bit is set when vsync come. And at this time load the buffer address for the coming frame. So after this irq come, change the buffer address could only effect next frame</p>                                                                                                                                                                                                                                                               |
| 06                     | R/W            | 0               | <p>HB_OF_INT_EN<br/>Hblank FIFO overflow</p> <p>The bit is set when 3 FIFOs still overflow after the hblank.</p>                                                                                                                                                                                                                                                                                                                                                                   |
| 05                     | R/W            | 0               | PRTC_ERR_INT_EN                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 04                     | R/W            | 0               | <p>FIFO2_OF_INT_EN<br/>FIFO 2 overflow</p> <p>The bit is set when the FIFO 2 become overflow.</p>                                                                                                                                                                                                                                                                                                                                                                                  |
| 03                     | R/W            | 0               | <p>FIFO1_OF_INT_EN<br/>FIFO 1 overflow</p> <p>The bit is set when the FIFO 1 become overflow.</p>                                                                                                                                                                                                                                                                                                                                                                                  |
| 02                     | R/W            | 0               | <p>FIFO0_OF_INT_EN<br/>FIFO 0 overflow</p> <p>The bit is set when the FIFO 0 become overflow.</p>                                                                                                                                                                                                                                                                                                                                                                                  |
| 01                     | R/W            | 0               | <p>FD_INT_EN<br/>Frame done</p> <p>Indicates the CSI has finished capturing an image frame. Applies to video capture mode. The bit is set after each completed frame capturing data is wrote to buffer as long as video capture remains enabled.</p>                                                                                                                                                                                                                               |
| 00                     | R/W            | 0               | <p>CD_INT_EN<br/>Capture done</p> <p>Indicates the CSI has completed capturing the image data.</p> <p>For still capture, the bit is set when one frame data has been wrote to buffer.</p> <p>For video capture, the bit is set when the last frame has been wrote to buffer after video capture has been disabled.</p> <p>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means field end.</p> |

#### 4.1.5.40. CSI CHANNEL\_2 INTERRUPT STATUS REGISTER

| Offset Address: 0X0234 |                |                 | Register Name: CSIO_C2_INT_STA_REG         |
|------------------------|----------------|-----------------|--------------------------------------------|
| Bit                    | Read/W<br>rite | Default/H<br>ex | Description                                |
| 31:08                  | /              | /               | /                                          |
| 07                     | R/W            | 0               | VS_PD<br>vsync flag                        |
| 06                     | R/W            | 0               | HB_OF_PD<br>Hblank FIFO overflow           |
| 05                     | R/W            | 0               | PRTC_ERR_PD<br><del>Protection error</del> |
| 04                     | R/W            | 0               | FIFO2_OF_PD<br>FIFO 2 overflow             |
| 03                     | R/W            | 0               | FIFO1_OF_PD<br>FIFO 1 overflow             |
| 02                     | R/W            | 0               | FIFO0_OF_PD<br>FIFO 0 overflow             |
| 01                     | R/W            | 0               | FD_PD<br>Frame done                        |
| 00                     | R/W            | 0               | CD_PD<br>Capture done                      |

#### 4.1.5.41. CSI CHANNEL\_2 HORIZONTAL SIZE REGISTER

| Offset Address: 0X0240 |                |                 | Register Name: CSIO_C2_HSIZE_REG |
|------------------------|----------------|-----------------|----------------------------------|
| Bit                    | Read/<br>Write | Default/H<br>ex | Description                      |

| Offset Address: 0X0240 |                |             | Register Name: CSI0_C2_HSIZE_REG                                                |
|------------------------|----------------|-------------|---------------------------------------------------------------------------------|
| Bit                    | Read/<br>Write | Default/Hex | Description                                                                     |
| 31:29                  | /              | /           | /                                                                               |
| 28:16                  | R/W            | 500         | HOR_LEN<br>Horizontal pixel clock length. Valid pixel clocks of a line.         |
| 15:13                  | /              | /           | /                                                                               |
| 12:00                  | R/W            | 0           | HOR_START<br>Horizontal pixel clock start. Pixel data is valid from this clock. |

#### 4.1.5.42. CSI CHANNEL\_2 VERTICAL SIZE REGISTER

| Offset Address: 0X0244 |                |             | Register Name: CSI0_C2_VSIZE_REG                                |
|------------------------|----------------|-------------|-----------------------------------------------------------------|
| Bit                    | Read/<br>Write | Default/Hex | Description                                                     |
| 31:29                  | /              | /           | /                                                               |
| 28:16                  | R/W            | 1E0         | VER_LEN<br>Vertical line length. Valid line number of a frame.  |
| 15:13                  | /              | /           | /                                                               |
| 12:00                  | R/W            | 0           | VER_START<br>Vertical line start. data is valid from this line. |

#### 4.1.5.43. CSI CHANNEL\_2 BUFFER LENGTH REGISTER

| Offset Address: 0X0248 |                |                 | Register Name: CSI0_C2_BUF_LEN_REG                                             |
|------------------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
| 31:13                  | /              | /               | /                                                                              |
| 12:00                  | R/W            | 280             | BUF_LEN<br>Buffer length of a line. Unit is byte. It is the max of the 3 FIFOs |

#### 4.1.5.44. CSI CHANNEL\_3 FIFO 0 OUTPUT BUFFER-A ADDRESS REGISTER

|                        |                                    |
|------------------------|------------------------------------|
| Offset Address: 0X0310 | Register Name: CSI0_C3_F0_BUFA_REG |
|------------------------|------------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                          |
|------------|------------------------|-------------------------|---------------------------------------------|
| 31:00      | R/W                    | 0                       | C3F0_BUFA<br>FIFO 0 output buffer-A address |

#### 4.1.5.45. CSI CHANNEL\_3 FIFO 0 OUTPUT BUFFER-B ADDRESS REGISTER

| <b>Offset Address: 0X0314</b> |                        |                         | <b>Register Name: CSI0_C3_F0_BUFB_REG</b>   |
|-------------------------------|------------------------|-------------------------|---------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                          |
| 31:00                         | R/W                    | 0                       | C3F0_BUFB<br>FIFO 0 output buffer-B address |

#### 4.1.5.46. CSI CHANNEL\_3 FIFO 1 OUTPUT BUFFER-A ADDRESS REGISTER

| <b>Offset Address: 0X0318</b> |                        |                         | <b>Register Name: CSI0_C3_F1_BUFA_REG</b>   |
|-------------------------------|------------------------|-------------------------|---------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                          |
| 31:00                         | R/W                    | 0                       | C3F1_BUFA<br>FIFO 1 output buffer-A address |

#### 4.1.5.47. CSI CHANNEL\_3 FIFO 1 OUTPUT BUFFER-B ADDRESS REGISTER

| <b>Offset Address: 0X031C</b> |                        |                         | <b>Register Name: CSI0_C3_F1_BUFB_REG</b>   |
|-------------------------------|------------------------|-------------------------|---------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                          |
| 31:00                         | R/W                    | 0                       | C3F1_BUFB<br>FIFO 1 output buffer-B address |

#### 4.1.5.48. CSI CHANNEL\_3 FIFO 2 OUTPUT BUFFER-A ADDRESS REGISTER

| <b>Offset Address: 0X0320</b> | <b>Register Name: CSI0_C3_F2_BUFA_REG</b> |
|-------------------------------|-------------------------------------------|
|-------------------------------|-------------------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                          |
|------------|------------------------|-------------------------|---------------------------------------------|
| 31:00      | R/W                    | 0                       | C3F2_BUFA<br>FIFO 2 output buffer-A address |

#### 4.1.5.49. CSI CHANNEL\_3 FIFO 2 OUTPUT BUFFER-B ADDRESS REGISTER

| <b>Offset Address: 0X0324</b> |                        |                         | <b>Register Name: CSI0_C3_F2_BUFB_REG</b>   |
|-------------------------------|------------------------|-------------------------|---------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                          |
| 31:00                         | R/W                    | 0                       | C3F2_BUFB<br>FIFO 2 output buffer-B address |

#### 4.1.5.50. CSI CHANNEL\_3 OUTPUT BUFFER CONTROL REGISTER

| <b>Offset Address: 0X0328</b> |                        |                         | <b>Register Name: CSI0_C3_BUF_CTL_REG</b>                                                                                                                 |
|-------------------------------|------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                        |
| 31:03                         | /                      | /                       | /                                                                                                                                                         |
| 02                            | R/W                    | 0                       | DBN<br>Buffer selected at next storing for CSI<br>0: Next buffer selection is buffer-A<br>1: Next buffer selection is buffer-B                            |
| 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. |

#### 4.1.5.51. CSI CHANNEL\_3 STATUS REGISTER

| Offset Address: 0X032C |                |                 | Register Name: CSI0_C3_BUF_STA_REG                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:08                  | R              | 0               | <p>LUM_STATIS<br/>luminance statistical value<br/>When frame done interrupt flag come, value is ready and will last until next frame done.<br/>For raw data, value = <math>(G&gt;&gt;1+R+G)&gt;&gt;8</math><br/>For yuv422, value = <math>Y&gt;&gt;8</math></p>                                                                                                                                                                     |
| 07:02                  | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 01                     | R              | 0               | <p>VCAP_STA<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>SCAP_STA<br/>Still capture in progress<br/>Indicates the CSI is capturing still image data (single frame). The bit is set at the start of the first frame after enabling still frame capture. It clears itself after the last pixel of the first frame is captured.<br/>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means filed end.</p> |

#### 4.1.5.52. CSI CHANNEL\_3 INTERRUPT ENABLE REGISTER

| Offset Address: 0X0330 |                |                 | Register Name: CSI0_C3_INT_EN_REG                                                                                                                                                                                 |
|------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                       |
| 31:08                  | /              | /               | /                                                                                                                                                                                                                 |
| 07                     | R/W            | 0               | <p>VS_INT_EN<br/>vsync flag<br/>The bit is set when vsync come. And at this time load the buffer address for the coming frame. So after this irq come, change the buffer address could only effect next frame</p> |
| 06                     | R/W            | 0               | HB_OF_INT_EN                                                                                                                                                                                                      |

| Offset Address: 0X0330 |                |                 | Register Name: CSI0_C3_INT_EN_REG                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                        |                |                 | Hblank FIFO overflow<br>The bit is set when 3 FIFOs still overflow after the hblank.                                                                                                                                                                                                                                                                                                                                                                       |
| 05                     | R/W            | 0               | PTC_ERR_INT_EN                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 04                     | R/W            | 0               | FIFO2_OF_INT_EN<br>FIFO 2 overflow<br>The bit is set when the FIFO 2 become overflow.                                                                                                                                                                                                                                                                                                                                                                      |
| 03                     | R/W            | 0               | FIFO1_OF_INT_EN<br>FIFO 1 overflow<br>The bit is set when the FIFO 1 become overflow.                                                                                                                                                                                                                                                                                                                                                                      |
| 02                     | R/W            | 0               | FIFO0_OF_INT_EN<br>FIFO 0 overflow<br>The bit is set when the FIFO 0 become overflow.                                                                                                                                                                                                                                                                                                                                                                      |
| 01                     | R/W            | 0               | FD_INT_EN<br>Frame done<br>Indicates the CSI has finished capturing an image frame. Applies to video capture mode. The bit is set after each completed frame capturing data is wrote to buffer as long as video capture remains enabled.                                                                                                                                                                                                                   |
| 00                     | R/W            | 0               | CD_INT_EN<br>Capture done<br>Indicates the CSI has completed capturing the image data.<br>For still capture, the bit is set when one frame data has been wrote to buffer.<br>For video capture, the bit is set when the last frame has been wrote to buffer after video capture has been disabled.<br>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means field end. |

#### 4.1.5.53. CSI CHANNEL\_3 INTERRUPT STATUS REGISTER

| Offset Address: 0X0334 |                |                 | Register Name: CSI0_C3_INT_STA_REG |
|------------------------|----------------|-----------------|------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                        |
| 31:08                  | /              | /               | /                                  |

| Offset Address: 0X0334 |                |                 | Register Name: CSI0_C3_INT_STA_REG |
|------------------------|----------------|-----------------|------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                        |
| 07                     | R/W            | 0               | VS_PD<br>vsync flag                |
| 06                     | R/W            | 0               | HB_OF_PD<br>Hblank FIFO overflow   |
| 05                     | R/W            | /               | /                                  |
| 04                     | R/W            | 0               | FIFO2_OF_PD<br>FIFO 2 overflow     |
| 03                     | R/W            | 0               | FIFO1_OF_PD<br>FIFO 1 overflow     |
| 02                     | R/W            | 0               | FIFO0_OF_PD<br>FIFO 0 overflow     |
| 01                     | R/W            | 0               | FD_PD<br>Frame done                |
| 00                     | R/W            | 0               | CD_PD<br>Capture done              |

#### 4.1.5.54. CSI CHANNEL\_3 HORIZONTAL SIZE REGISTER

| Offset Address: 0X0340 |                |                 | Register Name: CSI0_C3_HSIZE_REG                                                |
|------------------------|----------------|-----------------|---------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                     |
| 31:29                  | /              | /               | /                                                                               |
| 28:16                  | R/W            | 500             | HOR_LEN<br>Horizontal pixel clock length. Valid pixel clocks of a line.         |
| 15:13                  | /              | /               | /                                                                               |
| 12:00                  | R/W            | 0               | HOR_START<br>Horizontal pixel clock start. Pixel data is valid from this clock. |

#### 4.1.5.55. CSI CHANNEL\_3 VERTICAL SIZE REGISTER

| Offset Address: 0X0344 |                |                 | Register Name: CSI0_C3_VSIZE_REG                                |
|------------------------|----------------|-----------------|-----------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                     |
| 31:29                  | /              | /               | /                                                               |
| 28:16                  | R/W            | 1E0             | VER_LEN<br>Vertical line length. Valid line number of a frame.  |
| 15:13                  | /              | /               | /                                                               |
| 12:00                  | R/W            | 0               | VER_START<br>Vertical line start. data is valid from this line. |

#### 4.1.5.56. CSI CHANNEL\_3 BUFFER LENGTH REGISTER

| Offset Address: 0X0348 |                |                 | Register Name: CSI0_C3_BUF_LEN_REG                                             |
|------------------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
| 31:13                  | /              | /               | /                                                                              |
| 12:00                  | R/W            | 280             | BUF_LEN<br>Buffer length of a line. Unit is byte. It is the max of the 3 FIFOs |

## 4.2. CSI1

### 4.2.1. Overview

The CSI1 module features:

- 8 bits input data
- Support CCIR656 protocol for NTSC and PAL
- 3 parallel data paths for image stream parsing
- Received data double buffer support
- Parsing bayer data into planar R, G, B output to memory
- Parsing interlaced data into planar or tiled Y, Cb, Cr output to memory
- Pass raw data direct to memory
- All data transmit timing can be adjusted by software
- Support multi-channel ITU-R BT.656 time-multiplexed format
- Luminance statistical value
- Support 10-bit raw data input
- Support 24-bit RGB/YUV 444 input, interlace/progressive mode, pixel clock up to 148.5(1080p)

## 4.2.2. CSI1 Block Diagram



## 4.2.3. CSI1 Description

### 4.2.3.1. CSI DATA PORTS

|       | <b>Bayer</b>     | <b>YCbCr (YUV)</b> | <b>Interlaced</b>      | <b>Pass-through</b> |
|-------|------------------|--------------------|------------------------|---------------------|
| FIFO0 | Red pixel data   | Y pixel data       | All field 1 pixel data | All pixel data      |
| FIFO1 | Green pixel data | Cb (U) pixel data  | All field 2 pixel data | -                   |
| FIFO2 | Blue pixel data  | Cr (V) pixel data  | -                      | -                   |

## 4.2.4. CSI1 Timing Diagram



Vref= positive; Href= positive



vertical size setting



horizontal size setting and pixel clock timing(Href= positive)

#### 4.2.5. CSI1 Register List

| Module Name | Base Address |
|-------------|--------------|
| CSI1        | 0x01C1D000   |

| Register Name    | Offset | Description                                 |
|------------------|--------|---------------------------------------------|
| CSI1_EN_REG      | 0X000  | CSI enable register                         |
| CSI1_CFG_REG     | 0X004  | CSI configuration register                  |
| CSI1_CAP_REG     | 0X008  | CSI capture control register                |
| CSI1_SCALE_REG   | 0X00C  | CSI scale register                          |
| CSI1_F0_BUFA_REG | 0X010  | CSI FIFO 0 output buffer-A address register |
| CSI1_F0_BUFB_REG | 0X014  | CSI FIFO 0 output buffer-B address register |
| CSI1_F1_BUFA_REG | 0X018  | CSI FIFO 1 output buffer-A address register |

| Register Name    | Offset | Description                                 |
|------------------|--------|---------------------------------------------|
| CSI1_F1_BUFB_REG | 0X01C  | CSI FIFO 1 output buffer-B address register |
| CSI1_F2_BUFA_REG | 0X020  | CSI FIFO 2 output buffer-A address register |
| CSI1_F2_BUFB_REG | 0X024  | CSI FIFO 2 output buffer-B address register |
| CSI1_BUF_CTL_REG | 0X028  | CSI output buffer control register          |
| CSI1_BUF_STA_REG | 0X02C  | CSI status register                         |
| CSI1_INT_EN_REG  | 0X030  | CSI interrupt enable register               |
| CSI1_INT_STA_REG | 0X034  | CSI interrupt status register               |
| CSI1_HSIZE_REG   | 0X040  | CSI horizontal size register                |
| CSI1_VSIZE_REG   | 0X044  | CSI vertical size register                  |
| CSI1_BUF_LEN_REG | 0X048  | CSI line buffer length register             |

## 4.2.6. CSI1 Register Description

### 4.2.6.1. CSI ENABLE REGISTER

| Offset: 0x0000 |                |                   | Register Name: CSI1_EN_REG       |
|----------------|----------------|-------------------|----------------------------------|
| Bit            | Read/<br>Write | Default/Het<br>er | Description                      |
| 31:1<br>0      | /              | /                 | /                                |
| 9              | R/W            | 0                 | PCLK_CNT<br>Pclk count per frame |
| 8              | R/W            | 0                 | LUMA_EN<br>Luma enable           |
| 7:5            | /              | /                 | /                                |
| 4              | R/W            | 0                 | NON16_ADD<br>Non-16 add 0x00     |
| 3              | R/W            | 0                 | RD_FIFO_EN                       |

| Offset: 0x0000 |                |                 | Register Name: CSI1_EN_REG                                                          |
|----------------|----------------|-----------------|-------------------------------------------------------------------------------------|
| Bit            | Read/<br>Write | Default/He<br>x | Description                                                                         |
|                |                |                 | Read fifo [3]fifo enable, fifo address[01c09800~01c09ffc]                           |
| 2              | R/W            | 0               | FIELD_REV<br>Ccir656 field_reverse                                                  |
| 1              | /              | /               | /                                                                                   |
| 0              | R/W            | 0               | CSI_EN<br>Enable<br>0: Reset and disable the CSI module<br>1: Enable the CSI module |

#### 4.2.6.2. CSI CONFIGURATION REGISTER

| Offset Address: 0X0004 |                |                 | Register Name: CSI1_CFG_REG                                                                                                                                                 |
|------------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                 |
| 31:23                  | /              | /               | /                                                                                                                                                                           |
| 22:20                  | R/W            | 3               | INPUT_FMT<br>Input data format<br>000: RAW stream<br>001: reserved<br>010: CCIR656(one channel)<br>011: YUV422<br>100: YUV444({R, B, G} or {Pr, Pb, Y})<br>others: reserved |

| Offset Address: 0X0004 |                |                 | Register Name: CSI1_CFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 19:16                  | R/W            | 0               | <p>OUTPUT_FMT</p> <p>Output data format</p> <p>When the input format is set RAW stream</p> <p>0000: pass-through</p> <p>When the input format is set CCIR656 interface</p> <p>0000: field planar YCbCr 422</p> <p>0001: field planar YCbCr 420</p> <p>0010: frame planar YCbCr 420</p> <p>0011: frame planar YCbCr 422</p> <p>0100: field planar YCbCr 422 UV combined</p> <p>0101: field planar YCbCr 420 UV combined</p> <p>0110: frame planar YCbCr 420 UV combined</p> <p>0111: frame planar YCbCr 422 UV combined</p> <p>1111: interlaced interleaved YCbCr422. In this mode, capturing interlaced input and output the interlaced fields from individual ports. Field 1 data will be wrote to FIFO0 output buffer and field 2 data will be wrote to FIFO1 output buffer.</p> <p>1000: field tiled YCbCr 422</p> <p>1001: field tiled YCbCr 420</p> <p>1010: frame tiled YCbCr 420</p> <p>1011: frame tiled YCbCr 422</p> <p>When the input format is set YUV422</p> <p>0000: planar YUV 422</p> <p>0001: planar YUV 420</p> <p>0100: planar YUV 422 UV combined</p> <p>0101: planar YUV 420 UV combined</p> <p>1000: tiled YUV 422</p> <p>1001: tiled YUV 420</p> <p>When the input format is set YUV444</p> <p>1100: field planar YUV 444</p> <p>1101: field planar YUV 422 UV combined</p> <p>1110: frame planar YUV 444</p> <p>1111: frame planar YUV 422 UV combined</p> |

| Offset Address: 0X0004 |                |                 | Register Name: CSI1_CFG_REG                                                                                                                                                                                                       |
|------------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                       |
| 15:12                  | /              | /               | /                                                                                                                                                                                                                                 |
| 11:10                  | R/W            | 0               | <p><b>FIELD_SEL</b><br/> Field selection. Applies to CCIR656 interface only.<br/> 00: start capturing with field 1.<br/> 01: start capturing with field 2.<br/> 10: start capturing with either field.<br/> 11: reserved</p>      |
| 09:08                  | R/W            | 2               | <p><b>INPUT_SEQ</b><br/> Input data sequence, only valid for YUV422 mode.<br/> 00: YUYV<br/> 01: YYVU<br/> 10: UYVY<br/> 11: VYUY</p>                                                                                             |
| 07:05                  | /              | /               | /                                                                                                                                                                                                                                 |
| 4                      | R/W            | 0               | <p><b>FPS_DS</b><br/> Fps down sample(failed, no this code)<br/> 0: no down sample<br/> 1: 1/2 fps, only receives the first frame every 2 frames</p>                                                                              |
| 3                      | R/W            | 0               | <p><b>FIELD_POL</b><br/> Field polarity<br/> 0: negative(field=0 indicate odd, field=1 indicate even )<br/> 1: positive(field=1 indicate odd, field=0 indicate even )<br/> This register is not applied to CCIR656 interface.</p> |
| 02                     | R/W            | 1               | <p><b>VREF_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>HERF_POL</b><br/> Href polarity<br/> 0: negative<br/> 1: positive<br/> This register is not applied to CCIR656 interface.</p>                                                                                               |
| 00                     | R/W            | 1               | <b>CLK_POL</b>                                                                                                                                                                                                                    |

| Offset Address: 0X0004 |                |                 | Register Name: CSI1_CFG_REG                                              |
|------------------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                              |
|                        |                |                 | Data clock type<br>0: active in falling edge<br>1: active in rising edge |

#### 4.2.6.3. CSI CAPTURE CONTROL REGISTER

| Offset Address: 0X0008 |                |                 | Register Name: CSI1_CAP_REG                                                                                                                                                                                                                                                                                                                                                    |
|------------------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                    |
| 31:02                  | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                              |
| 01                     | R/W            | 0               | <b>VCAP_ON</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 wrote 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>SCAP_ON</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 clearing and always reads as a 0.                                                    |

#### 4.2.6.4. CSI HORIZONTAL SCALE REGISTER

| Offset Address: 0X000C |                |                 | Register Name: CSI0_SCALE_REG |
|------------------------|----------------|-----------------|-------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                   |
| 31:28                  | /              | /               | /                             |

| Offset Address: 0X000C |                |                 | Register Name: CSI0_SCALE_REG                                                                                                                                                                           |
|------------------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                             |
| 27:24                  | R/W            | F               | VER_MASK<br>Vertical (line) mask. Every 4-line is a mask group. Bit 24 mask the first line, bit 25 mask the second line, and so on. Mask bit = 0 means discarding this line data.                       |
| 23:16                  | /              | /               | /                                                                                                                                                                                                       |
| 15:00                  | R/W            | FFFF            | HOR_MASK<br>Horizontal (datastream) mask. Every 16-byte is a mask group. Bit 0 mask the first byte, bit 1 mask the second byte, and so on. Mask bit = 0 means discarding this byte from the datastream. |

#### 4.2.6.5. CSI CHANNEL\_0 FIFO 0 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0010 |                |                 | Register Name: CSI1_F0_BUFA_REG           |
|------------------------|----------------|-----------------|-------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                               |
| 31:00                  | R/W            | 0               | F0_BUFA<br>FIFO 0 output buffer-A address |

#### 4.2.6.6. CSI CHANNEL\_0 FIFO 0 OUTPUT BUFFER-B ADDRESS REGISTER

| Offset Address: 0X0014 |                |                 | Register Name: CSI1_F0_BUFB_REG           |
|------------------------|----------------|-----------------|-------------------------------------------|
| Bit                    | Read/<br>Write | Default/H<br>ex | Description                               |
| 31:00                  | R/W            | 0               | F0_BUFB<br>FIFO 0 output buffer-B address |

#### 4.2.6.7. CSI CHANNEL\_0 FIFO 1 OUTPUT BUFFER-A ADDRESS REGISTER

| Offset Address: 0X0018 | Register Name: CSI1_F1_BUFA_REG |
|------------------------|---------------------------------|
|------------------------|---------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                        |
|------------|------------------------|-------------------------|-------------------------------------------|
| 31:00      | R/W                    | 0                       | F1_BUFA<br>FIFO 1 output buffer-A address |

#### 4.2.6.8. CSI CHANNEL\_0 FIFO 1 OUTPUT BUFFER-B ADDRESS REGISTER

| <b>Offset Address: 0X001C</b> |                        |                         | <b>Register Name: CSI1_F1_BUFB_REG</b>    |
|-------------------------------|------------------------|-------------------------|-------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                        |
| 31:00                         | R/W                    | 0                       | F1_BUFB<br>FIFO 1 output buffer-B address |

#### 4.2.6.9. CSI CHANNEL\_0 FIFO 2 OUTPUT BUFFER-A ADDRESS REGISTER

| <b>Offset Address: 0X0020</b> |                        |                         | <b>Register Name: CSI1_F2_BUFA_REG</b>    |
|-------------------------------|------------------------|-------------------------|-------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                        |
| 31:00                         | R/W                    | 0                       | F2_BUFA<br>FIFO 2 output buffer-A address |

#### 4.2.6.10. CSI CHANNEL\_0 FIFO 2 OUTPUT BUFFER-B ADDRESS REGISTER

| <b>Offset Address: 0X0024</b> |                        |                         | <b>Register Name: CSI1_F2_BUFB_REG</b>    |
|-------------------------------|------------------------|-------------------------|-------------------------------------------|
| <b>Bit</b>                    | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                        |
| 31:00                         | R/W                    | 0                       | F2_BUFB<br>FIFO 2 output buffer-B address |

#### 4.2.6.11. CSI CHANNEL\_0 OUTPUT BUFFER CONTROL REGISTER

| Offset Address: 0X0028 |                |                 | Register Name: CSI1_BUF_CTL_REG                                                                                                                                                  |
|------------------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                      |
| 31:03                  | /              | /               | /                                                                                                                                                                                |
| 02                     | R/W            | 0               | <p>DBN</p> <p>Buffer selected at next storing for CSI</p> <p>0: Next buffer selection is buffer-A</p> <p>1: Next buffer selection is buffer-B</p>                                |
| 01                     | R              | 0               | <p>DBS</p> <p>output buffer selected status</p> <p>0: Selected output buffer-A</p> <p>1: Selected output buffer-B</p>                                                            |
| 00                     | R/W            | 0               | <p>DBE</p> <p>Double buffer mode enable</p> <p>0: disable</p> <p>1: enable</p> <p>If the double buffer mode is disabled, the buffer-A will be always selected by CSI module.</p> |

#### 4.2.6.12. CSI CHANNEL\_0 STATUS REGISTER

| Offset Address: 0X002C |                |                 | Register Name: CSI1_BUF_STA_REG                                                                                                                                                                                                                                             |
|------------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                 |
| 31:08                  | R              | 0               | <p>LUM_STATIS</p> <p>luminance statistical value</p> <p>When frame done interrupt flag come, value is ready and will last until next frame done.</p> <p>For raw data, value = <math>(G&gt;&gt;1+R+G)&gt;&gt;8</math></p> <p>For yuv422, value = <math>Y&gt;&gt;8</math></p> |
| 07:02                  | /              | /               | /                                                                                                                                                                                                                                                                           |
| 01                     | R              | 0               | <p>VCAP_STA</p> <p>Video capture in progress</p> <p>Indicates the CSI is capturing video image data (multiple frames). The bit is set at the start of the first frame after enabling</p>                                                                                    |

| Offset Address: 0X002C |                |                 | Register Name: CSI1_BUF_STA_REG                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                        |                |                 | video capture. When software disables video capture, it clears itself after the last pixel of the current frame is captured.                                                                                                                                                                                                                                                                                                              |
| 00                     | R              | 0               | <p>SCAP_STA<br/>Still capture in progress</p> <p>Indicates the CSI is capturing still image data (single frame). The bit is set at the start of the first frame after enabling still frame capture. It clears itself after the last pixel of the first frame is captured.</p> <p>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means filed end.</p> |

#### 4.2.6.13. CSI CHANNEL\_0 INTERRUPT ENABLE REGISTER

| Offset Address: 0X0030 |                |                 | Register Name: CSI1_INT_EN_REG                                                                                                                                                                                       |
|------------------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                          |
| 31:08                  | /              | /               | /                                                                                                                                                                                                                    |
| 07                     | R/W            | 0               | <p>VS_INT_EN<br/>vsync flag</p> <p>The bit is set when vsync come. And at this time load the buffer address for the coming frame. So after this irq come, change the buffer address could only effect next frame</p> |
| 06                     | R/W            | 0               | <p>HB_OF_INT_EN<br/>Hblank FIFO overflow</p> <p>The bit is set when 3 FIFOs still overflow after the hblank.</p>                                                                                                     |
| 05                     | R/W            | 0               | PRTC_ERR_INT_EN                                                                                                                                                                                                      |
| 04                     | R/W            | 0               | <p>FIFO2_OF_INT_EN<br/>FIFO 2 overflow</p> <p>The bit is set when the FIFO 2 become overflow.</p>                                                                                                                    |
| 03                     | R/W            | 0               | <p>FIFO1_OF_INT_EN<br/>FIFO 1 overflow</p> <p>The bit is set when the FIFO 1 become overflow.</p>                                                                                                                    |

| Offset Address: 0X0030 |                |                 | Register Name: CSI1_INT_EN_REG                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 02                     | R/W            | 0               | FIFO0_OF_INT_EN<br>FIFO 0 overflow<br>The bit is set when the FIFO 0 become overflow.                                                                                                                                                                                                                                                                                                                                                                      |
| 01                     | R/W            | 0               | FD_INT_EN<br>Frame done<br>Indicates the CSI has finished capturing an image frame. Applies to video capture mode. The bit is set after each completed frame capturing data is wrote to buffer as long as video capture remains enabled.                                                                                                                                                                                                                   |
| 00                     | R/W            | 0               | CD_INT_EN<br>Capture done<br>Indicates the CSI has completed capturing the image data.<br>For still capture, the bit is set when one frame data has been wrote to buffer.<br>For video capture, the bit is set when the last frame has been wrote to buffer after video capture has been disabled.<br>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means field end. |

#### 4.2.6.14. CSI CHANNEL\_0 INTERRUPT STATUS REGISTER

| Offset Address: 0X0034 |                |                 | Register Name: CSI1_INT_STA_REG  |
|------------------------|----------------|-----------------|----------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                      |
| 31:08                  | /              | /               | /                                |
| 07                     | R/W            | 0               | VS_PD<br>vsync flag              |
| 06                     | R/W            | 0               | HB_OF_PD<br>Hblank FIFO overflow |
| 05                     | R/W            | 0               | PRTC_ERR_PD                      |
| 04                     | R/W            | 0               | FIFO2_OF_PD<br>FIFO 2 overflow   |

| Offset Address: 0X0034 |                |                 | Register Name: CSI1_INT_STA_REG |
|------------------------|----------------|-----------------|---------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                     |
| 03                     | R/W            | 0               | FIFO1_OF_PD<br>FIFO 1 overflow  |
| 02                     | R/W            | 0               | FIFO0_OF_PD<br>FIFO 0 overflow  |
| 01                     | R/W            | 0               | FD_PD<br>Frame done             |
| 00                     | R/W            | 0               | CD_PD<br>Capture done           |

#### 4.2.6.15. CSI CHANNEL\_0 HORIZONTAL SIZE REGISTER

| Offset Address: 0X0040 |                |                 | Register Name: CSI1_HSIZE_REG                                                   |
|------------------------|----------------|-----------------|---------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                     |
| 31:29                  | /              | /               | /                                                                               |
| 28:16                  | R/W            | 500             | HOR_LEN<br>Horizontal pixel clock length. Valid pixel clocks of a line.         |
| 15:13                  | /              | /               | /                                                                               |
| 12:00                  | R/W            | 0               | HOR_START<br>Horizontal pixel clock start. Pixel data is valid from this clock. |

#### 4.2.6.16. CSI CHANNEL\_0 VERTICAL SIZE REGISTER

| Offset Address: 0X0044 |                |                 | Register Name: CSI1_VSIZE_REG |
|------------------------|----------------|-----------------|-------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                   |

| Offset Address: 0X0044 |                |                 | Register Name: CSI1_VSIZE_REG                                   |
|------------------------|----------------|-----------------|-----------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                     |
| 31:29                  | /              | /               | /                                                               |
| 28:16                  | R/W            | 1E0             | VER_LEN<br>Vertical line length. Valid line number of a frame.  |
| 15:13                  | /              | /               | /                                                               |
| 12:00                  | R/W            | 0               | VER_START<br>Vertical line start. data is valid from this line. |

#### 4.2.6.17. CSI CHANNEL\_0 BUFFER LENGTH REGISTER

| Offset Address: 0X0048 |                |                 | Register Name: CSI1_BUF_LEN_REG                                                |
|------------------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit                    | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
| 31:13                  | /              | /               | /                                                                              |
| 12:00                  | R/W            | 280             | BUF_LEN<br>Buffer length of a line. Unit is byte. It is the max of the 3 FIFOs |

# Chapter 5 Display

This chapter provides a detailed description of the display feature of A20 processor from following aspects:

- TCON
- HDMI
- DISPLAY ENGINE FRONTEND
- DISPLAY ENGINE FRONTEND
- TVE

Here is the application block diagram of display module:



## 5.1. TCON

### 5.1.1. Overview

The TCON features:

- Support dual-channel LCD output
- Support LVDS interface with single/dual link, up to 1920x1080@60fps
- Support RGB interface with DE/SYNC mode, up to 2048x1536@60fps
- Support serial RGB/dummy RGB/CCIR656 interface, up to 1280x720@60fps
- Support i80 interface with 18/16/9/8 bits, up to 1280x720@60fps
- Dither function for RGB666/RGB565/RGB888
- Gamma correction with R/G/B channel independence

### 5.1.2. TCON Block Diagram



### 5.1.3. TCON Register List

| Module Name | Base Address |
|-------------|--------------|
| TCON0       | 0x01C0C000   |
| TCON1       | 0x01C0D000   |

| 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     |
| TCON_FRM_CTL_REG  | 0x0010 | TCON FRM control register           |
| 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_TTL0_REG    | 0x0070 | TCON0 ttl timing register0          |
| TCON0_TTL1_REG    | 0x0074 | TCON0 ttl timing register1          |
| TCON0_TTL2_REG    | 0x0078 | TCON0 ttl timing register2          |
| TCON0_TTL3_REG    | 0x007C | TCON0 ttl timing register3          |
| TCON0_TTL4_REG    | 0x0080 | TCON0 ttl timing register4          |
| TCON0_LVDS_IF_REG | 0x0084 | TCON0 lvds panel interface register |
| TCON0_IO_POL_REG  | 0x0088 | TCON0 IO polarity register          |
| TCON0_IO_TRI_REG  | 0x008C | TCON0 IO control register           |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>               |
|----------------------|---------------|----------------------------------|
| 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_MUL_RR_REG  | 0x0110        | TCON CEU coefficient register0   |
| TCON_CEU_MUL_RG_REG  | 0x0114        | TCON CEU coefficient register1   |
| TCON_CEU_MUL_RB_REG  | 0x0118        | TCON CEU coefficient register2   |
| TCON_CEU_ADD_RC_REG  | 0x011C        | TCON CEU coefficient register3   |
| TCON_CEU_MUL_GR_REG  | 0x0120        | TCON CEU coefficient register4   |
| TCON_CEU_MUL_GG_REG  | 0x0124        | TCON CEU coefficient register5   |
| TCON_CEU_MUL_GB_REG  | 0x0128        | TCON CEU coefficient register6   |
| TCON_CEU_ADD_GC_REG  | 0x012C        | TCON CEU coefficient register7   |
| TCON_CEU_MUL_BR_REG  | 0x0130        | TCON CEU coefficient register8   |
| TCON_CEU_MUL_BG_REG  | 0x0134        | TCON CEU coefficient register9   |
| TCON_CEU_MUL_BB_REG  | 0x0138        | TCON CEU coefficient register10  |
| TCON_CEU_ADD_BC_REG  | 0x013C        | TCON CEU coefficient register11  |
| TCON_CEU_RANGE_R_REG | 0x0140        | TCON CEU coefficient register12  |
| TCON_CEU_RANGE_G_REG | 0x0144        | TCON CEU coefficient register13  |
| TCON_CEU_RANGE_B_REG | 0x0148        | TCON CEU coefficient register14  |
| TCON1_FILL_CTL_REG   | 0x0300        | TCON1 fill data control register |
| TCON1_FILL_BEG0_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_BEG1_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  |

| Register Name         | Offset | Description                            |
|-----------------------|--------|----------------------------------------|
| TCON1_FILL_BEG2_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 | 0x0400 | TCON1 gamma table register 0x400-0x7FF |

## 5.1.4. TCON Register Description

### 5.1.4.1. TCON GLOBAL CONTROL REGISTER

| Offset: 0x000 |                |                 | Register Name: TCON_GCTL_REG                                                                             |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                              |
| 31            | R/W            | 0               | <b>TCON_En</b><br>0: disable<br>1: enable<br>When it's disabled, the module will be reset to idle state. |
| 30            | R/W            | 0               | <b>TCON_Gamma_En</b><br>0: disable<br>1: enable                                                          |
| 29:1          | /              | /               | /                                                                                                        |
| 0             | R/W            | 0               | <b>IO_Map_Sel</b><br>0: TCON0<br>1: TCON1<br>Note: this bit determined which IO_INV/IO_TRI are valid     |

### 5.1.4.2. TCON GLOBAL INTERRUPT REGISTER0

| Offset: 0x004 |                |                 | Register Name: TCON_GINT0_REG |
|---------------|----------------|-----------------|-------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                   |

| Offset: 0x004 |                |                 | Register Name: TCON_GINT0_REG                                                                               |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                 |
| 31            | R/W            | 0               | <b>TCON0_Vb_Int_En</b><br>0: disable<br>1: enable                                                           |
| 30            | R/W            | 0               | <b>TCON1_Vb_Int_En</b><br>0: disable<br>1: enable                                                           |
| 29            | R/W            | 0               | <b>TCON0_Line_Int_En</b><br>0: disable<br>1: enable                                                         |
| 28            | R/W            | 0               | <b>TCON1_Line_Int_En</b><br>0: disable<br>1: enable                                                         |
| 27:16         | /              | /               | /                                                                                                           |
| 15            | R/W            | 0               | <b>TCON0_Vb_Int_Flag</b><br>Asserted during vertical no-display period every frame.<br>Write 0 to clear it. |
| 14            | R/W            | 0               | <b>TCON1_Vb_Int_Flag</b><br>Asserted during vertical no-display period every frame.<br>Write 0 to clear it. |
| 13            | R/W            | 0               | <b>TCON0_Line_Int_Flag</b><br>trigger when SY0 match the current TCON0 scan line<br>Write 0 to clear it.    |
| 12            | R/W            | 0               | <b>TCON1_Line_Int_Flag</b><br>trigger when SY1 match the current TCON1 scan line<br>Write 0 to clear it.    |
| 11:0          | /              | /               | /                                                                                                           |

#### 5.1.4.3. TCON GLOBAL INTERRUPT REGISTER1

| Offset: 0x008 |                |                 | Register Name: TCON_GINT1_REG |
|---------------|----------------|-----------------|-------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                   |

| Offset: 0x008 |                |                 | Register Name: TCON_GINT1_REG                                                                                                                                                                     |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                       |
| 31:27         | /              | /               | /                                                                                                                                                                                                 |
| 26:16         | R/W            | 0               | <b>TCON0_Line_Int_Num</b><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 disable.  |
| 15:11         | /              | /               | /                                                                                                                                                                                                 |
| 10:0          | R/W            | 0               | <b>TCON1_Line_Int_Num</b><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 disable. |

#### 5.1.4.4. TCON FRM CONTROL REGISTER

| Offset: 0x010 |                |                 | Register Name: TCON_FRM_CTL_REG                                     |
|---------------|----------------|-----------------|---------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                         |
| 31            | R/W            | 0               | <b>TCON0_Frm_En</b><br>0:disable<br>1:enable                        |
| 30:7          | /              | /               | /                                                                   |
| 6             | R/W            | 0               | <b>TCON0_Frm_Mode_R</b><br>0: 6bit frm output<br>1: 5bit frm output |
| 5             | R/W            | 0               | <b>TCON0_Frm_Mode_G</b><br>0: 6bit frm output<br>1: 5bit frm output |
| 4             | R/W            | 0               | <b>TCON0_Frm_Mode_B</b><br>0: 6bit frm output<br>1: 5bit frm output |
| 3:2           | /              | /               | /                                                                   |
| 1:0           | R/W            | 0               | /                                                                   |

#### 5.1.4.5. TCON0 DATA CLOCK REGISTER

| Offset: 0x044 |                |                 | Register Name: TCON0_DCLK REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:28         | R/W            | 0               | <p><b>TCON0_Dclk_En</b></p> <p>LCLK_EN[3:0] :TCON0 clock enable</p> <p>4'h0,<br/>         'h4,4'h6,4'ha7:dclk_en=0;dclk1_en=0;dclk2_en=0;dclkm2_en=0;<br/>         4'h1: dclk_en = 1; dclk1_en = 0; dclk2_en = 0; dclkm2_en = 0;<br/>         4'h2: dclk_en = 1; dclk1_en = 0; dclk2_en = 0; dclkm2_en = 1;<br/>         4'h3: dclk_en = 1; dclk1_en = 1; dclk2_en = 0; dclkm2_en = 0;<br/>         4'h5: dclk_en = 1; dclk1_en = 0; dclk2_en = 1; dclkm2_en = 0;<br/>         4'h8,4'h9,4'ha,4'hb,4'hc,4'hd,4'he,4'hf:<br/>             dclk_en   = 1;<br/>             dclk1_en  = 1;<br/>             dclk2_en  = 1;<br/>             dclkm2_en = 1;</p> |
| 27:7          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6:0           | R/W            | 0               | <p><b>TCON0_Dclk_Div</b></p> <p>Tdclk = Tsclk * DCLKDIV</p> <p>Note:</p> <p>1.if dclk1&amp;dclk2 used,DCLKDIV &gt;=6</p> <p>2.if dclk only,DCLKDIV &gt;=4</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

#### 5.1.4.6. TCON0 BASIC TIMING REGISTER0

| Offset: 0x048 |                |                 | Register Name: TCON0_BASIC0_REG                 |
|---------------|----------------|-----------------|-------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                     |
| 31:27         | /              | /               | /                                               |
| 26:16         | R/W            | 0               | <p><b>TCON0_X</b></p> <p>Panel width is X+1</p> |
| 15:11         | /              | /               | /                                               |

| Offset: 0x048 |                |                 | Register Name: TCON0_BASIC0_REG       |
|---------------|----------------|-----------------|---------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                           |
| 10:0          | R/W            | 0               | <b>TCON0_Y</b><br>Panel height is Y+1 |

#### 5.1.4.7. TCON0 BASIC TIMING REGISTER1

| Offset: 0x04C |                |                 | Register Name: TCON0_BASIC1_REG                                                                                                                                                                                                                                                                        |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                            |
| 31            | R/W            | 0               | <b>UF_En</b><br>0: default<br>1: delay next line sync(Hsync in basic timing) until the FIFO1 is full<br>Note: it must be used when FIFO depth is less than one line active pixels.                                                                                                                     |
| 30:28         | /              | /               | /                                                                                                                                                                                                                                                                                                      |
| 27:16         | R/W            | 0               | <b>HT</b><br>$\text{Thcycle} = (\text{HT} + 1) * \text{Tdclk}$<br>Note: 1) parallel : $\text{HT} \geq (\text{HBP} + 1) + (\text{X} + 1) + 2$<br>2) serial 1: $\text{HT} \geq (\text{HBP} + 1) + (\text{X} + 1) * 3 + 2$<br>3) serial 2: $\text{HT} \geq (\text{HBP} + 1) + (\text{X} + 1) * 3 / 2 + 2$ |
| 15:10         | /              | /               | /                                                                                                                                                                                                                                                                                                      |
| 9:0           | R/W            | 0               | <b>HBP</b><br>horizontal back porch (in dclk)<br>$\text{Thbp} = (\text{HBP} + 1) * \text{Tdclk}$                                                                                                                                                                                                       |

#### 5.1.4.8. TCON0 BASIC TIMING REGISTER2

| Offset: 0x050 |                |                 | Register Name: TCON0_BASIC2_REG                                                                                                 |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                     |
| 31:28         | /              | /               | /                                                                                                                               |
| 27:16         | R/W            | 0               | <b>VT</b><br>$\text{TVT} = (\text{VT}) / 2 * \text{Thsync}$<br>Note: $\text{VT} / 2 \geq (\text{VBP} + 1) + (\text{Y} + 1) + 2$ |

| Offset: 0x050 |                |                 | Register Name: TCON0_BASIC2_REG           |
|---------------|----------------|-----------------|-------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                               |
| 15:10         | /              | /               | /                                         |
| 9:0           | R/W            | 0               | <b>VBP</b><br>$Tvbp = (VBP + 1) * Thsync$ |

#### 5.1.4.9. TCON0 BASIC TIMING REGISTER3

| Offset: 0x054 |                |                 | Register Name: TCON0_BASIC3_REG                                     |
|---------------|----------------|-----------------|---------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                         |
| 31:26         | /              | /               | /                                                                   |
| 25:16         | R/W            | 0               | <b>HSPW</b><br>$Thspw = (HSPW+1) * Tdclk$<br>Note: HT > (HSPW+1)    |
| 15:10         | /              | /               | /                                                                   |
| 9:0           | R/W            | 0               | <b>VSPW</b><br>$Tvspw = (VSPW+1) * Thsync$<br>Note: VT/2 > (VSPW+1) |

#### 5.1.4.10. TCON0 HV PANEL INTERFACE REGISTER

| Offset: 0x058 |                |                 | Register Name: TCON0_HV_IF_REG                                                                          |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                             |
| 31            | R/W            | 0               | <b>HV_Mode</b><br>0: 24bit parallel mode<br>1: 8bit serial mode                                         |
| 30            | R/W            | 0               | <b>Serial_Mode</b><br>0: 8bit/3cycle RGB serial mode(RGB888)<br>1: 8bit/2cycle YUV serial mode(CCIR656) |
| 29:28         | /              | /               | /                                                                                                       |
| 27:26         | R/W            | 0               | <b>RGB888_SM0</b>                                                                                       |

| Offset: 0x058 |                |                 | Register Name: TCON0_HV_IF_REG                                                                                                                                         |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                            |
|               |                |                 | serial RGB888 mode Output sequence at odd lines of the panel<br>(line 1, 3, 5, 7...)<br>00: R->G->B<br>01: B->R->G<br>10: G->B->R<br>11: R->G->B                       |
| 25:24         | R/W            | 0               | <b>RGB888_SM1</b><br>serial RGB888 mode Output sequence at even lines of the panel<br>(line 2, 4, 6, 8...)<br>00: R->G->B<br>01: B->R->G<br>10: G->B->R<br>11: R->G->B |
| 23:22         | R/W            | 0               | <b>YUV_SM</b><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               | <b>YUV EAV/SAV F line delay</b><br>0:F toggle right after active video line<br>1:delay 2 line(CCIR NTSC)<br>2:delay 3 line(CCIR PAL)<br>3:reserved                     |
| 19:0          | /              | /               | /                                                                                                                                                                      |

#### 5.1.4.11. TCON0 CPU PANEL INTERFACE REGISTER

| Offset: 0x060 |                |                 | Register Name: TCON0_CPU_IF_REG                            |
|---------------|----------------|-----------------|------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                |
| 31:29         | R/W            | 0               | <b>CPU_MOD</b><br>000: 18bit/256K mode<br>001: 16bit mode0 |

| Offset: 0x060 |                |                 | Register Name: TCON0_CPU_IF_REG                                                                                                                                                                          |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                              |
|               |                |                 | 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               | <b>AUTO</b><br>auto Transfer Mode:<br>If it's 1, all the valid data during this frame are write to panel.<br>Note: This bit is sampled by Vsync                                                          |
| 27            | R/W            | 0               | <b>FLUSH</b><br>direct transfer mode:<br>If it's enabled, FIFO1 is regardless of the HV timing, pixels data keep being transferred unless the input FIFO was empty.<br>Data output rate control by DCLK. |
| 26            | R/W            | 0               | <b>DA</b><br>pin A1 value in 8080 mode auto/flash states                                                                                                                                                 |
| 25            | R/W            | 0               | <b>CA</b><br>pin A1 value in 8080 mode WR/RD execute                                                                                                                                                     |
| 24            | R/W            | 0               | <b>VSYNC_Cs_Sel</b><br>0:CS<br>1:VSYNC                                                                                                                                                                   |
| 23            | R              | 0               | <b>Wr_Flag</b><br>0:write operation is finishing<br>1:write operation is pending                                                                                                                         |
| 22            | R              | 0               | <b>Rd_Flag</b><br>0:read operation is finishing<br>1:read operation is pending                                                                                                                           |
| 21:0          | /              | /               | /                                                                                                                                                                                                        |

#### 5.1.4.12. TCON0 CPU PANEL WRITE DATA REGISTER

| Offset: 0x064 | Register Name: TCON0_CPU_WR_REG |
|---------------|---------------------------------|
|---------------|---------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                             |
|------------|------------------------|-------------------------|--------------------------------------------------------------------------------|
| 31:24      | /                      | /                       | /                                                                              |
| 23:0       | W                      | 0                       | <b>Data_Wr</b><br>data write on 8080 bus, launch a write operation on 8080 bus |

#### 5.1.4.13. TCON0 CPU PANEL READ DATA REGISTER0

| <b>Offset: 0x068</b> |                        |                         | <b>Register Name: TCON0_CPU_RD0_REG</b>                                           |
|----------------------|------------------------|-------------------------|-----------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                |
| 31:24                | /                      | /                       | /                                                                                 |
| 23:0                 | R                      | /                       | <b>Data_Rd0</b><br>data read on 8080 bus, launch a new read operation on 8080 bus |

#### 5.1.4.14. TCON0 CPU PANEL READ DATA REGISTER1

| <b>Offset: 0x06C</b> |                        |                         | <b>Register Name: TCON0_CPU_RD1_REG</b>                                            |
|----------------------|------------------------|-------------------------|------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                 |
| 31:24                | /                      | /                       | /                                                                                  |
| 23:0                 | R                      | /                       | <b>Data_Rd1</b><br>data read on 8080 bus, without a new read operation on 8080 bus |

#### 5.1.4.15. TCON0 TTL PANEL TIMING REGISTER 0

| <b>Offset: 0x070</b> |                        |                         | <b>Register Name: TCON0_TTL0_REG</b>                                                                                |
|----------------------|------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                  |
| 31:20                | R/W                    | 0                       | <b>STVH</b><br>STV high plus width (in dclk)<br>$Tstvh = (STVH + 1) * Tdclk$<br>Note: STV has a period of one frame |

| Offset: 0x070 |                |                 | Register Name: TCON0_TTL0_REG                                                             |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                               |
| 19:0          | R/W            | 0               | <b>STVD</b><br>VSYNC-STV delay time<br>$Tstvd = STVD[19:10] * Thsync + STVD[9:0] * Tdclk$ |

#### 5.1.4.16. TCON0 TTL PANEL TIMING REGISTER 1

| Offset: 0x074 |                |                 | Register Name: TCON0_TTL1_REG                                                |
|---------------|----------------|-----------------|------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                  |
| 31:30         | R/W            | 0               | <b>CKVT</b><br>CKV period (in line)<br>$Tckvt = (CKVT + 1) * Thsync$         |
| 29:20         | /              | /               | /                                                                            |
| 19:10         | R/W            | 0               | <b>CKVH</b><br>CKV high plus width (in dclk)<br>$Tckvh = (CKVH + 1) * Tdclk$ |
| 9:0           | R/W            | 0               | <b>CKVD</b><br>VSYNC –CKV delay time(in dclk)<br>$Tdskv = CKVD * Tdclk$      |

#### 5.1.4.17. TCON0 TTL PANEL TIMING REGISTER 2

| Offset: 0x078 |                |                 | Register Name: TCON0_TTL2_REG                                      |
|---------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                        |
| 31:30         | R/W            | 0               | <b>OEV</b><br>OEV period (in line)<br>$Toevt = (OEV + 1) * Thsync$ |
| 29:20         | /              | /               | /                                                                  |
| 19:10         | R/W            | 0               | <b>OEVH</b><br>OEV high plus width (in dclk)                       |

| Offset: 0x078 |                |                 | Register Name: TCON0_TTL2_REG                                         |
|---------------|----------------|-----------------|-----------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                           |
|               |                |                 | Toevh = (OEVH + 1) * Tdclk                                            |
| 9:0           | R/W            | 0               | <b>OEVD</b><br>VSYNC -OEV delay time(in dclk)<br>Toevd = OEVD * Tdclk |

#### 5.1.4.18. TCON0 TTL PANEL TIMING REGISTER3

| Offset: 0x07C |                |                 | Register Name: TCON0_TTL3_REG                                                                                  |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                    |
|               |                |                 | <b>STHH</b><br>STH high plus time(in dclk)<br>$Tsthh = (STHH+1) * Tdclk$<br>Note: STH has a period of one line |
| 31:26         | R/W            | 0               | <b>STHD</b><br>HSYNC-STH delay time(in dclk)<br>$Tsthd = STHD * Tdclk$                                         |
|               |                |                 | <b>OEHH</b><br>OEH high plus time(in dclk)<br>$Tlhd = (OEHH+1) * Tdclk$                                        |
| 15:10         | R/W            | 0               | <b>OEHD</b><br>HSYNC -OEH delay time(in dclk)<br>$Tldd = OEHD * Tdclk$                                         |
| 9:0           | R/W            | 0               |                                                                                                                |

#### 5.1.4.19. TCON0 TTL PANEL TIMING REGISTER3

| Offset: 0x080 |                |                 | Register Name: TCON0_TTL4_REG |
|---------------|----------------|-----------------|-------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                   |
| 31:24         | /              | /               | /                             |
| 23            | R/W            | 0               | <b>Output_Data_Rate</b>       |

| Offset: 0x080 |                |                 | Register Name: TCON0_TTL4_REG                                                                                                                                                                                                                                                                                                                                       |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                         |
|               |                |                 | <p>0: single data rate (SDR).<br/> LCD read data at the rising edge of clock<br/> 1: Double data rate (DDR).<br/> (The first data of every line must be ready at rising edge of CKH/CKH1/CKH2.)<br/> Note: When DATA_RATE = 1, HT and HBP had better be even number;<br/> CKH-CKH1 and CKH1-CKH2 delay time is always 1/3 Tdclk</p>                                 |
| 22            | R/W            | 0               | <p><b>Rev_Sel</b><br/> REV toggle mode<br/> 0:1H time toggle mode with frame inversion<br/> 1: Frame toggle mode<br/> Note: no matter in which mode, make sure REV has different polarity at the beginning of every frame (take VSYNC as reference).</p>                                                                                                            |
| 21            | R/W            | 0               | <p><b>TTL_Data_Inv_En</b><br/> 0: disable<br/> 1: data inverted ref to REV signal</p>                                                                                                                                                                                                                                                                               |
| 20            | R/W            | 0               | <p><b>TTL_Data_Inv_Sel</b><br/> TTL data invert mode<br/> 0: bit inverted when REV is 1<br/> 1: bit inverted when REV is 0</p>                                                                                                                                                                                                                                      |
| 19:10         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                   |
| 9:0           | R/W            | 0               | <p><b>REVD</b><br/> HSYNC-REV delay time(in dclk)<br/> <math>T_{revd} = REVD * T_{dclk}</math><br/> Note:<br/> 1. When <b>REV_SEL</b> is 0, REV has a 2H period with 50% duty.<br/> 2. When <b>REV_SEL</b> is 1, REV has a 2 Frame period with 50% duty.<br/> 3. Make sure REV has different polarity at the beginning of every frame(take VSYNC as reference).</p> |

#### 5.1.4.20. TCON0 LVDS PANEL INTERFACE REGISTER

| Offset: 0x084 |                |                 | Register Name: TCON0_LVDS_IF_REG                                  |
|---------------|----------------|-----------------|-------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                       |
| 31            | R/W            | 0               | TCON0_LVDS_En<br>0: disable<br>1: enable                          |
| 30:29         | /              | /               | /                                                                 |
| 28            | R/W            | 0               | TCON0_LVDS_Dir<br>1: normal<br>2: reverse<br>NOTE: LVDS direction |
| 27            | R/W            | 0               | TCON0_LVDS_Mode<br>0: NS mode<br>1: JEIDA mode                    |
| 26            | R/W            | 0               | TCON0_LVDS_BitWidth<br>0: 24bit<br>1: 18bit                       |
| 25:24         | R/W            | 0               | /                                                                 |
| 23            | R/W            | 0               | TCON0_LVDS_Correct_Mode<br>0: mode0<br>1: mode1                   |
| 22:0          | /              | /               | /                                                                 |

#### 5.1.4.21. TCON0 IO POLARITY REGISTER

| Offset: 0x088 |                |                 | Register Name: TCON0_IO_POL_REG                                                                                                                |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                    |
| 31:30         | /              | /               | /                                                                                                                                              |
| 29:28         | R/W            | 0               | <b>DCLK_Sel</b><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 |

| Offset: 0x088 |                |                 | Register Name: TCON0_IO_POL_REG                                                                                                                      |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                          |
| 27            | R/W            | 0               | <b>IO3_Inv</b><br>0: not invert<br>1: invert                                                                                                         |
| 26            | R/W            | 0               | <b>IO2_Inv</b><br>0: not invert<br>1: invert                                                                                                         |
| 25            | R/W            | 0               | <b>IO1_Inv</b><br>0: not invert<br>1: invert                                                                                                         |
| 24            | R/W            | 0               | <b>IO0_Inv</b><br>0: not invert<br>1: invert                                                                                                         |
| 23:0          | R/W            | 0               | <b>Data_Inv</b><br>TCON0 output port D[23:0] polarity control, with independent bit control:<br>0s: normal polarity<br>1s: invert the specify output |

#### 5.1.4.22. TCON0 IO CONTROL REGISTER

| Offset: 0x08C |                |                 | Register Name: TCON0_IO_TRI_REG                     |
|---------------|----------------|-----------------|-----------------------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                                         |
| 31:28         | /              | /               | /                                                   |
| 27            | R/W            | 1               | <b>IO3_Output_Tri_En</b><br>1: disable<br>0: enable |
| 26            | R/W            | 1               | <b>IO2_Output_Tri_En</b><br>1: disable<br>0: enable |
| 25            | R/W            | 1               | <b>IO1_Output_Tri_En</b><br>1: disable<br>0: enable |

| Offset: 0x08C |                |                 | Register Name: TCON0_IO_TRI_REG                                                                                                  |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                                                                                                                      |
| 24            | R/W            | 1               | <b>IO0_Output_Tri_En</b><br>1: disable<br>0: enable                                                                              |
| 23:0          | R/W            | 0xFFFFFFF       | <b>Data_Output_Tri_En</b><br>TCON0 output port D[23:0] output enable, with independent bit control:<br>1s: disable<br>0s: enable |

#### 5.1.4.23. TCON1 CONTROL REGISTER

| Offset: 0x090 |                |                 | Register Name: TCON1_CTL_REG                                                                                             |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                              |
| 31            | R/W            | 0               | <b>TCON1_En</b><br>0: disable<br>1: enable                                                                               |
| 30:21         | /              | /               | /                                                                                                                        |
| 20            | R/W            | 0               | <b>Interlace_En</b><br>0:disable<br>1:enable                                                                             |
| 19:9          | /              | /               | /                                                                                                                        |
| 8:4           | R/W            | 0               | <b>Start_Delay</b><br>This is for DE1 and DE2                                                                            |
| 3:2           | /              | /               | /                                                                                                                        |
| 1:0           | R/W            | 0               | <b>TCON1_Src_Sel</b><br>00: DE CH1(FIFO2 enable)<br>01: DE CH2(FIFO2 enable)<br>1x: BLUE data(FIFO2 disable, RGB=0000FF) |

#### 5.1.4.24. TCON1 BASIC TIMING REGISTER0

| Offset: 0x094 |                |                 | Register Name: TCON1_BASIC0_REG         |
|---------------|----------------|-----------------|-----------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                             |
| 31:28         | /              | /               | /                                       |
| 27:16         | R/W            | 0               | <b>TCON1_XI</b><br>source width is X+1  |
| 15:12         | /              | /               | /                                       |
| 11:0          | R/W            | 0               | <b>TCON1_YI</b><br>source height is Y+1 |

#### 5.1.4.25. TCON1 BASIC TIMING REGISTER1

| Offset: 0x098 |                |                 | Register Name: TCON1_BASIC1_REG                                         |
|---------------|----------------|-----------------|-------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                             |
| 31:28         | /              | /               | /                                                                       |
| 27:16         | R/W            | 0               | <b>LS_XO</b><br>width is LS_XO+1                                        |
| 15:12         | /              | /               | /                                                                       |
| 11:0          | R/W            | 0               | <b>LS_YO</b><br>width is LS_YO+1<br>NOTE: this version LS_YO = TCON1_YI |

#### 5.1.4.26. TCON1 BASIC TIMING REGISTER2

| Offset: 0x09C |                |                 | Register Name: TCON1_BASIC2_REG        |
|---------------|----------------|-----------------|----------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                            |
| 31:28         | /              | /               | /                                      |
| 27:16         | R/W            | 0               | <b>TCON1_XO</b><br>width is TCON1_XO+1 |
| 15:12         | /              | /               | /                                      |

| Offset: 0x09C |                |                 | Register Name: TCON1_BASIC2_REG         |
|---------------|----------------|-----------------|-----------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                             |
| 11:0          | R/W            | 0               | <b>TCON1_YO</b><br>height is TCON1_YO+1 |

#### 5.1.4.27. TCON1 BASIC TIMING REGISTER3

| Offset: 0x0A0 |                |                 | Register Name: TCON1_BASIC3_REG                                                         |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                             |
| 31:29         | /              | /               | /                                                                                       |
| 28:16         | R/W            | 0               | <b>HT</b><br>horizontal total time<br>$\text{Thcycle} = (\text{HT}+1) * \text{Thdclk}$  |
| 15:12         | /              | /               | /                                                                                       |
| 11:0          | R/W            | 0               | <b>HBP</b><br>horizontal back porch<br>$\text{Thbp} = (\text{HBP} + 1) * \text{Thdclk}$ |

#### 5.1.4.28. TCON1 BASIC TIMING REGISTER4

| Offset: 0x0A4 |                |                 | Register Name: TCON1_BASIC4_REG                                                                  |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                      |
| 31:29         | /              | /               | /                                                                                                |
| 28:16         | R/W            | 0               | <b>VT</b><br>horizontal total time (in HD line)<br>$\text{Tvt} = \text{VT}/2 * \text{Th}$        |
| 15:12         | /              | /               | /                                                                                                |
| 11:0          | R/W            | 0               | <b>VBP</b><br>horizontal back porch (in HD line)<br>$\text{Tvbp} = (\text{VBP} + 1) * \text{Th}$ |

#### 5.1.4.29. TCON1 BASIC TIMING REGISTER5

| Offset: 0x0A8 |                |                 | Register Name: TCON1_BASIC5_REG                                                                                 |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                     |
| 31:26         | /              | /               | /                                                                                                               |
| 25:16         | R/W            | 0               | <b>HSPW</b><br>horizontal Sync Pulse Width (in dclk)<br>$T_{hspw} = (HSPW+1) * T_{dclk}$<br>Note: HT > (HSPW+1) |
| 15:10         | /              | /               | /                                                                                                               |
| 9:0           | R/W            | 0               | <b>VSPW</b><br>vertical Sync Pulse Width (in lines)<br>$T_{vspw} = (VSPW+1) * Th$<br>Note: VT/2 > (VSPW+1)      |

#### 5.1.4.30. TCON1 IO POLARITY REGISTER

| Offset: 0x0F0 |                |                 | Register Name: TCON1_IO_POL_REG              |
|---------------|----------------|-----------------|----------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                  |
| 31:28         | /              | /               | /                                            |
| 27            | R/W            | 0               | <b>IO3_Inv</b><br>0: not invert<br>1: invert |
| 26            | R/W            | 0               | <b>IO2_Inv</b><br>0: not invert<br>1: invert |
| 25            | R/W            | 0               | <b>IO1_Inv</b><br>0: not invert<br>1: invert |
| 24            | R/W            | 0               | <b>IO0_Inv</b><br>0: not invert<br>1: invert |

| Offset: 0x0F0 |                |                 | Register Name: TCON1_IO_POL_REG                                                                                                                    |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                        |
| 23:0          | R/W            | 0               | <b>Data_Inv:</b> TCON1 output port D[23:0] polarity control, with independent bit control:<br>0s: normal polarity<br>1s: invert the specify output |

#### 5.1.4.31. TCON1 IO CONTROL REGISTER

| Offset: 0x0F4 |                |             | Register Name: TCON1_IO_TRI_REG                                                                                                  |
|---------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                      |
| 31:28         | /              | /           | /                                                                                                                                |
| 27            | R/W            | 1           | <b>IO3_Output_Tri_En</b><br>1: disable<br>0: enable                                                                              |
| 26            | R/W            | 1           | <b>IO2_Output_Tri_En</b><br>1: disable<br>0: enable                                                                              |
| 25            | R/W            | 1           | <b>IO1_Output_Tri_En</b><br>1: disable<br>0: enable                                                                              |
| 24            | R/W            | 1           | <b>IO0_Output_Tri_En</b><br>1: disable<br>0: enable                                                                              |
| 23:0          | R/W            | 0xFFFFFFF   | <b>Data_Output_Tri_En</b><br>TCON1 output port D[23:0] output enable, with independent bit control:<br>1s: disable<br>0s: enable |

#### 5.1.4.32. TCON CEU CONTROL REGISTER

| Offset: 0x100 |                |             | Register Name: TCON_CEU_CTL_REG |
|---------------|----------------|-------------|---------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                     |

| Offset: 0x100 |                |             | Register Name: TCON_CEU_CTL_REG         |
|---------------|----------------|-------------|-----------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                             |
| 31            | R/W            | 0           | <b>CEU_en</b><br>0: bypass<br>1: enable |
| 30:0          | /              | /           | /                                       |

#### 5.1.4.33. TCON CEU COEFFICIENT REGISTER

| Offset: 0x110 |                |                 | Register Name: TCON_CEU_MUL_RR_REG                         |
|---------------|----------------|-----------------|------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                |
| 31:13         | /              | /               | /                                                          |
| 12:0          | R/W            | 0               | <b>Coef_Value</b><br>signed 13bit value, range of (-16,16) |

| Offset: 0x114 |                |                 | Register Name: TCON_CEU_MUL_RG_REG                         |
|---------------|----------------|-----------------|------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                |
| 31:13         | /              | /               | /                                                          |
| 12:0          | R/W            | 0               | <b>Coef_Value</b><br>signed 13bit value, range of (-16,16) |

| Offset: 0x118 |                |                 | Register Name: TCON_CEU_MUL_RB_REG                         |
|---------------|----------------|-----------------|------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                |
| 31:13         | /              | /               | /                                                          |
| 12:0          | R/W            | 0               | <b>Coef_Value</b><br>signed 13bit value, range of (-16,16) |

| Offset: 0x11c |                |                 | Register Name: TCON_CEU_ADD_RC_REG |
|---------------|----------------|-----------------|------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                        |
| 31:19         | /              | /               | /                                  |

| Offset: 0x11c |                |                 | Register Name: TCON_CEU_ADD_RC_REG                                |
|---------------|----------------|-----------------|-------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                       |
| 18:0          | R/W            | 0               | <b>Coef_Value</b><br>signed 19bit value, range of (-16384, 16384) |

| Offset: 0x120 |                |                 | Register Name: TCON_CEU_MUL_GR_REG                          |
|---------------|----------------|-----------------|-------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                 |
| 31:13         | /              | /               | /                                                           |
| 12:0          | R/W            | 0               | <b>Coef_Value</b><br>signed 13bit value, range of (-16, 16) |

| Offset: 0x124 |                |                 | Register Name: TCON_CEU_MUL_GG_REG                          |
|---------------|----------------|-----------------|-------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                 |
| 31:13         | /              | /               | /                                                           |
| 12:0          | R/W            | 0               | <b>Coef_Value</b><br>signed 13bit value, range of (-16, 16) |

| Offset: 0x128 |                |                 | Register Name: TCON_CEU_MUL_GB_REG                          |
|---------------|----------------|-----------------|-------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                 |
| 31:13         | /              | /               | /                                                           |
| 12:0          | R/W            | 0               | <b>Coef_Value</b><br>signed 13bit value, range of (-16, 16) |

| Offset: 0x12C |                |                 | Register Name: TCON_CEU_ADD_GC_REG                                |
|---------------|----------------|-----------------|-------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                       |
| 31:19         | /              | /               | /                                                                 |
| 18:0          | R/W            | 0               | <b>Coef_Value</b><br>signed 19bit value, range of (-16384, 16384) |

| Offset: 0x130 |  |  | Register Name: TCON_CEU_MUL_BR_REG |
|---------------|--|--|------------------------------------|
|---------------|--|--|------------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                         |
|------------|------------------------|-------------------------|------------------------------------------------------------|
| 31:13      | /                      | /                       | /                                                          |
| 12:0       | R/W                    | 0                       | <b>Coef_Value</b><br>signed 13bit value, range of (-16,16) |

| <b>Offset: 0x134</b> |                        |                         | <b>Register Name: TCON_CEU_MUL_BG_REG</b>                  |
|----------------------|------------------------|-------------------------|------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                         |
| 31:13                | /                      | /                       | /                                                          |
| 12:0                 | R/W                    | 0                       | <b>Coef_Value</b><br>signed 13bit value, range of (-16,16) |

| <b>Offset: 0x138</b> |                        |                         | <b>Register Name: TCON_CEU_MUL_BB_REG</b>                  |
|----------------------|------------------------|-------------------------|------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                         |
| 31:13                | /                      | /                       | /                                                          |
| 12:0                 | R/W                    | 0                       | <b>Coef_Value</b><br>signed 13bit value, range of (-16,16) |

| <b>Offset: 0x13C</b> |                        |                         | <b>Register Name: TCON_CEU_ADD_BC_REG</b>                         |
|----------------------|------------------------|-------------------------|-------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                |
| 31:19                | /                      | /                       | /                                                                 |
| 18:0                 | R/W                    | 0                       | <b>Coef_Value</b><br>signed 19bit value, range of (-16384, 16384) |

| <b>Offset: 0x140</b> |                        |                         | <b>Register Name: TCON_CEU_RANGE_R_REG</b>                     |
|----------------------|------------------------|-------------------------|----------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                             |
| 31:24                | /                      | /                       | /                                                              |
| 23:16                | R/W                    | 0                       | <b>Coef_Range_Min</b><br>unsigned 8bit value, range of [0,255] |

| Offset: 0x140 |                |                 | Register Name: TCON_CEU_RANGE_R_REG                            |
|---------------|----------------|-----------------|----------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                    |
| 15:8          | /              | /               | /                                                              |
| 7:0           | R/W            | 0               | <b>Coef_Range_Max</b><br>unsigned 8bit value, range of [0,255] |

| Offset: 0x144 |                |                 | Register Name: TCON_CEU_RANGE_G_REG                            |
|---------------|----------------|-----------------|----------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                    |
| 31:24         | /              | /               | /                                                              |
| 23:16         | R/W            | 0               | <b>Coef_Range_Min</b><br>unsigned 8bit value, range of [0,255] |
| 15:8          | /              | /               | /                                                              |
| 7:0           | R/W            | 0               | <b>Coef_Range_Max</b><br>unsigned 8bit value, range of [0,255] |

| Offset: 0x148 |                |                 | Register Name: TCON_CEU_RANGE_B_REG                            |
|---------------|----------------|-----------------|----------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                    |
| 31:24         | /              | /               | /                                                              |
| 23:16         | R/W            | 0               | <b>Coef_Range_Min</b><br>unsigned 8bit value, range of [0,255] |
| 15:8          | /              | /               | /                                                              |
| 7:0           | R/W            | 0               | <b>Coef_Range_Max</b><br>unsigned 8bit value, range of [0,255] |

#### 5.1.4.34. TCON1 FILL DATA CONTROL REGISTER

| Offset: 0x300 |                |                 | Register Name: TCON1_FILL_CTL_REG |
|---------------|----------------|-----------------|-----------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                       |
| 31            | R/W            | 0               | <b>TCON1_Fill_En:</b>             |

| Offset: 0x300 |                |                 | Register Name: TCON1_FILL_CTL_REG |
|---------------|----------------|-----------------|-----------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                       |
|               |                |                 | 0: bypass<br>1: enable            |
| 30:0          | /              | /               | /                                 |

#### 5.1.4.35. TCON1 FILL DATA BEGIN REGISTER

| Offset: 0x304 |                |                 | Register Name: TCON1_FILL_BEG0_REG |
|---------------|----------------|-----------------|------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                        |
| 31:24         | /              | /               | /                                  |
| 23:0          | R/W            | 0               | Fill_Begin                         |

#### 5.1.4.36. TCON1 FILL DATA END REGISTER

| Offset: 0x308 |                |                 | Register Name: TCON1_FILL_END0_REG |
|---------------|----------------|-----------------|------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                        |
| 31:24         | /              | /               | /                                  |
| 23:0          | R/W            | 0               | Fill_End                           |

#### 5.1.4.37. TCON1 FILL DATA VALUE REGISTER

| Offset: 0x30C |                |                 | Register Name: TCON1_FILL_DATA0_REG |
|---------------|----------------|-----------------|-------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                         |
| 31:24         | /              | /               | /                                   |
| 23:0          | R/W            | 0               | Fill_Value                          |

#### 5.1.4.38. TCON1 FILL DATA BEGIN REGISTER

| Offset: 0x310 |                |                 | Register Name: TCON1_FILL_BEG1_REG |
|---------------|----------------|-----------------|------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                        |
| 31:24         | /              | /               | /                                  |
| 23:0          | R/W            | 0               | Fill_Begin                         |

#### 5.1.4.39. TCON1 FILL DATA END REGISTER

| Offset: 0x314 |                |                 | Register Name: TCON1_FILL_END1_REG |
|---------------|----------------|-----------------|------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                        |
| 31:24         | /              | /               | /                                  |
| 23:0          | R/W            | 0               | Fill_End                           |

#### 5.1.4.40. TCON1 FILL DATA VALUE REGISTER

| Offset: 0x318 |                |                 | Register Name: TCON1_FILL_DATA1_REG |
|---------------|----------------|-----------------|-------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                         |
| 31:24         | /              | /               | /                                   |
| 23:0          | R/W            | 0               | Fill_Value                          |

#### 5.1.4.41. TCON1 FILL DATA BEGIN REGISTER

| Offset: 0x31C |                |                 | Register Name: TCON1_FILL_BEG2_REG |
|---------------|----------------|-----------------|------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                        |
| 31:24         | /              | /               | /                                  |
| 23:0          | R/W            | 0               | Fill_Begin                         |

#### 5.1.4.42. TCON1 FILL DATA END REGISTER

| Offset: 0x320 |                |                 | Register Name: TCON1_FILL_END2_REG |
|---------------|----------------|-----------------|------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                        |
| 31:24         | /              | /               | /                                  |
| 23:0          | R/W            | 0               | Fill_End                           |

#### 5.1.4.43. TCON1 FILL DATA VALUE REGISTER

| Offset: 0x324 |                |                 | Register Name: TCON1_FILL_DATA2_REG |
|---------------|----------------|-----------------|-------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                         |
| 31:24         | /              | /               | /                                   |
| 23:0          | R/W            | 0               | Fill_Value                          |

## 5.2. HDMI

### 5.2.1. Overview

The basic video and audio features:

- Comply with the HDMI v1.3 with HDCP
- Support up to 165M pixel per second
- Support 480i/576i/480p/576p/720p/1080i/1080p at 24/25/30/50/59.9Hz
- Support 1080p/24 3D output
- Support up to 8 channels, 24-bit PCM(IEC60958)
- Support IEC61937 compress audio formats
- Hardware receiver active sense and hot plug detection

### 5.2.2. HDMI Block Diagram



### 5.2.3. HDMI Control Register Description

| Module Name | Base Address |
|-------------|--------------|
| HDMI        | 0x01C16000   |

Base address:

| Register Name | Offset | Description                   |
|---------------|--------|-------------------------------|
| Version_ID    | 0x000  | Version ID register           |
| 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       |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>              |
|----------------------|---------------|---------------------------------|
| 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               |
| PLL_Dbgo             | 0x20c         | PLL/DRV Setting 3               |
| PLL_Dbgi             | 0x210         | PLL/DRV Setting 4               |
| HPD_CEC              | 0x214         | PLL/DRV Setting 5               |
| SPD_Pkt              | 0x240         | SPD packet                      |
| Pkt_Ctrl0            | 0x2f0         | PACKET_CONTROL0                 |
| Pkt_Ctrl0            | 0x2f4         | PACKET_CONTROL1                 |
| HDMI_DBG4            | 0x310         | Audio sample counter            |
| 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       |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>          |
|----------------------|---------------|-----------------------------|
| DDC_FIFO_Status      | 0x514         | DDC FIFO Status Register    |
| DDC_FIFO_Access      | 0x518         | DDC FIFO Access Register    |
| DDC_Byte_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          |
| DDC_DBG              | 0x540         | DDC Slave Address Register  |

## 5.2.4. HDMI Register Description

### 5.2.4.1. HDMI VERSION ID

| <b>Offset: 0x000</b> |                        |                         | <b>Register name: Version_ID</b>     |
|----------------------|------------------------|-------------------------|--------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                   |
| 31:16                | R                      | 0x0001                  | VER_ID_H: Version number of the core |
| 15:0                 | R                      | 0x0003                  | VER_ID_L: Version number of the core |

### 5.2.4.2. SYSTEM CONTROL REGISTER

| <b>Offset: 0x004</b> |                        |                         | <b>Register name: Ctrl</b>          |
|----------------------|------------------------|-------------------------|-------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                  |
| 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                            |

| Offset: 0x004 |                |                 | Register name: Ctrl                                     |
|---------------|----------------|-----------------|---------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                             |
| 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   |

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

| Offset: 0x008 |             |              | Register name: Int_Status                                                                                                                |
|---------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                              |
| 5             | R/Clear     | 0            | AUD_FIFO_OVER_FLOW<br>Audio input fifo over flow flag<br>0: normal<br>1: over flow happen                                                |
| 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<br>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                                             |

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

| Offset: 0x00c |             |              | Register name: HPD                                             |
|---------------|-------------|--------------|----------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                    |
|               |             |              | 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         |

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

| Offset: 0x010 |             |              | Register name: VID_Ctrl                                                                                            |
|---------------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                        |
| 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                        |

#### 5.2.4.6. 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:                                                                |

| Offset: 0x014 |             |              | Register name: VID_Timing_0                                  |
|---------------|-------------|--------------|--------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                  |
|               |             |              | Video active horizontal resolution is:<br>VID_ACT_H+1 pixels |

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

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

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

#### 5.2.4.10. VIDEO TIMING REGISTER4

| Offset: 0x024 |             |              | Register name: VID_Timing_4                                                          |
|---------------|-------------|--------------|--------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                          |
| 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 |

#### 5.2.4.11. AUDIO CONTROL REGISTER:

| Offset: 0x040 |             |              | Register name: Aud_Ctrl                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31            | R/W         | 0            | <p>AUD_EN:<br/>0:disable<br/>1:enable</p> <p>Audio module enable</p>                                                                                                                                                                                                                                                                                                                                              |
| 30            | R/W         | 0            | <p>AUD_RST:<br/>0: normal<br/>1: reset</p> <p>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.</p> <p>Note: before change the audio parameters, first disable the AUD_EN, then write 1 to AUD_RST to reset the audio module, when this reset bit return to 0, then configure the parameters and enable the AUD_EN.</p> |
| 29:0          | /           | /            | reserved                                                                                                                                                                                                                                                                                                                                                                                                          |

#### 5.2.4.12. AUDIO DMA&FIFO CONTROL REGISTER:

| Offset: 0x044 |             |              | Register name: ADMA_Ctrl                                            |
|---------------|-------------|--------------|---------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                         |
| 31            | R/W         | 0            | <p>Audio Source DMA Mode<br/>0: dedicated DMA<br/>1: normal DMA</p> |
| 30:26         | /           | /            | reserved                                                            |
| 25:24         | R/W         | 0            | DMA REQ CRTL<br>00: 1/2 FIFO empty                                  |

| Offset: 0x044 |             |              | Register name: ADMA_Ctrl                                                                                     |
|---------------|-------------|--------------|--------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                  |
|               |             |              | 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><br>Audio data to send when FIFO is underflow               |

#### 5.2.4.13. AUDIO FORMAT CONTROL REGISTER

| Offset: 0x048 |             |              | Register name: AudFmt |
|---------------|-------------|--------------|-----------------------|
| Bits          | Read /Write | Default /Hex | Description           |

| Offset: 0x048 |             |              | Register name: AudFmt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31            | R/W         | 0            | <p>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</p>                                                                                                                                                                                                                                                                                                                                                                            |
| 30:26         | /           | /            | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 26:24         | R/W         | 0            | <p>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<br/>           1xx: reserved</p>                                                                                                                                                                                                                                                                                                                                          |
| 23:5          | /           | /            | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4             | R/W         | 0            | <p>DSD_FMT<br/>           0: LSB first<br/>           1:MSB first</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3             | R/W         | 0            | <p>AUD_LAYOUT:<br/>           PCM/1-bit Audio layout selection<br/>           0: layout 0 (2 channels)<br/>           1: layout 1 (up to 8 channels)</p>                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2:0           | R/W         |              | <p>PCM_SRC_CH_CFG(LPCM &amp; 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</p> <p>Note: this only indicates how many channels of input PCM stream; it does not mean 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.</p> |

#### 5.2.4.14. AUDIO PCM CONTROL REGISTER

| Offset: 0x04c |             |              | Register name: Aud_PCM_Ctrl                                                                                                                                                                                                                                          |
|---------------|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                          |
| 31            | /           | /            | reserved                                                                                                                                                                                                                                                             |
| 30:28         | R/W         | 7            | PCM_CH7_MAP:<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 27            | /           | /            | reserved                                                                                                                                                                                                                                                             |
| 26:24         | R/W         | 6            | PCM_CH6_MAP:<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 23            | /           | /            | reserved                                                                                                                                                                                                                                                             |
| 22:20         | R/W         | 5            | PCM_CH5_MAP:<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 19            | /           | /            | reserved                                                                                                                                                                                                                                                             |
| 18:16         | R/W         | 4            | PCM_CH4_MAP:                                                                                                                                                                                                                                                         |

| Offset: 0x04c |             |              | Register name: Aud_PCM_Ctrl                                                                                                                                                                                                                                          |
|---------------|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                          |
|               |             |              | 000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample                 |
| 15            | /           | /            | reserved                                                                                                                                                                                                                                                             |
| 14:12         | R/W         | 3            | PCM_CH3_MAP:<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 11            | /           | /            | reserved                                                                                                                                                                                                                                                             |
| 10:8          | R/W         | 2            | PCM_CH2_MAP:<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 7             | /           | /            | reserved                                                                                                                                                                                                                                                             |
| 6:4           | R/W         | 1            | PCM_CH1_MAP:<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample                                                                                                                             |

| Offset: 0x04c |             |              | Register name: Aud_PCM_Ctrl                                                                                                                                                                                                                                          |
|---------------|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                          |
|               |             |              | 100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample                                                                                                                                             |
| 3             | /           | /            | reserved                                                                                                                                                                                                                                                             |
| 2:0           | R/W         | 0            | PCM_CH0_MAP:<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |

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

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

| Offset: 0x054 |             |              | Register name: Aud_N              |
|---------------|-------------|--------------|-----------------------------------|
| Bits          | Read /Write | Default /Hex | Description                       |
|               |             |              | Audio clock regeneration factor N |

#### 5.2.4.17. AUDIO PCM CHANNEL STATUS 0

| Offset: 0x058 |             |              | Register name: Aud_CH_Status0                                                                                                                                                              |
|---------------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                |
| 31:30         | R/W         | 0x00         | CHNL_BIT1<br>(reserved)                                                                                                                                                                    |
| 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<br>others = reserved |
| 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: Reserved                                                                                                                                                |
| 5:3           | R/W         | 0x00         | EMPHASIS<br>Additional format information                                                                                                                                                  |

| Offset: 0x058 |             |              | Register name: Aud_CH_Status0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|               |             |              | <p>For bit 1 = “0”, Linear PCM audio mode:</p> <ul style="list-style-type: none"> <li>000: 2 audio channels without pre-emphasis</li> <li>001: 2 audio channels with 50 µs / 15 µs pre-emphasis</li> <li>010: Reserved (for 2 audio channels with pre-emphasis)</li> <li>011: Reserved (for 2 audio channels with pre-emphasis)</li> <li>100~111: Reserved</li> </ul> <p>For bit 1 = “1”, other than Linear PCM applications:</p> <ul style="list-style-type: none"> <li>000: Default state</li> <li>001~111: Reserved</li> </ul> |
| 2             | R/W         | 0x00         | <p>CP</p> <p>Copyright</p> <p>0: copyright is asserted</p> <p>1: no copyright is asserted</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1             | R/W         | 0x00         | <p>AUD_DATA_TYPE</p> <p>Audio Data Type</p> <p>0: Linear PCM Samples</p> <p>1: For non-linear PCM audio such as AC3, DTS, MPEG audio</p>                                                                                                                                                                                                                                                                                                                                                                                          |
| 0             | R/W         | 0x00         | <p>APP_TYPE</p> <p>Application type</p> <p>0: Consumer Application</p> <p>1: Professional Application</p> <p>Note: This bit must be fixed to “0”</p>                                                                                                                                                                                                                                                                                                                                                                              |

#### 5.2.4.18. 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         | <p>CGMS-A</p> <ul style="list-style-type: none"> <li>00: Copying is permitted without restriction</li> <li>01: One generation of copies may be made</li> <li>10: Condition not be used</li> </ul> |

| Offset: 0x05c |             |              | Register name: Aud_CH_Status1                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|-------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|               |             |              | 11: No copying is permitted                                                                                                                                                                                                                                                                                                                                                                       |
| 7:4           | R/W         | 0x00         | <p>ORIGINAL_FS</p> <p>Original sampling frequency</p> <p>0000: not indicated</p> <p>0001: 192kHz</p> <p>0010: 12kHz</p> <p>0011: 176.4kHz</p> <p>0100: Reserved</p> <p>0101: 96kHz</p> <p>0110: 8kHz</p> <p>0111: 88.2kHz</p> <p>1000: 16kHz</p> <p>1001: 24kHz</p> <p>1010: 11.025kHz</p> <p>1011: 22.05kHz</p> <p>1100: 32kHz</p> <p>1101: 48kHz</p> <p>1110: Reserved</p> <p>1111: 44.1kHz</p> |
| 3:1           | R/W         | 0x00         | <p>WORD_LEN</p> <p>Sample word length</p> <p>For bit 0 = "0":</p> <p>000: not indicated</p> <p>001: 16 bits</p> <p>010: 18 bits</p> <p>100: 19 bits</p> <p>101: 20 bits</p> <p>110: 17 bits</p> <p>111: Reserved</p> <p>For bit 0 = "1":</p> <p>000: not indicated</p> <p>001: 20 bits</p> <p>010: 22 bits</p> <p>100: 23 bits</p>                                                                |

| Offset: 0x05c |             |              | Register name: Aud_CH_Status1                                                                                                       |
|---------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                         |
|               |             |              | 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, bits that not list above should set to 0

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

| Offset: 0x080 |             |              | Register name: AVI_Info_Pkt  |
|---------------|-------------|--------------|------------------------------|
| BYTE          | Read /Write | Default /Hex | Description                  |
|               |             |              | 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<br>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 |

#### 5.2.4.20. AUDIO\_INFO\_FRMAE\_PACKET

| Offset: 0x0a0 |             |              | Register name: Aud_info_Pkt       |
|---------------|-------------|--------------|-----------------------------------|
| BYTE          | Read /Write | Default /Hex | Description                       |
| 0x00          | R/W         | 0x00         | <b>AUD_HB0</b><br>Packet type     |
| 0x01          | R/W         | 0x00         | <b>AUD_HB1</b><br>Packet version  |
| 0x02          | R/W         | 0x00         | <b>AUD_HB2</b><br>Packet length   |
| 0x03          | R/W         | 0x00         | <b>AUD_PB0</b><br>checksum        |
| 0x04          | R/W         | 0x00         | <b>AUD_PB1</b><br>AUD data byte 1 |

| Offset: 0x0a0 |             |              | Register name: Aud_info_Pkt         |
|---------------|-------------|--------------|-------------------------------------|
| BYTE          | Read /Write | Default /Hex | Description                         |
| 0x05          | R/W         | 0x00         | <b>AUD_PB2</b><br>AUD data byte 2   |
| 0x06          | R/W         | 0x00         | <b>AUD_PB3</b><br>AUD data byte 3   |
| 0x07          | R/W         | 0x00         | <b>AUD_PB4</b><br>AUD data byte 4   |
| 0x08          | R/W         | 0x00         | <b>AUD_PB5</b><br>AUD data byte 5   |
| 0x09          | R/W         | 0x00         | <b>AUD_PB6</b><br>AUD data byte 6   |
| 0x0a          | R/W         | 0x00         | <b>AUD_PB7</b><br>AUD data byte 7   |
| 0x0b          | R/W         | 0x00         | <b>AUD_PB8</b><br>AUD data byte 8   |
| 0x0c          | R/W         | 0x00         | <b>AUD_PB9</b><br>AUD data byte 9   |
| 0x0d          | R/W         | 0x00         | <b>AUD_PB10</b><br>AUD data byte 10 |

#### 5.2.4.21. 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>Reseved     |
| 0x02          | R/W         | 0x00         | ACP_PB0                |
| 0x03          | R/W         | 0x00         | ACP_PB1                |
| 0x04          | R/W         | 0x00         | ACP_PB2                |

| Offset: 0x0c0 |             |              | Register name: ACP_Pkt                                        |
|---------------|-------------|--------------|---------------------------------------------------------------|
| BYTE          | Read /Write | Default /Hex | Description                                                   |
| 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 |

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

| Offset: 0x0e0-0x0e9 |             |              | Register name: GP_Pkt |
|---------------------|-------------|--------------|-----------------------|
| BYTE                | Read /Write | Default /Hex | Description           |
| 0x06                | R/W         | 0x00         | GCP_PB3               |
| 0x07                | R/W         | 0x00         | GCP_PB4               |
| 0x08                | R/W         | 0x00         | GCP_PB5               |
| 0x09                | R/W         | 0x00         | GCP_PB6               |

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

| Offset: 0x240 |             |              | Register name: SPD_Pkt |
|---------------|-------------|--------------|------------------------|
| BYTE          | Read /Write | Default /Hex | Description            |
| 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              |

#### 5.2.4.24. 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: |

| Offset: 0x200 |             |              | Register name: Pad_Ctrl0 |
|---------------|-------------|--------------|--------------------------|
| Bits          | Read /Write | Default /Hex | Description              |
| 21            | R/W         | 0            | Lsb_msb                  |
| 20:0          | /           | /            | reserved                 |

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

#### 5.2.4.26. PLL/DRV SETTING 2: PLL\_CTRL0

| Offset: 0x208 |             |              | Register name: PLL_Ctrl |
|---------------|-------------|--------------|-------------------------|
| Bits          | Read /Write | Default /Hex | Description             |
| 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                   |

#### 5.2.4.27. PLL/DRV SETTING 3: PLL\_DBG0

| Offset: 0x20c |             |              | Register name: PLL_Dbg0 |
|---------------|-------------|--------------|-------------------------|
| Bits          | Read /Write | Default /Hex | Description             |
| 31            | R/W         | 0            | PLL_DBG_EN              |
| 30:28         | R/W         | 0            | PSET                    |
| 27:26         | R/W         | 0            | CLKSTEP                 |
| 25:24         | R/W         | 0            | PDCLKSEL                |
| 23            | R/W         | 0            | S5_7                    |
| 22            | R/W         | 0            | /                       |
| 21            | R/W         | 0            | CKIN_SEL                |

| Offset: 0x20c |             |              | Register name: PLL_Dbgo |
|---------------|-------------|--------------|-------------------------|
| Bits          | Read /Write | Default /Hex | Description             |
| 20            | R/W         | 0            | VCO_RST_IN              |
| 19            | R/W         | 0            | VREG2_OUT_EN            |
| 18            | R/W         | 0            | VREG1_OUT_EN            |
| 17            | R/W         | 0            | REG_OD1                 |
| 16            | R/W         | 0            | REG_OD                  |
| 15:14         | /           | /            | reserved                |
| 13:8          | R/W         | 0            | B_IN                    |
| 7:6           | /           | /            | reserved                |
| 5:0           | R/W         | 0            | CNT_INT                 |

#### 5.2.4.28. PLL/DRV SETTING 4: PLL DBG0

| Offset: 0x210 |             |              | Register name: PLL_Dbgo1 |
|---------------|-------------|--------------|--------------------------|
| Bits          | Read /Write | Default /Hex | Description              |
| 31:25         | /           | /            | reserved                 |
| 24            | R/W         | 0            | Lock_flag2               |
| 23:17         | /           | /            | reserved                 |
| 16            | R/W         | 0            | Lock_flag1               |
| 15:10         | /           | /            | reserved                 |
| 9             | R/W         | 0            | Error_sf                 |
| 8             | R/W         | 0            | Error_sfdet              |
| 7:6           | /           | /            | reserved                 |
| 5:0           | R/W         | 0            | PLL_BNSI                 |

#### 5.2.4.29. PLL/DRV SETTING 5: HPD/CEC

| Offset: 0x214 | Register name: HPD_CEC |
|---------------|------------------------|
|---------------|------------------------|

| <b>Bits</b> | <b>Read /Write</b> | <b>Default /Hex</b> | <b>Description</b> |
|-------------|--------------------|---------------------|--------------------|
| 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_HPDPD          |
| 1           | R/W                | 0                   | W_HPD              |
| 0           | R                  | /                   | R_HPD              |

#### 5.2.4.30. PACKET\_CONTROL0

| Offset: 0x2f0 |                    |                     | Register name: Pkt_Ctrl0                                                                                    |
|---------------|--------------------|---------------------|-------------------------------------------------------------------------------------------------------------|
| <b>Bits</b>   | <b>Read /Write</b> | <b>Default /Hex</b> | <b>Description</b>                                                                                          |
| 31:28         | R/W                | 0                   | Pkt_4_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_3_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16<br>5: 32                                        |

| Offset: 0x2f0 |             |              | Register name: Pkt_Ctrl0                                                                                                                                                                                                                             |
|---------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                          |
|               |             |              | 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: user_define(reserved)<br>7: acp_pkt(reserved)<br>8: mpeg_info(reserved)<br>15:arbiter table end<br>Others: reserved |

| Offset: 0x2f0 |             |              | Register name: Pkt_Ctrl0                                                                                                                                                                                                                             |
|---------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                          |
| 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: user_define(reserved)<br>7: acp_pkt(reserved)<br>8: mpeg_info(reserved)<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: user_define(reserved)<br>7: acp_pkt(reserved)<br>8: mpeg_info(reserved)<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: user_define(reserved)<br>7: acp_pkt(reserved)<br>8: mpeg_info(reserved)<br>15:arbiter table end                     |

| Offset: 0x2f0 |             |              | Register name: Pkt_Ctrl0 |
|---------------|-------------|--------------|--------------------------|
| Bits          | Read /Write | Default /Hex | Description              |
|               |             |              | Others: reserved         |

#### 5.2.4.31. PACKET CONTROL1

| Offset address: 0x2f4 |             |              | Register name: Pkt_Ctrl1                                                                                    |
|-----------------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------|
| Bits                  | Read /Write | Default /Hex | Description                                                                                                 |
| 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                                                 |

| Offset address: 0x2f4 |             |              | Register name: Pkt_Ctrl1                                                                                                                                                                                                                             |
|-----------------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits                  | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                          |
|                       |             |              | 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<br>1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: user_define(reserved)<br>7: acp_pkt(reserved)<br>8: mpeg_info(reserved)<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: user_define(reserved)<br>7: acp_pkt(reserved)                                                                       |

| Offset address: 0x2f4 |             |              | Register name: Pkt_Ctrl1                                                                                                                                                                                                                             |
|-----------------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits                  | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                          |
|                       |             |              | 8: mpeg_info(reserved)<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: user_define(reserved)<br>7: acp_pkt(reserved)<br>8: mpeg_info(reserved)<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: user_define(reserved)<br>7: acp_pkt(reserved)<br>8: mpeg_info(reserved)<br>15:arbiter table end<br>Others: reserved |

#### 5.2.4.32. AUDIO NORMAL DMA PORT

| Offset: 0x400 |             |              | Register name: Aud_TX_FIFO |
|---------------|-------------|--------------|----------------------------|
| Bits          | Read /Write | Default /Hex | Description                |

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

#### 5.2.4.33. 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 clear when the command complete.<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 completing soft reset operation                                                    |

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

| Offset: 0x504 |             |              | Register name: DDC_Slave_Addr                                             |
|---------------|-------------|--------------|---------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                               |
| 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<br>Slave Address                                                    |

#### 5.2.4.35. DDC INTERRUPT MASK REGISTER

| Offset: 0x508 |             |              | Register name: DDC_Int_Mask                                                                                                                                                                                                                                                                 |
|---------------|-------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                                                 |
| 31:6          | /           | /            | reserved                                                                                                                                                                                                                                                                                    |
| 7             | R/W         | 0            | Illegal_FIFO_Op_Int_Msk<br>0: disable<br>1: enable<br>Illegal FIFO operation interrupt mask                                                                                                                                                                                                 |
| 6             | R/W         | 0            | 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 underflow in read operation.<br>Write 1 to this bit will clear it                                                                                         |
| 5             | R/W         | 0            | DDC_FIFO_Overflow_Int_Mask<br>0: not overflow<br>1: overflow<br>This bit is set when FIFO overflow in write operation.<br>Write 1 to this bit will clear it                                                                                                                                 |
| 4             | R           | 0            | 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. |

| Offset: 0x508 |             |              | Register name: DDC_Int_Mask                               |
|---------------|-------------|--------------|-----------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                               |
| 3             | R/W         | 0            | DDC_Arbitration_Error_Int_Mask<br>0: disable<br>1: enable |
| 2             | R/W         | 0            | DDC_ACK_Error_Int_Mask<br>0: disable<br>1: enable         |
| 1             | R/W         | 0            | DDC_Bus_Error_Int_Mask<br>0: disable<br>1: enable         |
| 0             | R/W         | 0            | DDC_Transfer_Complete_Int_Mask<br>0: disable<br>1: enable |

#### 5.2.4.36. DDC INTERRUPT STATUS REGISTER:

| Offset: 0x50C |             |              | Register name: DDC_Int_Status                                                                                                                                     |
|---------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                       |
| 31:8          | /           | /            | reserved                                                                                                                                                          |
| 8             | R           | 0            | Interrupt_Clear_Status<br>0: Interrupt have be cleared<br>1: Interrupt clear is in process<br>Note : When clear interrupt, must check this bit for clear complete |
| 7             | R/W         | 0            | Illegal_FIFO_operation_interrupt_status_bit                                                                                                                       |
| 6             | R/W         | 0            | DDC_RX FIFO_Underflow_Interrupt_Status_Bit<br>0: not underflow<br>1: underflow<br>This bit is set when FIFO underflow<br>Write 1 to this bit will clear it        |
| 5             | R/W         | 0            | DDC_TX FIFO_Overflow_Interrupt_Status_Bit<br>0: not overflow<br>1: overflow                                                                                       |

| Offset: 0x50C |             |              | Register name: DDC_Int_Status                                                                                                                                                                                                                 |
|---------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                   |
|               |             |              | This bit is set when FIFO overflow<br>Write 1 to this bit will clear it                                                                                                                                                                       |
| 4             | R           | 0            | DDC_FIFO_Request_Interrupt_Status_Bit<br><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. |
| 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                                                                                                                                                                                                    |

#### 5.2.4.37. DDC FIFO CONTROL REGISTER

| Offset: 0x510 |             |              | Register name: DDC_FIFO_Ctrl                                                                                                                                |
|---------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                 |
| 31            | R/W         | 0            | FIFO_Address_Clear<br><br>Write '1' to this bit will clear FIFO address, and auto clear to 0 when completing FIFO addresses clear operation.                |
| 30:9          | /           | /            | Reserved                                                                                                                                                    |
| 8             | R/W         | 0            | DMA_Request_En<br><br>0: disable<br>1: enable<br><br>Note: this bit can only be set when correct FIFO direction is set                                      |
| 7:4           | R/W         | 0            | FIFO_RX_TRIGGER_THRESH<br><br>When FIFO level is above this value in read mode, DMA request and FIFO request interrupt is assert if relative enable is on.  |
| 3:0           | R/W         | 0            | FIFO_TX_TRIGGER_THRESH<br><br>When FIFO level is below this value in write mode, DMA request and FIFO request interrupt is assert if relative enable is on. |

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

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

#### 5.2.4.40. 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_Bit_Number      |

#### 5.2.4.41. 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<br>110 = Explicit Offset Address E-DDC Read<br>111 = Implicit Offset Address E-DDC Read |

#### 5.2.4.42. 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 decide 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                                                                                                                                                                 |

| Offset: 0x524 |             |              | Register name: DDC_ExREG                                                                                                                                                                              |
|---------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                           |
|               |             |              | 0: disable<br>1: enable                                                                                                                                                                               |
| 0             | R/W         | 0            | <b>DDC_SDA_LineState_Control_Bit</b><br>When DDC_SDA line state control enable is set to '1', the value of this bit decide the output level of DDC_SDA<br>0: output low level<br>1: output high level |

#### 5.2.4.43. 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 recommend set to 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><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><br>The source clock frequency is the $f_{TMDS}/2$ . |

## 5.3. Display Engine Frontend

### 5.3.1. Overview

The DEFE performs image capture/driver, video/graphic scaling, format conversion and color space conversion. It is composed of DMA controller, input controller, deinterlacing, scaler, color space conversion, post process and output controller.

The DEFE features:

- Support interlace/progressive output scan types
- De-interlace method: weave/bob/motion-adaptive/motion-adaptive-bob
- 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
- 8 tap scale filter in horizontal and 4 tap in vertical direction
- 32 programmable coefficients for each tap
- Color space conversion between YUV and RGB
- Output support directly display and write back to memory
- Input support from DRAM, DEBE and interface of LCD with DEBE
- Support 3D format content input/output format convert/display(including HDMI)

### 5.3.2. DEFE Block Diagram



### 5.3.3. DEFE Register List

| Module Name | Base Address |
|-------------|--------------|
| DEFEO       | 0x01E00000   |
| DEFE1       | 0x01E20000   |

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

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                            |
|----------------------|---------------|-----------------------------------------------|
| 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_WB_ADDR1_REG    | 0x0054        | DEFE Channel 4 Write Back Address Register    |
| DEFE_WB_ADDR2_REG    | 0x0058        | DEFE Channel 5 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 Coefficent 00 Register               |
| DEFE_CSC_COEF01_REG  | 0x0074        | DEFE CSC Coefficent 01 Register               |
| DEFE_CSC_COEF02_REG  | 0x0078        | DEFE CSC Coefficent 02 Register               |
| DEFE_CSC_COEF03_REG  | 0x007C        | DEFE CSC Coefficent 03 Register               |
| DEFE_CSC_COEF10_REG  | 0x0080        | DEFE CSC Coefficent 10 Register               |
| DEFE_CSC_COEF11_REG  | 0x0084        | DEFE CSC Coefficent 11 Register               |
| DEFE_CSC_COEF12_REG  | 0x0088        | DEFE CSC Coefficent 12 Register               |
| DEFE_CSC_COEF13_REG  | 0x008C        | DEFE CSC Coefficent 13 Register               |
| DEFE_CSC_COEF20_REG  | 0x0090        | DEFE CSC Coefficent 20 Register               |
| DEFE_CSC_COEF21_REG  | 0x0094        | DEFE CSC Coefficent 21 Register               |
| DEFE_CSC_COEF22_REG  | 0x0098        | DEFE CSC Coefficent 22 Register               |
| DEFE_CSC_COEF23_REG  | 0x009C        | DEFE CSC Coefficent 23 Register               |
| DEFE_DI_CTRL_REG     | 0x00A0        | DEFE De-interlacing Control Register          |
| DEFE_DI_DIAGINTP_REG | 0x00A4        | DEFE De-interlacing Diag-Interpolate Register |
| DEFE_DI_TEMPDIFF_REG | 0x00A8        | DEFE De-interlacing Temp-Difference Register  |
| DEFE_DI_SAWTOOTH_REG | 0x00AC        | DEFE De-interlaing Sawtooth Register          |

| <b>Register Name</b>     | <b>Offset</b> | <b>Description</b>                                  |
|--------------------------|---------------|-----------------------------------------------------|
| DEFE_DI_SPATCOMP_REG     | 0x00B0        | DEFE De-interlacing Spatial Compare Register        |
| DEFE_DI_BURSTLEN_REG     | 0x00B4        | DEFE De-interlacing DMA Burst Length Register       |
| DEFE_DI_PRELUMA_REG      | 0x00B8        | DEFE De-interlacing Pre-Frame Luma Address Register |
| DEFE_DI_TILEFLAG_REG     | 0x00BC        | DEFE De-interlacing Tile Flag Address Register      |
| DEFE_DI_FLAGLINESTRD_REG | 0x00C0        | DEFE De-interlacing Tile Flag LineStride 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_WB_LINESTRD1_REG    | 0x00D8        | DEFE Write Back Channel 4 Line Stride Register      |
| DEFE_WB_LINESTRD2_REG    | 0x00DC        | DEFE Write Back Channel 5 Line Stride Register      |
| DEFE_3D_CTRL_REG         | 0x00E0        | DEFE 3D Mode Control Register                       |
| DEFE_3D_BUF_ADDR0_REG    | 0x00E4        | DEFE 3D Channel 0 Buffer Address Register           |
| DEFE_3D_BUF_ADDR1_REG    | 0x00E8        | DEFE 3D Channel 1 Buffer Address Register           |
| DEFE_3D_BUF_ADDR2_REG    | 0x00EC        | DEFE 3D Channel 2 Buffer Address Register           |
| DEFE_3D_TB_OFF0_REG      | 0x00F0        | DEFE 3D Channel 0 Tile-Based Offset Register        |
| DEFE_3D_TB_OFF1_REG      | 0x00F4        | DEFE 3D Channel 1 Tile-Based Offset Register        |
| DEFE_3D_TB_OFF2_REG      | 0x00F8        | DEFE 3D Channel 2 Tile-Based Offset 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    |

| <b>Register Name</b>    | <b>Offset</b> | <b>Description</b>                                           |
|-------------------------|---------------|--------------------------------------------------------------|
| DEFE_CH0_VERTPHASE1_REG | 0x0118        | DEFE Channel 0 Vertical Initial Phase 1 Register             |
| DEFE_CH0_HORZTAP0_REG   | 0x0120        | DEFE Channel 0 Horizontal Tap Offset 0 Register              |
| DEFE_CH0_HORZTAP1_REG   | 0x0124        | DEFE Channel 0 Horizontal Tap Offset 1 Register              |
| DEFE_CH0_VERTTAP_REG    | 0x0128        | DEFE Channel 0 Vertical Tap Offset 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_CH1_HORZTAP0_REG   | 0x0220        | DEFE Channel 1 Horizontal Tap Offset 0 Register              |
| DEFE_CH1_HORZTAP1_REG   | 0x0224        | DEFE Channel 1 Horizontal Tap Offset 1 Register              |
| DEFE_CH1_VERTTAP_REG    | 0x0228        | DEFE Channel 1 Vertical Tap Offset Register                  |
| DEFE_CH0_HORZCOEF0_REG  | 0x0400+N*4    | DEFE Channel 0 Horizontal Filter Coefficient Register N=0:31 |
| DEFE_CH0_HORZCOEF1_REG  | 0x0480+N*4    | DEFE Channel 0 Horizontal Filter Coefficient Register N=0:31 |
| DEFE_CH0_VERTCOEF_REG   | 0x0500+N*4    | DEFE Channel 0 Vertical Filter Coeffient Register N=0:31     |
| DEFE_CH1_HORZCOEF0_REG  | 0x0600+N*4    | DEFE Channel 1 Horizontal Filter Coeffient Register N=0:31   |
| DEFE_CH1_HORZCOEF1_REG  | 0x0680+N*4    | DEFE Channel 1 Horizontal Filter Coeffient Register N=0:31   |
| DEFE_CH1_VERTCOEF_REG   | 0x0700+N*4    | DEFE Channel 1 Vertical Filter Coeffient Register N=0:31     |
| DEFE_VPP_EN_REG         | 0x0A00        | DEFE Video Post Process Enable Register                      |
| DEFE_VPP_DCTL_REG       | 0x0A04        | DEFE Video Post Process Digital Chroma                       |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                                                   |
|----------------------|---------------|----------------------------------------------------------------------|
|                      |               | Transition Improve Configuration Register                            |
| DEFE_VPP_LP1_REG     | 0x0A08        | DEFE Video Post Process Luminance Peaking Configuration 1 Register   |
| DEFE_VPP_LP2_REG     | 0x0A0C        | DEFE Video Post Process Luminance Peaking Configuration 2 Register   |
| DEFE_VPP_WLE_REG     | 0x0A10        | DEFE Video Post Process White Level Extension Configuration Register |
| DEFE_VPP_BLE_REG     | 0x0A14        | DEFE Video Post Process Black Level Extension Configuration Register |

### 5.3.4. DEFE Register Description

#### 5.3.4.1. DEFE\_EN\_REG

| Offset: 0x0 |                |                 | Register Name: DEFE_EN_REG                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | 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 is transition 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> |

#### 5.3.4.2. DEFE\_FRM\_CTRL\_REG

| Offset: 0x4 |                |             | Register Name: DEFE_FRM_CTRL_REG |
|-------------|----------------|-------------|----------------------------------|
| Bit         | Read/<br>Write | Default/Hex | Description                      |
| 31:17       | /              | /           | /                                |

| Offset: 0x4 |                |                 | Register Name: DEFE_FRM_CTRL_REG                                                                                                                                                                                                                                                                                                                                                             |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                  |
| 16          | R/W            | 0x0             | <p>FRM_START<br/>Frame start &amp; reset control<br/>0: reset<br/>1: start</p> <p>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.</p>                                                                                                                             |
| 15          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                            |
| 14:12       | R/W            | 0x0             | <p>IN_CTRL<br/>DEFE input source control<br/>000: from dram<br/>100: from DEBE0 interface of DEBE2lcd (don't influence the interface timing of DEBE)<br/>101: from DEBE1 interface of DEBE2lcd(don't influence the interface timing of DEBE)<br/>110: from DEBE0(influence the interface timing of DEBE)<br/>111: from DEBE1(influence the interface timing of DEBE)<br/>Other: reserved</p> |
| 11          | R/W            | 0x0             | <p>OUT_CTRL<br/>DEFE output control<br/>0: enable DEFE output to DEBE<br/>1: disable DEFE output to DEBE</p> <p>If DEFE write back function is enable, DEFE output to DEBE isn't recommended.</p>                                                                                                                                                                                            |
| 10          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                            |
| 9:8         | R/W            | 0x0             | <p>OUT_PORT_SEL<br/>DEFE output port select<br/>00: DEBE0<br/>01: DEBE1<br/>other: reserved</p>                                                                                                                                                                                                                                                                                              |
| 7:3         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                            |
| 2           | R/W            | 0x0             | WB_EN<br>Write back enable                                                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0x4 |                |                 | Register Name: DEFE_FRM_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|             |                |                 | <p>0: Disable<br/>1: Enable</p> <p>If output to DEBE is enable, 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.</p>                                                                                                                                                                                                                                                                                                                     |
| 1           | R/W            | 0x0             | <p>COEF_RDY_EN<br/>Filter coefficients ready enable<br/>0: not ready<br/>1: filter coefficients configuration ready</p> <p>In order to avoid the noise, you have to ensure the same set filter coefficients are used in one frame, so the filter coefficients are buffered, the programmer can change the coefficients in any time. When the filter coefficients setting is finished, the programmer should set the bit if the programmer need the new coefficients in next scaling frame.</p> <p>When the new frame start, the bit will be self-cleared.</p>         |
| 0           | R/W            | 0x0             | <p>REG_RDY_EN<br/>Register ready enable<br/>0: not ready<br/>1: registers configuration ready</p> <p>As same as filter coefficients configuration, in order to ensure the display be correct, the correlative display configuration registers are buffered too, the programmer 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 programmer need the new configuration in next scaling frame.</p> <p>When the new frame starts, the bit will also be self-cleared.</p> |

### 5.3.4.3. DEFE\_BYPASS\_REG

| Offset: 0x8 |                |                 | Register Name: DEFE_BYPASS_REG |
|-------------|----------------|-----------------|--------------------------------|
| Bit         | Read/<br>Write | Default/<br>Hex | Description                    |
|             |                |                 |                                |

| Offset: 0x8 |                |                 | Register Name: DEFE_BYPASS_REG                                                                                                                                                                                                                            |
|-------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                               |
| 31:2        | /              | /               | /                                                                                                                                                                                                                                                         |
| 1           | R/W            | 0x0             | CSC_BYPASS_EN<br>CSC by-pass enable<br>0: CSC enable<br>1: CSC will be by-passed<br><br>Actually, in order ensure the module working be correct, This bit only can be set when input data format is the same as output data format (both YUV or both RGB) |
| 0           | /              | /               | /                                                                                                                                                                                                                                                         |

#### 5.3.4.4. DEFE\_AGTH\_SEL\_REG

| Offset: 0xC |                |                 | Register Name: DEFE_AGTH_SEL_REG                                                                       |
|-------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------|
| Bit         | Read/<br>Write | Default/<br>Hex | Description                                                                                            |
| 31:9        | /              | /               | /                                                                                                      |
| 8           | R/W            | 0x0             | LINEBUF_AGTH<br>DEFE line buffer algorithm select<br>0: horizontal filtered result<br>1: original data |
| 7:0         | /              | /               | /                                                                                                      |

#### 5.3.4.5. DEFE\_LINT\_CTRL\_REG

| Offset: 0x10 |                |                 | Register Name: DEFE_LINT_CTRL_REG |
|--------------|----------------|-----------------|-----------------------------------|
| Bit          | Read/<br>Write | Default/He<br>x | Description                       |
| 31:28        | /              | /               | /                                 |
| 27:16        | R              | 0x0             | CURRENT_LINE                      |
| 15           | R/W            | 0x0             | FIELD_SEL                         |

| Offset: 0x10 |                |             | Register Name: DEFE_LINT_CTRL_REG                                       |
|--------------|----------------|-------------|-------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                             |
|              |                |             | Field select<br>0: each field<br>1: end field(field counter in reg0x2c) |
| 14:13        | /              | /           | /                                                                       |
| 12:0         | R/W            | 0x0         | TRIG_LINE<br>Trigger line number of line interrupt                      |

#### 5.3.4.6. DEFE\_BUF\_ADDR0\_REG

| Offset: 0x20 |                |             | Register Name: DEFE_BUF_ADDR0_REG                                                                                                                                                                                                                         |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                               |
| 31:0         | R/W            | 0x0         | BUF_ADDR<br>DEFE frame buffer address<br><br>In tile-based type:<br>The address is the start address of the line in the first tile used to generating output frame.<br><br>In non-tile-based type:<br>The address is the start address of the first line. |

#### 5.3.4.7. DEFE\_BUF\_ADDR1\_REG

| Offset: 0x24 |                |             | Register Name: DEFE_BUF_ADDR1_REG                                                                                                       |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                             |
| 31:0         | R/W            | 0x0         | BUF_ADDR<br>DEFE frame buffer address<br><br>In tile-based type:<br>The address is the start address of the line in the first tile used |

| Offset: 0x24 |                |             | Register Name: DEFE_BUF_ADDR1_REG                                                                                         |
|--------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                               |
|              |                |             | <p>to generating output frame.</p> <p>In non-tile-based type:<br/>The address is the start address of the first line.</p> |

#### 5.3.4.8. DEFE\_BUF\_ADDR2\_REG

| Offset: 0x28 |                |             | Register Name: DEFE_BUF_ADDR2_REG                                                                                                                                                                                                                                    |
|--------------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 31:0         |                |             | <p>BUF_ADDR<br/>DEFE frame buffer address</p> <p>In tile-based type:<br/>The address is the start address of the line in the first tile used to generating output frame.</p> <p>In non- tile-based type:<br/>The address is the start address of the first line.</p> |

#### 5.3.4.9. DEFE\_FIELD\_CTRL\_REG

| Offset: 0x2C |                |             | Register Name: DEFE_FIELD_CTRL_REG                                                       |
|--------------|----------------|-------------|------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                              |
| 31:13        | /              | /           | /                                                                                        |
| 12           | R/W            | 0x0         | <p>FIELD_LOOP_MOD<br/>Field loop mode<br/>0:the last field; 1:the full frame</p>         |
| 11           | /              | /           | /                                                                                        |
| 10:8         | R/W            | 0x0         | <p>VALID_FIELD_CNT<br/>Valid field counter bit<br/>the valid value = this value + 1;</p> |

| Offset: 0x2C |                |             | Register Name: DEFE_FIELD_CTRL_REG                                                            |
|--------------|----------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                                                   |
| 7:0          | R/W            | 0x0         | FIELD_CNT<br>Field counter<br>each bit specify a field to display, 0:top field,1:bottom field |

#### 5.3.4.10. DEFE\_TB\_OFF0\_REG

| Offset: 0x30 |                |             | Register Name: DEFE_TB_OFF0_REG                                     |
|--------------|----------------|-------------|---------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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   |

#### 5.3.4.11. DEFE\_TB\_OFF1\_REG

| Offset: 0x34 |                |             | Register Name: DEFE_TB_OFF1_REG                                     |
|--------------|----------------|-------------|---------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                         |
| 31:21        | /              | /           | /                                                                   |
| 20:16        | R/W            | 0x0         | X_OFFSET1<br>The x offset of the bottom-right point in the end tile |

| Offset: 0x34 |                |             | Register Name: DEFE_TB_OFF1_REG                                   |
|--------------|----------------|-------------|-------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                                       |
| 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 |

#### 5.3.4.12. DEFE\_TB\_OFF2\_REG

| Offset: 0x38 |                |             | Register Name: DEFE_TB_OFF2_REG                                     |
|--------------|----------------|-------------|---------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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   |

#### 5.3.4.13. DEFE\_LINESTRD0\_REG

|              |                                   |
|--------------|-----------------------------------|
| Offset: 0x40 | Register Name: DEFE_LINESTRD0_REG |
|--------------|-----------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                          |
|------------|------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | R/W                    | 0x0                     | <p><b>LINE_STRIDE</b></p> <p><b>In tile-based type</b></p> <p>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)</p> <p><b>In non-tile-based type</b></p> <p>The stride length is the distance from the start of one line to the start of the next line.</p> |

#### 5.3.4.14. DEFE\_LINESTRD1\_REG

| <b>Offset: 0x44</b> |                        |                         | <b>Register Name: DEFE_LINESTRD1_REG</b>                                                                                                                                                                                                                                                                                                                                    |
|---------------------|------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                          |
| 31:0                | R/W                    | 0x0                     | <p><b>LINE_STRIDE</b></p> <p><b>In tile-based type</b></p> <p>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)</p> <p><b>In non-tile-based type</b></p> <p>The stride length is the distance from the start of one line to the start of the next line.</p> |

#### 5.3.4.15. DEFE\_LINESTRD2\_REG

| <b>Offset: 0x48</b> |                        |                         | <b>Register Name: DEFE_LINESTRD2_REG</b>                                                                                                                                                                                            |
|---------------------|------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                                                                                                                                                                                  |
| 31:0                | R/W                    | 0x0                     | <p><b>LINE_STRIDE</b></p> <p><b>In tile-based type</b></p> <p>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)</p> |

| Offset: 0x48 |                |                 | Register Name: DEFE_LINESTRD2_REG                                                                                                       |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                                                                             |
|              |                |                 | <p><b>In non-tile-based type</b></p> <p>The stride length is the distance from the start of one line to the start of the next line.</p> |

#### 5.3.4.16. DEFE\_INPUT\_FMT\_REG

| Offset: 0x4C |                |                 | Register Name: DEFE_INPUT_FMT_REG                                                                                                                                                                                                                          |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                |
| 31:17        | /              | /               | /                                                                                                                                                                                                                                                          |
| 16           | R/W            | 0x0             | <p><b>BYTE_SEQ</b></p> <p>Input data byte sequence selection</p> <p>0: P3P2P1P0(word)<br/>1: P0P1P2P3(word)</p>                                                                                                                                            |
| 15:13        | /              | /               | /                                                                                                                                                                                                                                                          |
| 12           | R/W            | 0x0             | <p><b>SCAN_MOD</b></p> <p>Scanning Mode selection</p> <p>0: non-interlace<br/>1: interlace</p>                                                                                                                                                             |
| 11           | /              | /               | /                                                                                                                                                                                                                                                          |
| 10:8         | R/W            | 0x0             | <p><b>DATA_MOD</b></p> <p>Input data mode selection</p> <p>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</p> |
| 7            | /              | /               | /                                                                                                                                                                                                                                                          |

| Offset: 0x4C |                |                 | Register Name: DEFE_INPUT_FMT_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6:4          | R/W            | 0x0             | <p>DATA_FMT<br/>Input component data format</p> <p><b>In non-tile-based planar data mode:</b></p> <ul style="list-style-type: none"> <li>000: YUV 4:4:4</li> <li>001: YUV 4:2:2</li> <li>010: YUV 4:2:0</li> <li>011: YUV 4:1:1</li> <li>100: CSI RGB data</li> <li>101: RGB888</li> <li>Other: Reserved</li> </ul> <p><b>In interleaved data mode:</b></p> <ul style="list-style-type: none"> <li>000: YUV 4:4:4</li> <li>001: YUV 4:2:2</li> <li>101: ARGB8888</li> <li>Other: reserved</li> </ul> <p><b>In non-tile-based UV combined data mode:</b></p> <ul style="list-style-type: none"> <li>001: YUV 4:2:2</li> <li>010: YUV 4:2:0</li> <li>011: YUV 4:1:1</li> <li>Other: reserved</li> </ul> <p><b>In tile-based planar data mode:</b></p> <ul style="list-style-type: none"> <li>001: YUV 4:2:2</li> <li>010: YUV 4:2:0</li> <li>011: YUV 4:1:1</li> <li>Other: Reserved</li> </ul> <p><b>In tile-based UV combined data mode:</b></p> <ul style="list-style-type: none"> <li>001: YUV 4:2:2</li> <li>010: YUV 4:2:0</li> <li>011: YUV 4:1:1</li> <li>Other: reserved</li> </ul> |
| 3:2          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1:0          | R/W            | 0x0             | DATA_PS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x4C |                |                 | Register Name: DEFE_INPUT_FMT_REG                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |                |                 | <p>Pixel sequence</p> <p><b>In interleaved YUV422 data mode:</b></p> <p>00: Y1V0Y0U0<br/>01: V0Y1U0Y0<br/>10: Y1U0Y0V0<br/>11: U0Y1V0Y0</p> <p><b>In interleaved YUV444 data mode:</b></p> <p>00: VUYA<br/>01: AYUV<br/>Other: reserved</p> <p><b>In UV combined data mode: (UV component)</b></p> <p>00: V1U1V0U0<br/>01: U1V1U0V0<br/>Other: reserved</p> <p><b>In interleaved ARGB8888 data mode:</b></p> <p>00: BGRA<br/>01: ARGB<br/>Other: reserved</p> |

#### 5.3.4.17. DEFE\_WB\_ADDR0\_REG

| Offset: 0x50 |                |                 | Register Name: DEFE_WB_ADDR0_REG                       |
|--------------|----------------|-----------------|--------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                            |
| 31:0         | R/W            | 0x0             | WB_ADDR<br>Write-back address setting for scaled data. |

#### 5.3.4.18. DEFE\_WB\_ADDR1\_REG

| Offset: 0x54 |                |             | Register Name: DEFE_WB_ADDR1_REG                       |
|--------------|----------------|-------------|--------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                            |
| 31:0         | R/W            | 0x0         | WB_ADDR<br>Write-back address setting for scaled data. |

#### 5.3.4.19. DEFE\_WB\_ADDR2\_REG

| Offset: 0x58 |                |             | Register Name: DEFE_WB_ADDR2_REG                       |
|--------------|----------------|-------------|--------------------------------------------------------|
| Bit          | Read/<br>Write | Default/Hex | Description                                            |
| 31:0         | R/W            | 0x0         | WB_ADDR<br>Write-back address setting for scaled data. |

#### 5.3.4.20. DEFE\_OUTPUT\_FMT\_REG

| Offset: 0x5C |                |                 | Register Name: DEFE_OUTPUT_FMT_REG                                                                                                                                                                       |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                              |
| 31: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                                                                                                                                           |

| Offset: 0x5C |                |                 | Register Name: DEFE_OUTPUT_FMT_REG                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|              |                |                 | 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 |

#### 5.3.4.21. DEFE\_INT\_EN\_REG

| Offset: 0x60 |                |             | Register Name: DEFE_INT_EN_REG                                      |
|--------------|----------------|-------------|---------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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          | /              | /           | /                                                                   |

#### 5.3.4.22. DEFE\_INT\_STATUS\_REG

| Offset: 0x64 |                |             | Register Name: DEFE_INT_STATUS_REG                      |
|--------------|----------------|-------------|---------------------------------------------------------|
| Bit          | Read/<br>Write | Default/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          | /              | /           | /                                                       |

#### 5.3.4.23. DEFE\_STATUS\_REG

| Offset: 0x68 |                |                 | Register Name: DEFE_STATUS_REG                                                                                                                                       |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | 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 write 0 to reset/start bit in frame control |

| Offset: 0x68 |                |                 | Register Name: DEFE_STATUS_REG                                                                                                                                                                                                                                                                                        |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                           |
|              |                |                 | register                                                                                                                                                                                                                                                                                                              |
| 11:6         | /              | /               | /                                                                                                                                                                                                                                                                                                                     |
| 5            | R              | 0x0             | <p>LCD_FIELD</p> <p>LCD field status</p> <p>0: top field</p> <p>1: bottom field</p>                                                                                                                                                                                                                                   |
| 4            | R              | 0x0             | <p>DRAM_STATUS</p> <p>Access dram status</p> <p>0: idle</p> <p>1: busy</p> <p>This flag indicates whether scaler is accessing dram</p>                                                                                                                                                                                |
| 3            | /              | /               | /                                                                                                                                                                                                                                                                                                                     |
| 2            | R              | 0x0             | <p>CFG_PENDING</p> <p>Register configuration pending</p> <p>0: no pending</p> <p>1: configuration pending</p> <p>This bit indicates the registers for the next frame has been configured. This bit will be set when configuration ready bit is set and this bit will be cleared when a new frame process begin.</p>   |
| 1            | R              | 0x0             | <p>WB_STATUS</p> <p>Write-back process status</p> <p>0: write-back end or write-back disable</p> <p>1: write-back in process</p> <p>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 end.</p> |
| 0            | R              | 0x0             | <p>FRM_BUSY</p> <p>Frame busy.</p> <p>This flag indicates that the frame is being processed.</p> <p>The bit will be set when frame process reset &amp; start is set, and be cleared when frame process reset or disabled.</p>                                                                                         |

#### 5.3.4.24. DEFE\_CSC\_COEF00\_REG

| Offset: 0x70 |                |                 | Register Name: DEFE_CSC_COEF00_REG                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                    |
| 31:13        | /              | /               | /                                                                              |
| 12:0         | R/W            | 0x0             | COEF<br>the Y/G coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

#### 5.3.4.25. DEFE\_CSC\_COEF01\_REG

| Offset: 0x74 |                |                 | Register Name: DEFE_CSC_COEF01_REG                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                    |
| 31:13        | /              | /               | /                                                                              |
| 12:0         | R/W            | 0x0             | COEF<br>the Y/G coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

#### 5.3.4.26. DEFE\_CSC\_COEF02\_REG

| Offset: 0x78 |                |                 | Register Name: DEFE_CSC_COEF02_REG                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                    |
| 31:13        | /              | /               | /                                                                              |
| 12:0         | R/W            | 0x0             | COEF<br>the Y/G coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

#### 5.3.4.27. DEFE\_CSC\_COEF03\_REG

| Offset: 0x7C | Register Name: DEFE_CSC_COEF03_REG |
|--------------|------------------------------------|
|--------------|------------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                         |
|------------|------------------------|-------------------------|----------------------------------------------------------------------------|
| 31:14      | /                      | /                       | /                                                                          |
| 13:0       | R/W                    | 0x0                     | CONT<br>the Y/G constant<br>the value equals to coefficient*2 <sup>4</sup> |

#### 5.3.4.28. DEFE\_CSC\_COEF10\_REG

| <b>Offset: 0x80</b> |                        |                         | <b>Register Name: DEFE_CSC_COEF10_REG</b>                                      |
|---------------------|------------------------|-------------------------|--------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                             |
| 31:13               | /                      | /                       | /                                                                              |
| 12:0                | R/W                    | 0x0                     | COEF<br>the U/R coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

#### 5.3.4.29. DEFE\_CSC\_COEF11\_REG

| <b>Offset: 0x84</b> |                        |                         | <b>Register Name: DEFE_CSC_COEF11_REG</b>                                      |
|---------------------|------------------------|-------------------------|--------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                                                             |
| 31:13               | /                      | /                       | /                                                                              |
| 12:0                | R/W                    | 0x0                     | COEF<br>the U/R coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

#### 5.3.4.30. DEFE\_CSC\_COEF12\_REG

| <b>Offset: 0x88</b> |                        |                         | <b>Register Name: DEFE_CSC_COEF12_REG</b> |
|---------------------|------------------------|-------------------------|-------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/H<br/>ex</b> | <b>Description</b>                        |
| 31:13               | /                      | /                       | /                                         |

| Offset: 0x88 |                |                 | Register Name: DEFE_CSC_COEF12_REG                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                    |
| 12:0         | R/W            | 0x0             | COEF<br>the U/R coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

#### 5.3.4.31. DEFE\_CSC\_COEF13\_REG

| Offset: 0x8C |                |                 | Register Name: DEFE_CSC_COEF13_REG                                         |
|--------------|----------------|-----------------|----------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                |
| 31:14        | /              | /               | /                                                                          |
| 13:00        | R/W            | 0x0             | CONT<br>the U/R constant<br>the value equals to coefficient*2 <sup>4</sup> |

#### 5.3.4.32. DEFE\_CSC\_COEF20\_REG

| Offset: 0x90 |                |                 | Register Name: DEFE_CSC_COEF20_REG                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | 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> |

#### 5.3.4.33. DEFE\_CSC\_COEF21\_REG

| Offset: 0x94 |                |                 | Register Name: DEFE_CSC_COEF21_REG |
|--------------|----------------|-----------------|------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                        |
| 31:13        | /              | /               | /                                  |

| Offset: 0x94 |                |                 | Register Name: DEFE_CSC_COEF21_REG                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                    |
| 12:0         | R/W            | 0x0             | COEF<br>the V/B coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

#### 5.3.4.34. DEFE\_CSC\_COEF22\_REG

| Offset: 0x98 |                |                 | Register Name: DEFE_CSC_COEF22_REG                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | 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> |

#### 5.3.4.35. DEFE\_CSC\_COEF23\_REG

| Offset: 0x9C |                |                 | Register Name: DEFE_CSC_COEF23_REG                                         |
|--------------|----------------|-----------------|----------------------------------------------------------------------------|
| Bit          | Read/<br>Write | 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> |

#### 5.3.4.36. DEFE\_DI\_CTRL\_REG

| Offset: 0xA0 |                |                 | Register Name: DEFE_DI_CTRL_REG |
|--------------|----------------|-----------------|---------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                     |
| 31:26        | /              | /               | /                               |

| Offset: 0xA0 |                |                 | Register Name: DEFE_DI_CTRL_REG                                                                                               |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                   |
| 25           | R/W            | 0x0             | <p>TEMPDIFF_EN</p> <p>Temporal difference compare enable</p> <p>0: disable<br/>1: enable</p>                                  |
| 24           | R/W            | 0x0             | <p>DIAGINTP_EN</p> <p>De-interlacing diagonal interpolate enable</p> <p>0: disable<br/>1: enable</p>                          |
| 23:18        | /              | /               | /                                                                                                                             |
| 17:16        | R/W            | 0x0             | <p>MOD</p> <p>De-interlacing mode select</p> <p>00: weave<br/>01: bob<br/>10: motion-adaptive<br/>11: motion-adaptive-bob</p> |
| 15:1         | /              | /               | /                                                                                                                             |
| 0            | R/W            | 0x0             | <p>EN</p> <p>De-interlacing enable</p> <p>0: de-interlacing disable<br/>1: de-interlacing enable</p>                          |

#### 5.3.4.37. DEFE\_DI\_DIAGINTP\_REG

| Offset: 0xA4 |                |                 | Register Name: DEFE_DI_DIAGINTP_REG |
|--------------|----------------|-----------------|-------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                         |
| 31:24        | R/W            | 0x8             | <p>TH3</p> <p>Diagintp_th3</p>      |
| 23:16        | R/W            | 0x10            | <p>TH2</p> <p>Diagintp_th2</p>      |
| 15           | /              | /               | /                                   |
| 14:8         | R/W            | 0x5             | TH1                                 |

| Offset: 0xA4 |                |                 | Register Name: DEFE_DI_DIAGINTP_REG |
|--------------|----------------|-----------------|-------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                         |
|              |                |                 | Diagintp_th1                        |
| 7            | /              | /               | /                                   |
| 6:0          | R/W            | 0x4F            | TH0<br>Diagintp_th0                 |

#### 5.3.4.38. DEFE\_DI\_TEMPDIFF\_REG

| Offset: 0xA8 |                |                 | Register Name: DEFE_DI_TEMPDIFF_REG |
|--------------|----------------|-----------------|-------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                         |
| 31:13        | /              | /               | /                                   |
| 12:8         | R/W            | 0xF             | TH<br>Temporal_th                   |
| 7:0          | /              | /               | /                                   |

#### 5.3.4.39. DEFE\_DI\_SAWTOOTH\_REG

| Offset: 0xAC |                |                 | Register Name: DEFE_DI_SAWTOOTH_REG |
|--------------|----------------|-----------------|-------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                         |
| 31:16        | /              | /               | /                                   |
| 15:8         | R/W            | 0x8             | TH2<br>sawtooth_th2                 |
| 7:0          | R/W            | 0x14            | TH1<br>Sawtooth_th1                 |

#### 5.3.4.40. DEFE\_DI\_SPATCOMP\_REG

| Offset: 0xB0 | Register Name: DEFE_DI_SPATCOMP_REG |
|--------------|-------------------------------------|
|--------------|-------------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b> |
|------------|------------------------|-------------------------|--------------------|
| 31:25      | /                      | /                       | /                  |
| 24:16      | R/W                    | 0xA                     | TH1<br>spatial_th1 |
| 15:9       | /                      | /                       | /                  |
| 8:0        | R/W                    | 0x64                    | TH0<br>spatial_th0 |

#### 5.3.4.41. DEFE\_DI\_BURSTLEN\_REG

| <b>Offset: 0xB4</b> |                        |                         | <b>Register Name: DEFE_DI_BURSTLEN_REG</b> |
|---------------------|------------------------|-------------------------|--------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                         |
| 31:14               | /                      | /                       | /                                          |
| 13:8                | R/W                    | 0x1F                    | CHROMA<br>Chroma burst length              |
| 7:6                 | /                      | /                       | /                                          |
| 5:0                 | R/W                    | 0x1F                    | LUMA<br>Luma burst length                  |

#### 5.3.4.42. DEFE\_DI\_PRELUMA\_REG

| <b>Offset: 0xB8</b> |                        |                         | <b>Register Name: DEFE_DI_PRELUMA_REG</b>       |
|---------------------|------------------------|-------------------------|-------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                              |
| 31:0                | R/W                    | 0x0                     | PREFRM_ADDR<br>Pre-frame buffer address of luma |

#### 5.3.4.43. DEFE\_DI\_TILEFLAG\_REG

| <b>Offset: 0xBC</b> | <b>Register Name: DEFE_DI_TILEFLAG_REG</b> |
|---------------------|--------------------------------------------|
|---------------------|--------------------------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                       |
|------------|------------------------|-------------------------|----------------------------------------------------------|
| 31:0       | R/W                    | 0x0                     | TILE_FLAG_ADDR<br>Current frame tile flag buffer address |

#### 5.3.4.44. DEFE\_DI\_FLAGLINESTRD\_REG

| <b>Offset: 0xC0</b> |                        |                         | <b>Register Name: DEFE_DI_FLAGLINESTRD_REG</b> |
|---------------------|------------------------|-------------------------|------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                             |
| 31:0                | R/W                    | 0x40                    | TILE_FLAG_LINESTRD<br>tile flag line-stride    |

#### 5.3.4.45. DEFE\_WB\_LINESTRD\_EN\_REG

| <b>Offset: 0xD0</b> |                        |                         | <b>Register Name: DEFE_WB_LINESTRD_EN_REG</b>                  |
|---------------------|------------------------|-------------------------|----------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                             |
| 31:1                | /                      | /                       | /                                                              |
| 0                   | R/W                    | 0x0                     | EN<br>Write back line-stride enable<br>0: disable<br>1: enable |

#### 5.3.4.46. DEFE\_WB\_LINESTRD0\_REG

| <b>Offset: 0xD4</b> |                        |                         | <b>Register Name: DEFE_WB_LINESTRD0_REG</b> |
|---------------------|------------------------|-------------------------|---------------------------------------------|
| <b>Bit</b>          | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                          |
| 31:0                | R/W                    | 0x0                     | LINE_STRD<br>Ch3 write back line-stride     |

#### 5.3.4.47. DEFE\_WB\_LINESTRD1\_REG

| Offset: 0xD8 |                |                 | Register Name: DEFE_WB_LINESTRD1_REG    |
|--------------|----------------|-----------------|-----------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                             |
| 31:0         | R/W            | 0x0             | LINE_STRD<br>Ch4 write back line-stride |

#### 5.3.4.48. DEFE\_WB\_LINESTRD2\_REG

| Offset: 0xDC |                |                 | Register Name: DEFE_WB_LINESTRD2_REG    |
|--------------|----------------|-----------------|-----------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                             |
| 31:0         | R/W            | 0x0             | LINE_STRD<br>Ch5 write back line-stride |

#### 5.3.4.49. DEFE\_3D\_CTRL\_REG

| Offset: 0xE0 |                |                 | Register Name: DEFE_3D_CTRL_REG                                                                                                                                                       |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                           |
| 31:26        | /              | /               | /                                                                                                                                                                                     |
| 25:24        | R/W            | 0x0             | TB_OUT_MOD_FIELD<br>Top/bottom output mode field number<br>0: left or left 1st field(determined by reg0x2c)<br>1: right or right 1st field<br>2: left 2nd field<br>3: right 2nd field |
| 23:19        | /              | /               | /                                                                                                                                                                                     |
| 18:16        | R/W            | 0x0             | CI_OUT_MOD<br>3D column interleaved mode<br>0: CI_1<br>1: CI_2<br>2: CI_3<br>3: CI_4                                                                                                  |

| Offset: 0xE0 |                |                 | Register Name: DEFE_3D_CTRL_REG                                                                                                                                                                                                                                                                                                                |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                    |
|              |                |                 | Other: reserved                                                                                                                                                                                                                                                                                                                                |
| 15:13        | /              | /               | /                                                                                                                                                                                                                                                                                                                                              |
| 12           | R/W            | 0x0             | TB_OUT_SCAN_MOD<br>Output top/bottom scan mode selection<br>0: progressive<br>1: interlace                                                                                                                                                                                                                                                     |
| 11           | R/W            | 0x0             | LI_IN_EN<br>3D input line interleaved enable                                                                                                                                                                                                                                                                                                   |
| 10           | R/W            | 0x0             | SS_OUT_EN<br>3D output side by side mode enable                                                                                                                                                                                                                                                                                                |
| 9            | /              | /               | /                                                                                                                                                                                                                                                                                                                                              |
| 8            | R/W            | 0x0             | CI_OUT_EN<br>3D Column interleaved mode output enable                                                                                                                                                                                                                                                                                          |
| 7:2          | /              | /               | /                                                                                                                                                                                                                                                                                                                                              |
| 1:0          | R/W            | 0x0             | MOD_SEL<br>3D mode select<br>00: normal output mode(2D mode)<br>01: 3D side by side/line interleaved/column interleaved output mode<br>10: 3D top/bottom output mode<br>11: reserved<br><br>When 3D mode is enable, DEFE will enter 3D mode(source will be composed of left and right frame, output will be composed of left and right frame). |

#### 5.3.4.50. DEFE\_3D\_BUF\_ADDR0\_REG

| Offset: 0xE4 |                |                 | Register Name: DEFE_3D_BUF_ADDR0_REG                                                                              |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                       |
| 31:0         | R/W            | 0x0             | RIGHT_CH0_ADDR<br>3D mode channel 0 buffer address<br>This address is the start address of right image in 3D mode |

#### 5.3.4.51. DEFE\_3D\_BUF\_ADDR1\_REG

| Offset: 0xE8 |                |                 | Register Name: DEFE_3D_BUF_ADDR1_REG                                                                              |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                       |
| 31:0         | R/W            | 0x0             | RIGHT_CH1_ADDR<br>3D mode channel 1 buffer address<br>This address is the start address of right image in 3D mode |

#### 5.3.4.52. DEFE\_3D\_BUF\_ADDR2\_REG

| Offset: 0xEC |                |                 | Register Name: DEFE_3D_BUF_ADDR2_REG                                                                              |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                       |
| 31:0         | R/W            | 0x0             | RIGHT_CH2_ADDR<br>3D mode channel 2 buffer address<br>This address is the start address of right image in 3D mode |

#### 5.3.4.53. DEFE\_3D\_TB\_OFF0\_REG

| Offset: 0xF0 |                |                 | Register Name: DEFE_3D_TB_OFF0_REG                                    |
|--------------|----------------|-----------------|-----------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                           |
| 31:21        | /              | /               | /                                                                     |
| 20:16        | R/W            | 0x0             | X_OFFSET1<br>The x offset of the bottom-right point in the first 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     |

| Offset: 0xF0 |                |                 | Register Name: DEFE_3D_TB_OFF0_REG                       |
|--------------|----------------|-----------------|----------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                              |
|              |                |                 | This value is the start offset of right image in 3D mode |

#### 5.3.4.54. DEFE\_3D\_TB\_OFF1\_REG

| Offset: 0xF4 |                |                 | Register Name: DEFE_3D_TB_OFF1_REG                                                                                            |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/<br>Hex | Description                                                                                                                   |
| 31:21        | /              | /               | /                                                                                                                             |
| 20:16        | R/W            | 0x0             | X_OFFSET1<br>The x offset of the bottom-right point in the first 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<br>This value is the start offset of right image in 3D mode |

#### 5.3.4.55. DEFE\_3D\_TB\_OFF2\_REG

| Offset: 0xF8 |                |                 | Register Name: DEFE_3D_TB_OFF2_REG                                    |
|--------------|----------------|-----------------|-----------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                           |
| 31:21        | /              | /               | /                                                                     |
| 20:16        | R/W            | 0x0             | X_OFFSET1<br>The x offset of the bottom-right point in the first 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          | /              | /               | /                                                                     |

| Offset: 0xF8 |                |                 | Register Name: DEFE_3D_TB_OFFSET2_REG                                                                                         |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                                                                   |
| 4:0          | R/W            | 0x0             | X_OFFSET0<br>The x offset of the top-left point in the first tile<br>This value is the start offset of right image in 3D mode |

#### 5.3.4.56. DEFE\_CH0\_INSIZE\_REG

| Offset: 0x100 |                |                 | Register Name: DEFE_CH0_INSIZE_REG                                                                                                                                                   |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                          |
| 31:29         | /              | /               | /                                                                                                                                                                                    |
| 28:16         | R/W            | 0x0             | IN_HEIGHT<br>Input image Y/G component height<br>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><br>When line buffer result selection is original data, the maximum width is 2048. |

#### 5.3.4.57. DEFE\_CH0\_OUTSIZE\_REG

| Offset: 0x104 |                |                 | Register Name: DEFE_CH0_OUTSIZE_REG                                                                        |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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 |

| Offset: 0x104 |                |                 | Register Name: DEFE_CH0_OUTSIZE_REG                                                                                                                                                                                |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                        |
| 15:13         | /              | /               | /                                                                                                                                                                                                                  |
| 12:0          | R/W            | 0x0             | <p>OUT_WIDTH<br/>Output layer Y/G component width<br/>The output layer width = The value of these bits add 1</p> <p>When line buffer result selection is horizontal filtered result, the maximum width is 2048</p> |

#### 5.3.4.58. DEFE\_CH0\_HORZFACT\_REG

| Offset: 0x108 |                |                 | Register Name: DEFE_CH0_HORZFACT_REG                                                                                                   |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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> |

#### 5.3.4.59. DEFE\_CH0\_VERTFACT\_REG

| Offset: 0x10C |                |                 | Register Name: DEFE_CH0_VERTFACT_REG |
|---------------|----------------|-----------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                          |
| 31:24         | /              | /               | /                                    |
| 23:16         | R/W            | 0x0             | FACTOR_INT                           |

| Offset: 0x10C |                |                 | Register Name: DEFE_CH0_VERTFACT_REG                                                                                         |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                  |
|               |                |                 | The integer part of the vertical scaling ratio<br>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 |

#### 5.3.4.60. DEFE\_CH0\_HORZPHASE\_REG

| Offset: 0x110 |                |                 | Register Name: DEFE_CH0_HORZPHASE_REG                                                                            |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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}$ |

#### 5.3.4.61. DEFE\_CH0\_VERTPHASE0\_REG

| Offset: 0x114 |                |                 | Register Name: DEFE_CH0_VERTPHASE0_REG                                                                                       |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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}$ |

#### 5.3.4.62. DEFE\_CH0\_VERTPHASE1\_REG

| Offset: 0x118 |                |                 | Register Name: DEFE_CH0_VERTPHASE1_REG                                                                                          |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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}$ |

#### 5.3.4.63. DEFE\_CH0\_HORZTAP0\_REG

| Offset: 0x120 |                |                 | Register Name: DEFE_CH0_HORZTAP0_REG |
|---------------|----------------|-----------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                          |
| 31            | /              | /               | /                                    |
| 30:24         | R/W            | 0x1             | TAP3<br>Tap 3 offset in horizontal   |
| 23            | /              | /               | /                                    |
| 22:16         | R/W            | 0x1             | TAP2<br>Tap 2 offset in horizontal   |
| 15            | /              | /               | /                                    |
| 14:8          | R/W            | 0x1             | TAP1<br>Tap 1 offset in horizontal   |
| 7             | /              | /               | /                                    |
| 6:0           | R/W            | 0x7D            | TAP0<br>Tap 0 offset in horizontal   |

#### 5.3.4.64. DEFE\_CH0\_HORZTAP1\_REG

| Offset: 0x124 |                |                 | Register Name: DEFE_CH0_HORZTAP1_REG |
|---------------|----------------|-----------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                          |

| Offset: 0x124 |                |                 | Register Name: DEFE_CH0_HORZTAP1_REG |
|---------------|----------------|-----------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                          |
| 31            | /              | /               | /                                    |
| 30:24         | R/W            | 0x1             | TAP7<br>Tap 7 offset in horizontal   |
| 23            | /              | /               | /                                    |
| 22:16         | R/W            | 0x1             | TAP6<br>Tap 6 offset in horizontal   |
| 15            | /              | /               | /                                    |
| 14:8          | R/W            | 0x1             | TAP5<br>Tap 5 offset in horizontal   |
| 7             | /              | /               | /                                    |
| 6:0           | R/W            | 0x1             | TAP4<br>Tap 4 offset in horizontal   |

#### 5.3.4.65. DEFE\_CH0\_VERTTAP\_REG

| Offset: 0x128 |                |                 | Register Name: DEFE_CH0_VERTTAP_REG |
|---------------|----------------|-----------------|-------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                         |
| 31            | /              | /               | /                                   |
| 30:24         | R/W            | 0x1             | TAP3<br>Tap 3 offset in vertical    |
| 23            | /              | /               | /                                   |
| 22:16         | R/W            | 0x1             | TAP2<br>Tap 2 offset in vertical    |
| 15            | /              | /               | /                                   |
| 14:8          | R/W            | 0x1             | TAP1<br>Tap 1 offset in vertical    |
| 7             | /              | /               | /                                   |
| 6:0           | R/W            | 0x7F            | TAP0<br>Tap 0 offset in vertical    |

#### 5.3.4.66. DEFE\_CH1\_INSIZE\_REG

| Offset: 0x200 |                |                 | Register Name: DEFE_CH1_INSIZE_REG                                                                                                                                                           |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                  |
| 31:29         | /              | /               | /                                                                                                                                                                                            |
| 28:16         | R/W            | 0x0             | <p>IN_HEIGHT<br/>Input image U/R component height<br/>Input image height = The value of these bits add 1</p>                                                                                 |
| 15:13         | /              | /               | /                                                                                                                                                                                            |
| 12:0          | R/W            | 0x0             | <p>IN_WIDTH<br/>Input image U/R component width<br/>The image width = The value of these bits add 1</p> <p>When line buffer result selection is original data, the maximum width is 2048</p> |

#### 5.3.4.67. DEFE\_CH1\_OUTSIZE\_REG

| Offset: 0x204 |                |                 | Register Name: DEFE_CH1_OUTSIZE_REG                                                                                                                                                                                |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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</p> <p>When line buffer result selection is horizontal filtered result, the maximum width is 2048</p> |

#### 5.3.4.68. DEFE\_CH1\_HORZFACT\_REG

| Offset: 0x208 |                |                 | Register Name: DEFE_CH1_HORZFACT_REG                                                                                          |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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 |

#### 5.3.4.69. DEFE\_CH1\_VERTFACT\_REG

| Offset: 0x20C |                |                 | Register Name: DEFE_CH1_VERTFACT_REG                                                                                         |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                  |
| 31:24         | /              | /               | /                                                                                                                            |
| 23:16         | R/W            | 0x0             | FACTOR_INT<br>The integer part of the vertical scaling ratio<br>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 |

#### 5.3.4.70. DEFE\_CH1\_HORZPHASE\_REG

| Offset: 0x210 |                |                 | Register Name: DEFE_CH1_HORZPHASE_REG                                                                            |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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}$ |

#### 5.3.4.71. DEFE\_CH1\_VERTPHASE0\_REG

| Offset: 0x214 |                |                 | Register Name: DEFE_CH1_VERTPHASE0_REG                                                                                       |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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}$ |

#### 5.3.4.72. DEFE\_CH1\_VERTPHASE1\_REG

| Offset: 0x218 |                |                 | Register Name: DEFE_CH1_VERTPHASE1_REG                                                                                          |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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}$ |

#### 5.3.4.73. DEFE\_CH1\_HORZTAP0\_REG

| Offset: 0x220 |                |                 | Register Name: DEFE_CH1_HORZTAP0_REG |
|---------------|----------------|-----------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                          |
| 31            | /              | /               | /                                    |
| 30:24         | R/W            | 0x1             | TAP3<br>Tap 3 offset in horizontal   |
| 23            | /              | /               | /                                    |
| 22:16         | R/W            | 0x1             | TAP2<br>Tap 2 offset in horizontal   |
| 15            | /              | /               | /                                    |
| 14:8          | R/W            | 0x1             | TAP1<br>Tap 1 offset in horizontal   |
| 7             | /              | /               | /                                    |
| 6:0           | R/W            | 0x7D            | TAP0<br>Tap 0 offset in horizontal   |

#### 5.3.4.74. DEFE\_CH1\_HORZTAP1\_REG

| Offset: 0x224 |                |                 | Register Name: DEFE_CH1_HORZTAP1_REG |
|---------------|----------------|-----------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                          |
| 31            | /              | /               | /                                    |
| 30:24         | R/W            | 0x1             | TAP7<br>Tap 7 offset in horizontal   |
| 23            | /              | /               | /                                    |
| 22:16         | R/W            | 0x1             | TAP6<br>Tap 6 offset in horizontal   |
| 15            | /              | /               | /                                    |
| 14:8          | R/W            | 0x1             | TAP5<br>Tap 5 offset in horizontal   |
| 7             | /              | /               | /                                    |
| 6:0           | R/W            | 0x1             | TAP4                                 |

| Offset: 0x224 |                |                 | Register Name: DEFE_CH1_HORZTAP1_REG |
|---------------|----------------|-----------------|--------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                          |
|               |                |                 | Tap 4 offset in horizontal           |

#### 5.3.4.75. DEFE\_CH1\_VERTTAP\_REG

| Offset: 0x228 |                |                 | Register Name: DEFE_CH1_VERTTAP_REG |
|---------------|----------------|-----------------|-------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                         |
| 31            | /              | /               | /                                   |
| 30:24         | R/W            | 0x1             | TAP3<br>Tap 3 offset in vertical    |
| 23            | /              | /               | /                                   |
| 22:16         | R/W            | 0x1             | TAP2<br>Tap 2 offset in vertical    |
| 15            | /              | /               | /                                   |
| 14:8          | R/W            | 0x1             | TAP1<br>Tap 1 offset in vertical    |
| 7             | /              | /               | /                                   |
| 6:0           | R/W            | 0x7F            | TAP0<br>Tap 0 offset in vertical    |

#### 5.3.4.76. DEFE\_CH0\_HORZCOEF0\_REGN (N=0 :31)

| Offset: 0x400+N*4 |                |             | Register Name: DEFE_CH0_HORZCOEF0_REGN                                                |
|-------------------|----------------|-------------|---------------------------------------------------------------------------------------|
| Bit               | Read/<br>Write | Default/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                                                   |

| Offset: 0x400+N*4 |                |                 | Register Name: DEFE_CH0_HORZCOEF0_REGN                                        |
|-------------------|----------------|-----------------|-------------------------------------------------------------------------------|
| Bit               | Read/<br>Write | Default/H<br>ex | Description                                                                   |
|                   |                |                 | 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<br>Horizontal tap0 coefficient<br>The value equals to coefficient* $2^6$ |

#### 5.3.4.77. DEFE\_CH0\_HORZCOEF1\_REGN (N=0 :31)

| Offset: 0x480+N*4 |                |                 | Register Name: DEFE_CH0_HORZCOEF1_REGN                                        |
|-------------------|----------------|-----------------|-------------------------------------------------------------------------------|
| Bit               | Read/<br>Write | Default/<br>Hex | Description                                                                   |
| 31:24             | R/W            | 0x0             | TAP7<br>Horizontal tap7 coefficient<br>The value equals to coefficient* $2^6$ |
| 23:16             | R/W            | 0x0             | TAP6<br>Horizontal tap6 coefficient<br>The value equals to coefficient* $2^6$ |
| 15:8              | R/W            | 0x0             | TAP5<br>Horizontal tap5 coefficient<br>The value equals to coefficient* $2^6$ |
| 7:0               | R/W            | 0x0             | TAP4<br>Horizontal tap4 coefficient<br>The value equals to coefficient* $2^6$ |

### 5.3.4.78. DEFE\_CH0\_VERTCOEF\_REGN (N=0 :31)

| Offset: 0x500+N*4 |                |                 | Register Name: DEFE_CH0_VERTCOEF_REGN                                               |
|-------------------|----------------|-----------------|-------------------------------------------------------------------------------------|
| Bit               | Read/<br>Write | 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> |

### 5.3.4.79. DEFE\_CH1\_HORZCOEF0\_REGN (N=0 :31)

| Offset: 0x600+N*4 |                |                 | Register Name: DEFE_CH1_HORZCOEF0_REGN                                                |
|-------------------|----------------|-----------------|---------------------------------------------------------------------------------------|
| Bit               | Read/<br>Write | 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> |

#### 5.3.4.80. DEFE\_CH1\_HORZCOEF1\_REGN (N=0 :31)

| Offset: 0x680+N*4 |                |                 | Register Name: DEFE_CH1_HORZCOEF1_REGN                                                |
|-------------------|----------------|-----------------|---------------------------------------------------------------------------------------|
| Bit               | Read/<br>Write | Default/<br>Hex | Description                                                                           |
| 31:24             | R/W            | 0x0             | TAP7<br>Horizontal tap7 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 23:16             | R/W            | 0x0             | TAP6<br>Horizontal tap6 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 15:8              | R/W            | 0x0             | TAP5<br>Horizontal tap5 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 7:0               | R/W            | 0x0             | TAP4<br>Horizontal tap4 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |

#### 5.3.4.81. DEFE\_CH1\_VERTCOEF\_REGN (N=0 :31)

| Offset: 0x700+N*4 |                |                 | Register Name: DEFE_CH1_VERTCOEF_REGN                                               |
|-------------------|----------------|-----------------|-------------------------------------------------------------------------------------|
| Bit               | Read/<br>Write | 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                                                   |

| Offset: 0x700+N*4 |                |                 | Register Name: DEFE_CH1_VERTCOEF_REGN          |
|-------------------|----------------|-----------------|------------------------------------------------|
| Bit               | Read/<br>Write | Default/<br>Hex | Description                                    |
|                   |                |                 | The value equals to coefficient*2 <sup>6</sup> |

#### 5.3.4.82. DEFE\_VPP\_EN\_REG

| Offset: 0xA00 |                |                 | Register Name: DEFE_VPP_EN_REG              |
|---------------|----------------|-----------------|---------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                 |
| 31:1          | /              | /               | /                                           |
| 0             | R/W            | 0x0             | EN<br>VPP enable<br>0: Disable<br>1: Enable |

#### 5.3.4.83. DEFE\_VPP\_DCTI\_REG

| Offset: 0xA04 |                |             | Register Name: DEFE_VPP_DCTI_REG                                                                                                                                                                                                                                   |
|---------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                                                                                                                                                                        |
| 31            | R/W            | 0x0         | UV_SEPARATE_EN<br>UV separate enable<br>0: U/V will be under direction detection control<br>1: U/V wont be under direction detection control                                                                                                                       |
| 30            | /              | /           | /                                                                                                                                                                                                                                                                  |
| 29            | R/W            | 0x0         | UV_SAME_SIGN_MAX/MIN_MODE_SEL<br>UV direction detection using max or min of  U / V  in same sign condition<br>when related separate mode select “Using Max/Min mode” and U/V path shift are in the same sign, path shift use<br>0: min( U , V )<br>1: max( U , V ) |
| 28            | R/W            | 0x0         | UV_DIFF_SIGN_MAX/MIN_MODE_SEL<br>UV direction detection using max or min of  U / V  in different sign                                                                                                                                                              |

| Offset: 0xA04 |                |                 | Register Name: DEFE_VPP_DCTI_REG                                                                                                                                                             |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                  |
|               |                |                 | <p>condition</p> <p>when related separate mode select “Using Max/Min mode” and U/V path shift are in the different sign, path shift use</p> <p>0: min( U , V )</p> <p>1: max( U , V )</p>    |
| 27:26         | R/W            | 0x0             | <p>UV_SAME_SIGN_MODE_SEL</p> <p>UV separate mode in same sign condition</p> <p>00: Using U always</p> <p>01: Using V always</p> <p>10: Using 0 always</p> <p>11: Using Max/Min mode</p>      |
| 25:24         | R/W            | 0x0             | <p>UV_DIFF_SIGN_MODE_SEL</p> <p>UV separate mode in different sign condition</p> <p>00: Using U always</p> <p>01: Using V always</p> <p>10: Using 0 always</p> <p>11: Using Max/Min mode</p> |
| 23:22         | /              | /               | /                                                                                                                                                                                            |
| 21:16         | R/W            | 0x0             | DCTI_GAIN                                                                                                                                                                                    |
| 15:12         | R/W            | 0x0             | <p>DCTI_PATH_LIMIT</p> <p>Max path limit equal to 12</p>                                                                                                                                     |
| 11:10         | R/W            | 0x0             | <p>DCTI_FILTER2_SEL</p> <p>DCTI 2<sup>nd</sup> filter algorithm selection</p> <p>00: algorithm0</p> <p>01: algorithm1</p> <p>10: algorithm2</p> <p>11: reserved</p>                          |
| 9:8           | R/W            | 0x0             | <p>DCTI_FILTER1_SEL</p> <p>DCTI 1<sup>st</sup> filter algorithm selection</p> <p>00: algorithm0</p> <p>01: algorithm1</p> <p>10: algorithm2</p> <p>11: reserved</p>                          |
| 7             | R/W            | 0x0             | DCTI_SUPHILL_EN                                                                                                                                                                              |

| Offset: 0xA04 |                |                 | Register Name: DEFE_VPP_DCTI_REG                                       |
|---------------|----------------|-----------------|------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                                                            |
|               |                |                 | DCTI super hill protection enable<br>0: Disable<br>1: Enable           |
| 6             | R/W            | 0x0             | DCTI_HILL_EN<br>DCTI hill protection enable<br>0: Disable<br>1: Enable |
| 5:1           | /              | /               | /                                                                      |
| 0:            | R/W            | 0x0             | DCTI_EN<br>0: Disable<br>1: Enable                                     |

#### 5.3.4.84. DEFE\_VPP\_LP1\_REG

| Offset: 0xA08 |                |                 | Register Name: DEFE_VPP_LP1_REG           |
|---------------|----------------|-----------------|-------------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                               |
| 31:29         | /              | /               | /                                         |
| 28:24         | R/W            | 0x0             | BETA<br>LP high-pass filter gain(BETA)    |
| 23:21         | /              | /               | /                                         |
| 20:16         | R/W            | 0x0             | ALPHA<br>LP band-pass filter2 gain(ALPHA) |
| 15:13         | /              | /               | /                                         |
| 12:8          | R/W            | 0x0             | TAU<br>LP band-pass filter1 gain(TAU)     |
| 7:1           | /              | /               | /                                         |
| 0             | R/W            | 0x0             | LP_EN<br>0: Disable<br>1: Enable          |

#### 5.3.4.85. DEFE\_VPP\_LP2\_REG

| Offset: 0xA0C |                |             | Register Name: DEFE_VPP_LP2_REG                                                                                       |
|---------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/Hex | Description                                                                                                           |
| 31:24         | R/W            | 0x0         | LIMIT_THR<br>LP limit threshold                                                                                       |
| 23:22         | R/W            | 0x0         | DELTA<br>LP LUT selection for overshoot(DELTA)<br>00: DELTA0<br>01: DELTA025<br>10: DELTA05<br>11: DELTA1             |
| 21:18         | /              | /           | /                                                                                                                     |
| 17:16         | R/W            | 0x0         | NEGGAIN<br>LP LUT selection for undershot(NEGGAIN)<br>00: NEGGAIN0<br>01: NEGGAIN025<br>10: NEGGAIN05<br>11: NEGGAIN1 |
| 15:8          | R/W            | 0x0         | CORTHR<br>LP coring threshold(CORTHR)                                                                                 |
| 7:5           | /              | /           | /                                                                                                                     |
| 4:0           | R/W            | 0x0         | LPF_GAIN<br>LP low-pass-filter gain                                                                                   |

#### 5.3.4.86. DEFE\_VPP\_WLE\_REG

| Offset: 0xA10 |                |                 | Register Name: DEFE_VPP_WLE_REG |
|---------------|----------------|-----------------|---------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                     |
| 31:24         | /              | /               | /                               |
| 23:16         | R/W            | 0x0             | WLE_GAIN<br>WLE gain            |
| 15:8          | R/W            | 0x0             | WLE_THR<br>WLE threshold        |

| Offset: 0xA10 |                |                 | Register Name: DEFE_VPP_WLE_REG |
|---------------|----------------|-----------------|---------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                     |
|               |                |                 | Note: MUST BE set 128~255.      |
| 7:1           | /              | /               | /                               |
| 0             | R/W            | 0x0             | WLE_EN<br>WLE enable            |

#### 5.3.4.87. DEFE\_VPP\_BLE\_REG

| Offset: 0xA14 |                |                 | Register Name: DEFE_VPP_BLE_REG                      |
|---------------|----------------|-----------------|------------------------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                                          |
|               |                |                 | /                                                    |
| 31:24         | /              | /               | /                                                    |
| 23:16         | R/W            | 0x0             | BLE_GAIN<br>BLE gain                                 |
| 15:8          | R/W            | 0x0             | BLE_THR<br>BLE threshold<br>Note: MUST BE set 0~127. |
| 7:1           | /              | /               | /                                                    |
| 0             | R/W            | 0x0             | BLE_EN<br>BLE enable                                 |

## 5.4. Display Engine Backend

### 5.4.1. Overview

The display engine backend features:

- 4 moveable and size-adjustable layers
- Layer size up to 8192x8192 pixels
- Alpha blending support
- Color key support
- Write back function support
- 1/2/4/8 bpp mono / palette support
- 16/24/32 bpp color support (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
- On chip SRAM support
  - 256 entry 32-bpp palette
  - 1/2/4/8 bpp internal frame buffer
  - Gamma correction support
- Hardware cursor support
  - 32x32 @8bpp
  - 64x64 @2bpp
  - 64x32 @4bpp
  - 32x64 @4bpp
- Sprite function support
  - 32bpp true color or 8bpp palette mode
  - up to 32 independent sprite blocks
  - each block can be set arbitrary coordinate
  - adjustable block size
- YUV input channel support
- Vertical keystone correction
- Output color correction

## 5.4.2. Display Engine Block Diagram



## 5.4.3. DEBE Register list

| Module name | Base Address |
|-------------|--------------|
| BE0         | 0x01e60000   |
| BE1         | 0x01e40000   |

| Register name         | Offset        | Description                                       |
|-----------------------|---------------|---------------------------------------------------|
| DEBE_MODCTL_REG       | 0x800         | DE back-end 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 |

| <b>Register name</b>     | <b>Offset</b> | <b>Description</b>                                           |
|--------------------------|---------------|--------------------------------------------------------------|
| 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         | DE backend write back control register                       |
| DEBE_WBADD_REG           | 0x8F4         | DE backend write back address register                       |
| DEBE_WBLINETHICKNESS_REG | 0x8F8         | DE backend write back buffer line thickness register         |
| DEBE_SPREN_REG           | 0x900         | DE-sprite enable register                                    |
| DEBE_SPRFMTCTL_REG       | 0x908         | DE-sprite format control register                            |
| DEBE_SPRALPHACTL_REG     | 0x90C         | DE-sprite alpha control register                             |
| DEBE_IYUVCTL_REG         | 0x920         | DE backend input YUV channel control register                |
| DEBE_IYUVADD_REG         | 0x930 – 0x938 | DE backend YUV channel frame buffer address register         |
| DEBE_IYUVTIMING_REG      | 0x940 – 0x948 | DE backend YUV channel buffer line width register            |
| DEBE_YGCOEF_REG          | 0x950 – 0x958 | DE backend Y/G coefficient register                          |
| DEBE_YGCONS_REG          | 0x95C         | DE backend Y/G constant register                             |
| DEBE_URCOEF_REG          | 0x960 – 0x968 | DE backend U/R coefficient register                          |
| DEBE_URCONS_REG          | 0x96C         | DE backend U/R constant register                             |
| DEBE_VBCOEF_REG          | 0x970 – 0x978 | DE backend V/B coefficient register                          |
| DEBE_VBCONS_REG          | 0x97C         | DE backend V/B constant register                             |
| DEBE_KSCTL_REG           | 0x980         | DE backend keystone correction control register              |
| DEBE_KSBKCOLOR_REG       | 0x984         | DE backend keystone back color control register              |
| DEBE_KSFSTLINEWIDTH_REG  | 0x988         | DE backend keystone output first line width setting register |

| <b>Register name</b>        | <b>Offset</b> | <b>Description</b>                                             |
|-----------------------------|---------------|----------------------------------------------------------------|
| DEBE_KSVSCAFCT_REG          | 0x98C         | DE backend keystone vertical scaling factor register           |
| DEBE_KSHSCACOEF_RAM         | 0x9A0 – 0x9BC | DE backend keystone horizontal filtering coefficient RAM block |
| DEBE_OCCTL_REG              | 0x9C0         | DE backend output color control register                       |
| DEBE_OCRCOEF_REG            | 0x9D0-0x9D8   | DE backend output color R coefficient register                 |
| DEBE_OCRCONS_REG            | 0x9DC         | DE backend output color R constant register                    |
| DEBE_OCGCOEF_REG            | 0x9E0-0x9E8   | DE backend output color G coefficient register                 |
| DEBE_OCGCONS_REG            | 0x9EC         | DE backend output color G constant register                    |
| DEBE_OCBCOEF_REG            | 0x9F0-0x9F8   | DE backend output color B coefficient register                 |
| DEBE_OCBCONS_REG            | 0x9FC         | DE backend output color B constant register                    |
| DEBE_SPRCOORCTL_REG         | 0xA00-0xAF0   | DE-sprite single block coordinate control register             |
| DEBE_SPRATTCTL_REG          | 0xB00-0xBFC   | DE-sprite single block attribute control register              |
| DEBE_SPRADD_SRAM            | 0xC00-0xCFC   | DE-sprite single block address setting SRAM array              |
| DEBE_SPRLINEWIDTH_SRAM      | 0xD00-0xDFC   | DE-sprite single block line width setting SRAM array           |
|                             |               |                                                                |
| Memories                    |               |                                                                |
| 0x4000-0x43FF               |               |                                                                |
| DE-sprite palette table     |               |                                                                |
| 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         |               |                                                                |

## 5.4.4. DEBE Register Description

### 5.4.4.1. DE BACK-END MODE CONTROL REGISTER

| Offset: 0x800 |                |                 | Register Name: DEBE_MODCTL_REG                                                                                                                                                                        |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                           |
| 31:30         | /              | /               | /                                                                                                                                                                                                     |
| 29            | R/W            | 0               | <b>LINE_SEL</b><br>Start top/bottom line selection in interlace mode                                                                                                                                  |
| 28            | R/W            | 0               | <b>ITLMOD_EN</b><br>Interlace mode enable<br>0:disable<br>1:enable                                                                                                                                    |
| 27            | /              | /               | /                                                                                                                                                                                                     |
| 22:20         | R/W            | 0               | <b>OUT_SEL</b><br>Output selection<br>000:LCD<br>110:FE0 only<br>111:FE1 only<br>Other: reserved                                                                                                      |
| 19:17         | /              | /               | /                                                                                                                                                                                                     |
| 16            | R/W            | 0               | <b>HWC_EN</b><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               | <b>LAY3_EN</b><br>Layer3 Enable/Disable<br>0: Disabled<br>1: Enabled                                                                                                                                  |
| 10            | R/W            | 0               | <b>LAY2_EN</b><br>Layer2 Enable/Disable<br>0: Disabled<br>1: Enabled                                                                                                                                  |

| Offset: 0x800 |                |                 | Register Name: DEBE_MODCTL_REG                                                           |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                              |
| 9             | R/W            | 0               | <b>LAY1_EN</b><br>Layer1 Enable/Disable<br>0: Disabled<br>1: Enabled                     |
| 8             | R/W            | 0               | <b>LAY0_EN</b><br>Layer0 Enable/Disable<br>0: Disabled<br>1: Enabled                     |
| 7:6           | /              | /               | /                                                                                        |
| 5             | R/W            | 0               | <b>OCSC_EN</b><br>Output CSC enable<br>0: disable<br>1: enable                           |
| 4             | R/W            | 0               | <b>DEFLK_EN</b><br>De-flicker enable<br>0: disable<br>1: enable                          |
| 3             | /              | /               | /                                                                                        |
| 2             | R/W            | 0               | <b>DLP_START_CTL</b><br>Direct LCD channel Start & Reset control<br>0: reset<br>1: start |
| 1             | R/W            | 0               | <b>START_CTL</b><br>Normal output channel Start & Reset control<br>0: reset<br>1: start  |
| 0             | R/W            | 0               | <b>DEBE_EN</b><br>DE back-end enable/disable<br>0: disable<br>1: enable                  |

#### 5.4.4.2. DE-BACK COLOR CONTROL REGISTER

| Offset: 0x804 |                |                 | Register Name: DEBE_BACKCOLOR_REG                               |
|---------------|----------------|-----------------|-----------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                     |
| 31:24         | /              | /               | /                                                               |
| 23:16         | R/W            | UDF             | <b>BK_RED</b><br>Red<br>Red screen background color value       |
| 15:8          | R/W            | UDF             | <b>BK_GREEN</b><br>Green<br>Green screen background color value |
| 7:0           | R/W            | UDF             | <b>BK_BLUE</b><br>Blue<br>Blue screen background color value    |

#### 5.4.4.3. DE-BACK DISPLAY SIZE SETTING REGISTER

| Offset: 0x808 |                |                 | Register Name: DEBE_DISSIZE_REG                                                                |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                    |
| 31:16         | R/W            | UDF             | <b>DIS_HEIGHT</b><br>Display height<br>The real display height = The value of these bits add 1 |
| 15:0          | R/W            | UDF             | <b>DIS_WIDTH</b><br>Display width<br>The real display width = The value of these bits add 1    |

#### 5.4.4.4. DE-LAYER SIZE REGISTER

|                                                                                            |                                        |
|--------------------------------------------------------------------------------------------|----------------------------------------|
| <b>Offset:</b><br><br>Layer 0: 0x810<br>Layer 1: 0x814<br>Layer 2: 0x818<br>Layer 3: 0x81C | <b>Register Name: DEBE_LAYSIZE_REG</b> |
|--------------------------------------------------------------------------------------------|----------------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                    |
|------------|------------------------|-------------------------|---------------------------------------------------------------------------------------|
| 31:29      | /                      | /                       | /                                                                                     |
| 28:16      | R/W                    | UDF                     | <b>LAY_HEIGHT</b><br>Layer Height<br>The Layer Height = The value of these bits add 1 |
| 15:13      | /                      | /                       | /                                                                                     |
| 12:0       | R/W                    | UDF                     | <b>LAY_WIDTH</b><br>Layer Width<br>The Layer Width = The value of these bits add 1    |

#### 5.4.4.5. DE-LAYER COORDINATE CONTROL REGISTER

| <b>Offset:</b><br><b>Layer 0: 0x820</b><br><b>Layer 1: 0x824</b><br><b>Layer 2: 0x828</b><br><b>Layer 3: 0x82C</b> |                        |                         | <b>Register Name: DEBE_LAYCOOR_REG</b>                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------|------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                                                                                                         | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                          |
| 31:16                                                                                                              | R/W                    | UDF                     | <b>LAY_YCOOR</b><br>Y coordinate<br>Y is the left-top y coordinate of layer on screen in pixels<br><br>The Y represent the two's complement |
| 15:0                                                                                                               | R/W                    | UDF                     | <b>LAY_XCOOR</b><br>X coordinate<br>X is left-top x coordinate of the layer on screen in pixels<br><br>The X represent the two's complement |

Setting the layer0-layer3 the coordinate (left-top) on screen control information

#### 5.4.4.6. DE-LAYER FRAME BUFFER LINE WIDTH REGISTER

| <b>Offset:</b><br><br>Layer 0: 0x840<br>Layer 1: 0x844<br>Layer 2: 0x848<br>Layer 3: 0x84C |                |                 | <b>Register Name: DEBE_LAYLINEWIDTH_REG</b>                   |
|--------------------------------------------------------------------------------------------|----------------|-----------------|---------------------------------------------------------------|
| Bit                                                                                        | Read/W<br>rite | Default/<br>Hex | Description                                                   |
| 31:0                                                                                       | R/W            | UDF             | <b>LAY_LINEWIDTH</b><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.

#### 5.4.4.7. DE-LAYER FRAME BUFFER LOW 32 BIT ADDRESS REGISTER

| <b>Offset:</b><br><br>Layer 0: 0x850<br>Layer 1: 0x854<br>Layer 2: 0x858<br>Layer 3: 0x85C |                |                 | <b>Register Name: DEBE_LAYFB_L32ADD_REG</b>                                            |
|--------------------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------------------|
| Bit                                                                                        | Read/W<br>rite | Default/<br>Hex | Description                                                                            |
| 31:0                                                                                       | R/W            | UDF             | <b>LAYFB_L32ADD</b><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.

#### 5.4.4.8. DE-LAYER FRAME BUFFER HIGH 4 BIT ADDRESS REGISTER

| <b>Offset: 0x860</b> |                |                 | <b>Register Name: DEBE_LAYFB_H4ADD_REG</b> |
|----------------------|----------------|-----------------|--------------------------------------------|
| Bit                  | Read/W<br>rite | Default/<br>Hex | Description                                |
| 31:28                | /              | /               | /                                          |

| Offset: 0x860 |                |                 | Register Name: DEBE_LAYFB_H4ADD_REG                                |
|---------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                        |
| 27:24         | R/W            | UDF             | <b>LAY3FB_H4ADD</b><br>Layer3<br>Layer Frame Buffer Address in bit |
| 23:20         | /              | /               | /                                                                  |
| 19:16         | R/W            | UDF             | <b>LAY2FB_H4ADD</b><br>Layer2<br>Layer Frame Buffer Address in bit |
| 15:12         | /              | /               | /                                                                  |
| 11:8          | R/W            | UDF             | <b>LAY1FB_H4ADD</b><br>Layer1<br>Layer Frame Buffer Address in bit |
| 7:4           | /              | /               | /                                                                  |
| 3:0           | R/W            | UDF             | <b>LAY0FB_H4ADD</b><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.

#### 5.4.4.9. DE-REGISTER BUFFER CONTROL REGISTER

| Offset: 0x870 |                |                 | Register Name: DEBE_REGBUFFCTL_REG                                                                                                                                                                                         |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                |
| 31:2          | /              | /               | /                                                                                                                                                                                                                          |
| 1             | R/W            | 0X00            | <b>REGAUTOLOAD_DIS</b><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 write 1 to bit0 of this register |
| 0             | R/W            | 0X00            | <b>REGLOADCTL</b><br>Register load control<br>When the Module registers loading auto mode disable control bit is set, the registers will be loaded by write 1 to the bit, and the bit                                      |

| Offset: 0x870 |                |                 | Register Name: DEBE_REGBUFFCTL_REG                  |
|---------------|----------------|-----------------|-----------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                         |
|               |                |                 | will self clean when the registers is loading done. |

#### 5.4.4.10. DE-COLOR KEY MAX REGISTER

| Offset: 0x880 |                |                 | Register Name: DEBE_CKMAX_REG                  |
|---------------|----------------|-----------------|------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                    |
| 31:24         | /              | /               | /                                              |
| 23:16         | R/W            | UDF             | <b>CKMAX_R</b><br>Red<br>Red color key max     |
| 15:8          | R/W            | UDF             | <b>CKMAX_G</b><br>Green<br>Green color key max |
| 7:0           | R/W            | UDF             | <b>CKMAX_B</b><br>Blue<br>Blue color key max   |

#### 5.4.4.11. DE-COLOR KEY MIN REGISTER

| Offset: 0x884 |                |                 | Register Name: DEBE_CKMIN_REG                  |
|---------------|----------------|-----------------|------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                    |
| 31:24         | /              | /               | /                                              |
| 23:16         | R/W            | UDF             | <b>CKMIN_R</b><br>Red<br>Red color key min     |
| 15:8          | R/W            | UDF             | <b>CKMIN_G</b><br>Green<br>Green color key min |
| 7:0           | R/W            | UDF             | <b>CKMIN_B</b>                                 |

| Offset: 0x884 |                |                 | Register Name: DEBE_CKMIN_REG |
|---------------|----------------|-----------------|-------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                   |
|               |                |                 | Blue<br>Blue color key min    |

#### 5.4.4.12. DE-COLOR KEY CONFIGURATION REGISTER

| Offset: 0x888 |                |                 | Register Name: DEBE_CKCFG_REG                                                                                                                                                   |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                     |
| 31:6          | /              | /               | /                                                                                                                                                                               |
| 5:4           | R/W            | UDF             | <b>CKR_MATCH</b><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             | <b>CKG_MATCH</b><br>Green 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) |
| 1:0           | R/W            | UDF             | <b>CKB_MATCH</b><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)  |

## DE-LAYER ATTRIBUTE CONTROL REGISTER0

| <b>Offset:</b><br><b>Layer0: 0x890</b><br><b>Layer1: 0x894</b><br><b>Layer2: 0x898</b><br><b>Layer3: 0x89C</b> |                        |                         | <b>Register Name: DEBE_ATTCTL_REG0</b>                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------------------------------------------------------|------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                                                                                                     | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                                                                                                                                                                         |
| 31:24                                                                                                          | R/W                    | UDF                     | <p><b>LAY_GLBALPHA</b><br/> Alpha value<br/> Alpha value is used for this layer</p>                                                                                                                                                                                                                        |
| 23:22                                                                                                          | R/W                    | UDF                     | <p><b>LAY_WORKMOD</b><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</p> <p>Except the normal mode, if the other working mode is selected, the on chip SRAM will be enabled.</p> |
| 21:20                                                                                                          | /                      | /                       | /                                                                                                                                                                                                                                                                                                          |
| 19:18                                                                                                          | R/W                    | UDF                     | <p><b>CKEN</b><br/> Color key Mode<br/> 00: disabled color key<br/> 01: The layer color key match another channel pixel data in Alpha Blender1.<br/> 1x: Reserved</p> <p>Only 2 channels pixel data can get to Alpha Blender1 at the same screen coordinate.</p>                                           |
| 17:16                                                                                                          | /                      | /                       | /                                                                                                                                                                                                                                                                                                          |
| 15                                                                                                             | R/W                    | UDF                     | <p><b>LAY_PIPESEL</b><br/> Pipe Select<br/> 0: select Pipe 0<br/> 1: select Pipe 1</p>                                                                                                                                                                                                                     |
| 14:12                                                                                                          | /                      | /                       | /                                                                                                                                                                                                                                                                                                          |
| 11:10                                                                                                          | R/W                    | UDF                     | <p><b>LAY_PRISEL</b><br/> Priority</p>                                                                                                                                                                                                                                                                     |

| <b>Offset:</b><br><b>Layer0: 0x890</b><br><b>Layer1: 0x894</b><br><b>Layer2: 0x898</b><br><b>Layer3: 0x89C</b> |                |                 | <b>Register Name: DEBE_ATTCTL_REG0</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------------------------------------------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                |                |                 | <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, soft designer must keep the condition.</p> <p>If more than 1 layer selects 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:5                                                                                                            | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4                                                                                                              | R/W            | UDF             | <p><b>LAY_VDOSEL</b><br/>           Video channel selection control<br/>           0:select video channel 0 (FE0)<br/>           1:select video channel 1 (FE1)</p> <p>The selection setting is only valid when Layer video channel selection is enabled.</p>                                                                                                                                                                                                                                  |
| 3                                                                                                              | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2                                                                                                              | R/W            | UDF             | <p><b>LAY_YUVEN</b><br/>           YUV channel selection<br/>           0: disable<br/>           1: enable</p> <p>Setting 2 or more layers YUV channel mode is illegal, programmer should confirm it.</p>                                                                                                                                                                                                                                                                                     |
| 1                                                                                                              | R/W            | UDF             | <p><b>LAY_VDOEN</b><br/>           Layer video channel selection enable control<br/>           0: disable<br/>           1: enable</p>                                                                                                                                                                                                                                                                                                                                                         |

| <b>Offset:</b><br><b>Layer0: 0x890</b><br><b>Layer1: 0x894</b><br><b>Layer2: 0x898</b><br><b>Layer3: 0x89C</b> |                |                 | <b>Register Name: DEBE_ATTCTL_REG0</b>                                                                                                                                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                       |
|                                                                                                                |                |                 | <p>Normally, one layer can not be set both video channel and YUV channel mode, if both 2 mode is set, the layer will work in video channel mode, YUV channel mode will be ignored, programmer should confirm it.</p> <p>Setting 2 or more layers video channel mode is illegal, programmer should confirm it.</p> |
|                                                                                                                |                |                 | <b>LAY_GLBALPHAEN</b><br>Alpha Enable<br>0: Disabled the alpha value of this register<br>1: Enabled the alpha value of this register for the layer                                                                                                                                                                |
| 0                                                                                                              | R/W            | UDF             | <b>LAY_GLBALPHAEN</b><br>Alpha Enable<br>0: Disabled the alpha value of this register<br>1: Enabled the alpha value of this register for the layer                                                                                                                                                                |

#### 5.4.4.13. DE-LAYER ATTRIBUTE CONTROL REGISTER1

| <b>Offset:</b><br><b>Layer0: 0x8A0</b><br><b>Layer1: 0x8A4</b><br><b>Layer2: 0x8A8</b><br><b>Layer3: 0x8AC</b> |                |                 | <b>Register Name: DEBE_ATTCTL_REG1</b>                                                                                                                                              |
|----------------------------------------------------------------------------------------------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                         |
| 31:16                                                                                                          | /              | /               | /                                                                                                                                                                                   |
| 15:14                                                                                                          | R/W            | UDF             | <b>LAY_HSCAFCT</b><br>Setting the internal frame buffer scaling factor, only valid in internal frame buffer mode<br>SH<br>Height scale factor<br>00: no scaling<br>01: *2<br>10: *4 |

| <b>Offset:</b><br><b>Layer0: 0x8A0</b><br><b>Layer1: 0x8A4</b><br><b>Layer2: 0x8A8</b><br><b>Layer3: 0x8AC</b> |                |                 | <b>Register Name: DEBE_ATTCTL_REG1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                |                |                 | 11: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13:12                                                                                                          | R/W            | UDF             | <b>LAY_WSCAFCT</b><br>Setting the internal frame buffer scaling factor, only valid in internal frame buffer mode<br>SW<br>Width scale factor<br>00: no scaling<br>01: *2<br>10: *4<br>11: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11:8                                                                                                           | R/W            | UDF             | <b>LAY_FBFMT</b><br>Frame buffer format<br>Normal mode data format<br>0000: mono 1-bpp<br>0001: mono 2-bpp<br>0010: mono 4-bpp<br>0011: mono 8-bpp<br>0100: color 16-bpp (R:6/G:5/B:5)<br>0101: color 16-bpp (R:5/G:6/B:5)<br>0110: color 16-bpp (R:5/G:5/B:6)<br>0111: color 16-bpp (Alpha:1/R:5/G:5/B:5)<br>1000: color 16-bpp (R:5/G:5/B:5/Alpha:1)<br>1001: color 24-bpp (Padding:8/R:8/G:8/B:8)<br>1010: color 32-bpp (Alpha:8/R:8/G:8/B:8)<br>1011: color 24-bpp (R:8/G:8/B:8)<br>1100: color 16-bpp (Alpha:4/R:4/G:4/B:4)<br>Other: Reserved<br><br>Palette Mode data format<br>In palette mode, the data of external frame buffer is regarded as pattern.<br>0000: 1-bpp<br>0001: 2-bpp<br>0010: 4-bpp |

| <b>Offset:</b><br><b>Layer0: 0x8A0</b><br><b>Layer1: 0x8A4</b><br><b>Layer2: 0x8A8</b><br><b>Layer3: 0x8AC</b> |                |                 | <b>Register Name: DEBE_ATTCTL_REG1</b>                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                 |
|                                                                                                                |                |                 | 0011: 8-bpp<br>other: Reserved<br><br>Internal Frame buffer mode data format<br>0000: 1-bpp<br>0001: 2-bpp<br>0010: 4-bpp<br>0011: 8-bpp<br>Other: Reserved |
| 7:3                                                                                                            | /              | /               | /                                                                                                                                                           |
| 2                                                                                                              | R/W            | UDF             | <b>LAY_BRSWAPEN</b><br>B R channel swap<br>0: RGB. Follow the bit[11:8]----RGB<br>1: BGR. Swap the B R channel in the data format.                          |
| 1:0                                                                                                            | R/W            | UDF             | <b>LAY_Fbps</b><br>PS<br>Pixels Sequence<br>See the follow table “Pixels Sequence”                                                                          |

#### 5.4.4.14. 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 |
| P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 | P29 | P28 | P27 | P26 | P25 | P24 | P23 | P22 |

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 | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |
| P04 | P05 | P06 | P07 | P00 | P01 | P02 | P03 | P29 | P28 | P27 | P26 | P25 | P24 | P23 | P22 |

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

#### 5.4.4.15. DE-HWC COORDINATE CONTROL REGISTER

| Offset: 0x8D8 |                |                 | Register Name: DEBE_HWCCTL_REG                   |
|---------------|----------------|-----------------|--------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                      |
| 31:16         | R/W            | UDF             | <b>HWC_YCOOR</b><br>Hardware cursor Y coordinate |
| 15:0          | R/W            | UDF             | <b>HWC_XCOOR</b><br>Hardware cursor X coordinate |

#### 5.4.4.16. DE-HWC FRAME BUFFER FORMAT REGISTER

| Offset: 0x8E0 |                |                 | Register Name: DEBE_HWCFBCTL_REG                                                                                                                                |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                     |
| 31:24         | R/W            | UDF             | <b>HWC_YCOOROFF</b><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             | <b>HWC_XCOOROFF</b><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             | <b>HWC_YSIZE</b>                                                                                                                                                |

| Offset: 0x8E0 |                |                 | Register Name: DEBE_HWCFBCTL_REG                                                                      |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                           |
|               |                |                 | Y size control<br>00: 32pixels per line<br>01: 64pixels per line<br>Other: reserved                   |
| 3:2           | R/W            | UDF             | <b>HWC_XSIZE</b><br>X size control<br>00: 32pixels per row<br>01: 64pixels per row<br>Other: reserved |
| 1:0           | R/W            | UDF             | <b>HWC_FBFMT</b><br>Pixels format control<br>00: 1bpp<br>01: 2bpp<br>10: 4bpp<br>11: 8bpp             |

#### 5.4.4.17. DE BACKEND WRITE BACK CONTROL REGISTER

| Offset: 0x8F0 |                |                 | Register Name: DEBE_WBCTL_REG                                                                                             |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                               |
| 31:13         | /              | /               | /                                                                                                                         |
| 12            | R/W            | UDF             | <b>WB_FMT</b><br>Write back data format setting<br>0:<br>ARGB (little endian system)<br>1:<br>BGRA (little endian system) |
| 11:10         | /              | /               | /                                                                                                                         |
| 9             | R/W            | UDF             | <b>WB_EFLAG</b><br>Error flag<br>0:<br>1: write back error                                                                |

| Offset: 0x8F0 |                |                 | Register Name: DEBE_WBCTL_REG                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8             | R/W            | UDF             | <p><b>WB_STATUS</b><br/>           Write-back process status<br/>           0:<br/>           write-back end or write-back disable<br/>           1:<br/>           write-back in process</p> <p>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 end.</p>                              |
| 7:2           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1             | R/W            | UDF             | <p><b>WB_WOC</b><br/>           Write back only control<br/>           0:<br/>           disable the write back only control, the normal channel data of back end will transfer to LCD/TV controller too.<br/>           1:<br/>           enable the write back only function, the all output data will by pass the LCD/TV controller.</p>                                                                     |
| 0             | R/W            | UDF             | <p><b>WB_EN</b><br/>           Write back enable<br/>           0: Disable<br/>           1: Enable</p> <p>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.</p> <p>The bit will be cleared when the new writing-back frame start to process.</p> |

#### 5.4.4.18. DE BACKEND WRITE BACK ADDRESS REGISTER

|               |                               |
|---------------|-------------------------------|
| Offset: 0x8F4 | Register Name: DEBE_WBADD_REG |
|---------------|-------------------------------|

| Bit  | Read/W<br>rite | Default/<br>Hex | Description                                                   |
|------|----------------|-----------------|---------------------------------------------------------------|
| 31:0 | R/W            | UDF             | <b>WB_ADD</b><br>The start address of write back data in WORD |

#### 5.4.4.19. DE BACKEND WRITE BACK BUFFER LINE WIDTH REGISTER

| Offset: 0x8F8 |                |                 | Register Name: DEBE_WBLINWIDTH_REG                                |
|---------------|----------------|-----------------|-------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                       |
| 31:0          | R/W            | UDF             | <b>WB_LINEWIDTH</b><br>Write back image buffer line width in bits |

#### 5.4.4.20. DE-SPRITE ENABLE REGISTER

| Offset: 0x900 |                |                 | Register Name: DEBE_SPREN_REG                  |
|---------------|----------------|-----------------|------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                    |
| 31:1          | /              | /               | /                                              |
| 0             | R/W            | UDF             | <b>SPR_EN</b><br>0:<br>disable<br>1:<br>enable |

#### 5.4.4.21. DE-SPRITE FORMAT CONTROL REGISTER

| Offset: 0x908 |                |                 | Register Name: DEBE_SPRFMTCTL_REG |
|---------------|----------------|-----------------|-----------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                       |
| 31:13         | /              | /               | /                                 |
| 12            | R/W            | UDF             | <b>SPR_Fbps</b><br>Pixel sequence |

| Offset: 0x908 |                |                 | Register Name: DEBE_SPRFMTCTL_REG                                              |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
|               |                |                 | 0:<br>1:<br>Reference the following illustration                               |
| 11:9          | /              | /               | /                                                                              |
| 8             | R/W            | UDF             | <b>SPR_FBFMT</b><br>Frame buffer format<br>0:32bpp mode<br>1:8bpp palette mode |
| 7:0           | /              | /               | /                                                                              |

#### 5.4.4.22. PIXELS SEQUENCE DESCRIPTION:

32bpp mode: (bit8 will be set 0)

The setting status of the DE-sprite format control register bit12

0:

ARGB (little endian system)

1:

BGRA (little endian system)

8bpp palette mode: (bit8 will be set 1)

The setting status of the DE-sprite format control register bit12

0:

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

1:

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

### DE-SPRITE ALPHA CONTROL REGISTER

| Offset: 0x90C |                |                 | Register Name: DEBE_SPRALPHACTL_REG                                                                                                                                                                            |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                    |
| 31:24         | R/W            | UDF             | <b>SPR_GLBALPHA</b><br>Globe alpha value                                                                                                                                                                       |
| 23:1          | /              | /               | /                                                                                                                                                                                                              |
| 0             | R/W            | UDF             | <b>SPR_GLBALPHAEN</b><br>0:<br>Disable the globe alpha function<br>1:<br>Enable the globe alpha function, when the function is set, the sprite will use the globe alpha value to calculate the display pixels. |

### 5.4.4.23. DE-SPRITE SINGLE BLOCK COORDINATE CONTROL REGISTER

| Offset:         |                |                 | Register Name: DEBE_SPRCOORCTL_REG                                                                                                      |
|-----------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Block 0: 0xA00  | Block 1: 0xA04 | Block 2: 0xA08  | .                                                                                                                                       |
| .               | .              | .               | .                                                                                                                                       |
| Block 31: 0xA7C |                |                 |                                                                                                                                         |
| Bit             | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                             |
| 31:16           | R/W            | UDF             | <b>SPR_YCOOR</b><br>Y coordinate<br>Y is the left-top y coordinate of layer on screen in pixels<br>The Y represent the two's complement |
| 15:0            | R/W            | UDF             | <b>SPR_XCOOR</b><br>X coordinate<br>X is left-top x coordinate of the layer on screen in pixels<br>The X represent the two's complement |

Note: this register is used to set the single block (block 0----block 31) the coordinate (left-top) on screen control information

#### 5.4.4.24. DE-SPRITE SINGLE BLOCK ATTRIBUTE CONTROL REGISTER

| <b>Offset:</b><br><b>Block 0: 0xB00</b><br><b>Block 1: 0xB04</b><br><b>Block 2: 0xB08</b><br>.<br>.<br>.<br><b>Block 31: 0xB7C</b> |                |                 |                                                                                                   |
|------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|---------------------------------------------------------------------------------------------------|
| <b>Register Name: DEBE_SPRATTCTL_REG</b>                                                                                           |                |                 |                                                                                                   |
| Bit                                                                                                                                | Read/W<br>rite | Default/<br>Hex | Description                                                                                       |
| 31:20                                                                                                                              | R/W            | UDF             | <b>SPR_HEIGHT</b><br>Single block height<br>The real block height = The value of these bits add 1 |
| 19:8                                                                                                                               | R/W            | UDF             | <b>SPR_WIDTH</b><br>Single block width<br>The real block width = The value of these bits add 1    |
| 7:6                                                                                                                                | /              | /               | /                                                                                                 |
| 5:0                                                                                                                                | R/W            | UDF             | <b>SPR_NEXTID</b><br>The value determine the next block ID number from 0-31                       |

#### 5.4.4.25. DE-SPRITE SINGLE BLOCK ADDRESS SETTING SRAM ARRAY

| <b>Offset:</b><br><b>Block 0: 0xC00</b><br><b>Block 1: 0xC04</b><br><b>Block 2: 0xC08</b><br>.<br>.<br>.<br><b>Block 31: 0xC7C</b> |                |                 | <b>Register Name: DEBE_SPRADD_SRAM</b>                                        |
|------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|-------------------------------------------------------------------------------|
| Bit                                                                                                                                | Read/W<br>rite | Default/<br>Hex | Description                                                                   |
| 31:0                                                                                                                               | R/W            | UDF             | <b>SPR_ADD</b><br>Sprite start address<br>Sprite buffer start address in BYTE |

#### DE-SPRITE LINE WIDTH SETTING SRAM ARRAY

| <b>Offset:</b><br><b>Block 0: 0xD00</b><br><b>Block 1: 0xD04</b><br><b>Block 2: 0xD08</b><br>.<br>.<br>.<br><b>Block 31: 0xD7C</b> |                |                 | <b>Register Name: DEBE_SPRLINEWIDTH_SRAM</b>                                                     |
|------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|--------------------------------------------------------------------------------------------------|
| Bit                                                                                                                                | Read/W<br>rite | Default/H<br>ex | Description                                                                                      |
| 31:0                                                                                                                               | R/W            | UDF             | <b>SPR_LINEWIDTH</b><br>Sprite single block line width<br>Sprite single block line width in bits |

#### 5.4.4.26. DE BACKEND INPUT YUV CHANNEL CONTROL REGISTER

| <b>Offset: 0x920</b> |                |                 | <b>Register Name: DEBE_IYUVCTL_REG</b> |
|----------------------|----------------|-----------------|----------------------------------------|
| Bit                  | Read/W<br>rite | Default/<br>Hex | Description                            |

| Offset: 0x920 |                |                 | Register Name: DEBE_IYUVCTL_REG                                                                                                                                                                                                                                                                                                                              |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                  |
| 31:15         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                            |
| 14:12         | R/W            | UDF             | <b>IYUV_FBFMT</b><br>Input data format<br>000: planar YUV 411<br>001: planar YUV 422<br>010: planar YUV 444<br>011: interleaved YUV 422<br>100: interleaved YUV 444<br>Other: illegal                                                                                                                                                                        |
| 11:10         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                            |
| 9:8           | R/W            | UDF             | <b>IYUV_FBPS</b><br>Pixel sequence<br><b>In planar data format mode:</b><br>00: Y3Y2Y1Y0<br>01: Y0Y1Y2Y3 (the other 2 components are same)<br>Other: illegal<br><b>In interleaved YUV 422 data format mode:</b><br>00: UYVY<br>01: YUYV<br>10: VYUY<br>11: YYVU<br><b>In interleaved YUV 444 data format mode:</b><br>00: AYUV<br>01: VUYA<br>Other: illegal |
| 7:5           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                            |
| 4             | R/W            | UDF             | <b>IYUV_LINNEREN</b><br>0:<br>linner<br>1:                                                                                                                                                                                                                                                                                                                   |
| 3:1           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                            |
| 0             | R/W            | UDF             | <b>IYUV_EN</b><br>YUV channel enable control<br>0: disable                                                                                                                                                                                                                                                                                                   |

| Offset: 0x920 |                |                 | Register Name: DEBE_IYUVCTL_REG |
|---------------|----------------|-----------------|---------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                     |
|               |                |                 | 1: enable                       |

#### 5.4.4.27. SOURCE DATA INPUT DATA PORTS

| Input buffer channel | Planar YUV | Interleaved YUV |
|----------------------|------------|-----------------|
| Channel0             | Y          | YUV             |
| Channel1             | U          | -               |
| Channel2             | V          | -               |

#### 5.4.4.28. DE BACKEND YUV CHANNEL FRAME BUFFER ADDRESS REGISTER

| Offset:<br><br>Channel 0 : 0x930<br>Channel 1 : 0x934<br>Channel 2 : 0x938 |                |                 | Register Name: DEBE_IYUVADD_REG                            |
|----------------------------------------------------------------------------|----------------|-----------------|------------------------------------------------------------|
| Bit                                                                        | Read/W<br>rite | Default/<br>Hex | Description                                                |
| 31:0                                                                       | R/W            | UDF             | IYUV_ADD<br>Buffer Address<br>Frame buffer address in BYTE |

#### 5.4.4.29. DE BACKEND 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 |
|----------------------------------------------------------------------------|---------------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                                               |
|------------|------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | R/W                    | UDF                     | <p><b>IYUV_LINEWIDTH</b><br/>         Line width<br/>         The width is the distance from the start of one line to the start of the next line.</p> <p>Description in bits</p> |

YUV to RGB conversion algorithm formula:

$R =$   
 $(R \text{ Y component coefficient} * Y) +$   
 $(R \text{ U component coefficient} * U) +$   
 $(R \text{ V component coefficient} * V) +$   
 $R \text{ constant}$

$G =$   
 $(G \text{ Y component coefficient} * Y) +$   
 $(G \text{ U component coefficient} * U) +$   
 $(G \text{ V component coefficient} * V) +$   
 $G \text{ constant}$

$B =$   
 $(B \text{ Y component coefficient} * Y) +$   
 $(B \text{ U component coefficient} * U) +$   
 $(B \text{ V component coefficient} * V) +$   
 $B \text{ constant}$

#### 5.4.4.30. DE BACKEND Y/G COEFFICIENT REGISTER

| <b>Offset:</b><br><b>G/Y component: 0x950</b><br><b>R/U component: 0x954</b><br><b>B/V component: 0x958</b> |                        |                         | <b>Register Name: DEBE_YGCOEF_REG</b>                                                                                                    |
|-------------------------------------------------------------------------------------------------------------|------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>                                                                                                  | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                       |
| 31:29                                                                                                       | /                      | /                       | /                                                                                                                                        |
| 28:16                                                                                                       | R/W                    | UDF                     | <p><b>DF_YGCOEF</b><br/>         the Y/G coefficient for de-flicker<br/>         the value equals to coefficient*<math>2^{10}</math></p> |

| <b>Offset:</b><br><b>G/Y component: 0x950</b><br><b>R/U component: 0x954</b><br><b>B/V component: 0x958</b> |                |                 | <b>Register Name: DEBE_YGCOEF_REG</b>                                                  |
|-------------------------------------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------------------|
| Bit                                                                                                         | Read/W<br>rite | Default/<br>Hex | Description                                                                            |
| 15:13                                                                                                       | /              | /               | /                                                                                      |
| 12:0                                                                                                        | R/W            | UDF             | <b>IYUV_YGCOEF</b><br>the Y/G coefficient<br>the value equals to coefficient* $2^{10}$ |

#### 5.4.4.31. DE BACKEND Y/G CONSTANT REGISTER

| <b>Offset: 0x95C</b> |                |                 | <b>Register Name: DEBE_YGCONS_REG</b>                                                         |
|----------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------|
| Bit                  | Read/W<br>rite | Default/<br>Hex | Description                                                                                   |
| 31:30                | /              | /               | /                                                                                             |
| 29:16                | R/W            | UDF             | <b>DF_YGCONS</b><br>the Y/G constant for de-flicker<br>the value equals to coefficient* $2^4$ |
| 15:14                | /              | /               | /                                                                                             |
| 13:0                 | R/W            | UDF             | <b>IYUV_YGCONS</b><br>the Y/G constant<br>the value equals to coefficient* $2^4$              |

#### 5.4.4.32. DE BACKEND U/R COEFFICIENT REGISTER

| <b>Offset:</b><br><b>G/Y component: 0x960</b><br><b>R/U component: 0x964</b><br><b>B/V component: 0x968</b> |                |                 | <b>Register Name: DEBE_URCOEF_REG</b> |
|-------------------------------------------------------------------------------------------------------------|----------------|-----------------|---------------------------------------|
| Bit                                                                                                         | Read/<br>Write | Default/He<br>x | Description                           |
| 31:29                                                                                                       | /              | /               | /                                     |

| <b>Offset:</b><br><b>G/Y component: 0x960</b><br><b>R/U component: 0x964</b><br><b>B/V component: 0x968</b> |                |                 | <b>Register Name: DEBE_URCOEF_REG</b>                                                               |
|-------------------------------------------------------------------------------------------------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------|
| Bit                                                                                                         | Read/<br>Write | Default/He<br>x | Description                                                                                         |
| 28:16                                                                                                       | R/W            | UDF             | <b>DF_URCOEF</b><br>the U/R coefficient for de-flicker<br>the value equals to coefficient* $2^{10}$ |
| 15:13                                                                                                       | /              | /               | /                                                                                                   |
| 12:0                                                                                                        | R/W            | UDF             | <b>IYUV_URCOEF</b><br>the U/R coefficient<br>the value equals to coefficient* $2^{10}$              |

#### 5.4.4.33. DE BACKEND U/R CONSTANT REGISTER

| <b>Offset: 0x96C</b> |                |                 | <b>Register Name: DEBE_URCONS_REG</b>                                                         |
|----------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------|
| Bit                  | Read/W<br>rite | Default/<br>Hex | Description                                                                                   |
| 31:30                | /              | /               | /                                                                                             |
| 29:16                | R/W            | UDF             | <b>DF_URCONS</b><br>the U/R constant for de-flicker<br>the value equals to coefficient* $2^4$ |
| 15:14                | /              | /               | /                                                                                             |
| 13:0                 | R/W            | UDF             | <b>IYUV_URCONS</b><br>the U/R constant<br>the value equals to coefficient* $2^4$              |

#### 5.4.4.34. DE BACKEND V/B COEFFICIENT REGISTER

|                                                                                                             |                                       |
|-------------------------------------------------------------------------------------------------------------|---------------------------------------|
| <b>Offset:</b><br><b>G/Y component: 0x970</b><br><b>R/U component: 0x974</b><br><b>B/V component: 0x978</b> | <b>Register Name: DEBE_VBCOEF_REG</b> |
|-------------------------------------------------------------------------------------------------------------|---------------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                  |
|------------|------------------------|-------------------------|-----------------------------------------------------------------------------------------------------|
| 31:29      | /                      | /                       | /                                                                                                   |
| 28:16      | R/W                    | UDF                     | <b>DF_VBCOEF</b><br>the V/B coefficient for de-flicker<br>the value equals to coefficient* $2^{10}$ |
| 15:13      | /                      | /                       | /                                                                                                   |
| 12:0       | R/W                    | UDF                     | <b>IYUV_VBCOEF</b><br>the V/B coefficient<br>the value equals to coefficient* $2^{10}$              |

#### 5.4.4.35. DE BACKEND V/B CONSTANT REGISTER

| <b>Offset: 0x97C</b> |                        |                         | <b>Register Name: DEBE_VBCONS_REG</b>                                                         |
|----------------------|------------------------|-------------------------|-----------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                            |
| 31:30                | /                      | /                       | /                                                                                             |
| 29:16                | R/W                    | UDF                     | <b>DF_VBCONS</b><br>the V/B constant for de-flicker<br>the value equals to coefficient* $2^4$ |
| 15:14                | /                      | /                       | /                                                                                             |
| 13:0                 | R/W                    | UDF                     | <b>IYUV_VBCONS</b><br>the V/B constant<br>the value equals to coefficient* $2^4$              |

#### 5.4.4.36. DE BACKEND KEYSTONE CORRECTION CONTROL REGISTER

| <b>Offset: 0x980</b> |                        |                         | <b>Register Name: DEBE_KSCTL_REG</b>    |
|----------------------|------------------------|-------------------------|-----------------------------------------|
| <b>Bit</b>           | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                      |
| 31:1                 | /                      | /                       | /                                       |
| 0                    | R/W                    | UDF                     | <b>KS_EN</b><br>0: disable<br>1: enable |

#### 5.4.4.37. DE BACKEND KEYSTONE BACK COLOR CONTROL REGISTER

| Offset: 0x984 |                |                 | Register Name: DEBE_KSBKCOLOR_REG                                 |
|---------------|----------------|-----------------|-------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                       |
| 31:24         | /              | /               | /                                                                 |
| 23:16         | R/W            | UDF             | <b>KS_BKRED</b><br>Red<br>Red screen background color value       |
| 15:8          | R/W            | UDF             | <b>KS_BKGREEN</b><br>Green<br>Green screen background color value |
| 7:0           | R/W            | UDF             | <b>KS_BKBLUE</b><br>Blue<br>Blue screen background color value    |

#### 5.4.4.38. DE BACKEND KEYSTONE OUTPUT FIRST LINE WIDTH SETTING REGISTER

| Offset: 0x988 |                |                 | Register Name: DEBE_KSFSTLINEWIDTH_REG                                                                   |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                              |
| 31:11         | /              | /               | /                                                                                                        |
| 10:0          | R/W            | UDF             | <b>KS_FSTLINEWIDTH</b><br>Output first line width in pixels<br>The width = The value of these bits add 1 |

#### 5.4.4.39. DE BACKEND KEYSTONE VERTICAL SCALING FACTOR REGISTER

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

| Offset: 0x98C |                |                 | Register Name: DEBE_KSVSCAFCT_REG                                         |
|---------------|----------------|-----------------|---------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                               |
| 31            | R/W            | UDF             | <b>KS_VSCASIGN</b><br>Sign bit<br>0:increasing<br>1:decreasing            |
| 30:24         | /              | /               | /                                                                         |
| 23:16         | R/W            | UDF             | <b>KS_VSCAIRATIO</b><br>The integer part of the vertical scaling ratio    |
| 15:12         | /              | /               | /                                                                         |
| 11:0          | R/W            | UDF             | <b>KS_VSCAFRATIO</b><br>The fractional part of the vertical scaling ratio |

#### 5.4.4.40. DE BACKEND KEYSTONE HORIZONTAL FILTERING COEFFICIENT RAM BLOCK

| Offset:<br>0x9A0 – 0x9BC |                |                 | Register Name: DEBE_KSHSCACOEF_RAM                                                              |
|--------------------------|----------------|-----------------|-------------------------------------------------------------------------------------------------|
| Bit                      | Read/W<br>rite | Default/<br>Hex | Description                                                                                     |
| 31:24                    | R/W            | UDF             | <b>KS_HSCATAP3COEF</b><br>Horizontal tap3 coefficient<br>The value equals to coefficient* $2^6$ |
| 23:16                    | R/W            | UDF             | <b>KS_HSCATAP2COEF</b><br>Horizontal tap2 coefficient<br>The value equals to coefficient* $2^6$ |
| 15:8                     | R/W            | UDF             | <b>KS_HSCATAP1COEF</b><br>Horizontal tap1 coefficient<br>The value equals to coefficient* $2^6$ |
| 7:0                      | R/W            | UDF             | <b>KS_HSCATAP0COEF</b><br>Horizontal tap0 coefficient<br>The value equals to coefficient* $2^6$ |

#### 5.4.4.41. DE BACKEND OUTPUT COLOR CONTROL REGISTER

| Offset: 0x9C0 |                |                 | Register Name: DEBE_OCCTL_REG                                                  |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
| 31:1          | /              | /               | /                                                                              |
| 0             | R/W            | UDF             | <b>OC_EN</b><br>Color control module enable control<br>0: disable<br>1: enable |

#### 5.4.4.42. COLOR CORRECTION CONVERSION ALGORITHM FORMULA:

```

R =
(R R component coefficient * R) +
(R G component coefficient * G) +
(R B component coefficient * B) +
R constant

G =
(G R component coefficient * R) +
(G G component coefficient * G) +
(G B component coefficient * B) +
G constant

B =
(B R component coefficient * R) +
(B G component coefficient * G) +
(B B component coefficient * B) +
B constant
  
```

#### 5.4.4.43. DE BACKEND OUTPUT COLOR R COEFFICIENT REGISTER

|                                                                                                       |                                        |
|-------------------------------------------------------------------------------------------------------|----------------------------------------|
| <b>Offset:</b><br><b>R component: 0x9D0</b><br><b>G component: 0x9D4</b><br><b>B component: 0x9D8</b> | <b>Register Name: DEBE_OCRCOEF_REG</b> |
|-------------------------------------------------------------------------------------------------------|----------------------------------------|

| Bit   | Read/W<br>rite | Default/<br>Hex | Description                                                                       |
|-------|----------------|-----------------|-----------------------------------------------------------------------------------|
| 31:14 | /              | /               | /                                                                                 |
| 13:0  | R/W            | UDF             | <b>OC_RCOEF</b><br>the R coefficient<br>the value equals to coefficient* $2^{10}$ |

#### 5.4.4.44. DE BACKEND OUTPUT COLOR R CONSTANT REGISTER

| Offset: 0x9DC |                |                 | Register Name: DEBE_OCRCONS_REG                                             |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                 |
| 31:15         | /              | /               | /                                                                           |
| 14:0          | R/W            | UDF             | <b>OC_RCONS</b><br>the R constant<br>the value equals to coefficient* $2^4$ |

#### 5.4.4.45. DE BACKEND OUTPUT COLOR G COEFFICIENT REGISTER

| Offset:<br><br>R component: 0x9E0<br>G component: 0x9E4<br>B component: 0x9E8 |                |                 | Register Name: DEBE_OCGCOEF_REG                                                   |
|-------------------------------------------------------------------------------|----------------|-----------------|-----------------------------------------------------------------------------------|
| Bit                                                                           | Read/W<br>rite | Default/<br>Hex | Description                                                                       |
| 31:14                                                                         | /              | /               | /                                                                                 |
| 13:0                                                                          | R/W            | UDF             | <b>OC_GCOEF</b><br>the G coefficient<br>the value equals to coefficient* $2^{10}$ |

#### 5.4.4.46. DE BACKEND OUTPUT COLOR G CONSTANT REGISTER

| Offset: 0x9EC |                |                 | Register Name: DEBE_OCGCONS_REG                                             |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                 |
| 31:15         | /              | /               | /                                                                           |
| 14:0          | R/W            | UDF             | <b>OC_GCONS</b><br>the G constant<br>the value equals to coefficient* $2^4$ |

#### 5.4.4.47. DE BACKEND OUTPUT COLOR B COEFFICIENT REGISTER

| Offset:<br><b>G/Y component: 0x9F0</b><br><b>R/U component: 0x9F4</b><br><b>B/V component: 0x9F8</b> | Register Name: DEBE_OCBCOEF_REG |                 |                                                                                   |
|------------------------------------------------------------------------------------------------------|---------------------------------|-----------------|-----------------------------------------------------------------------------------|
| Bit                                                                                                  | Read/W<br>rite                  | Default/<br>Hex | Description                                                                       |
| 31:14                                                                                                | /                               | /               | /                                                                                 |
| 13:0                                                                                                 | R/W                             | UDF             | <b>OC_BCOEF</b><br>the B coefficient<br>the value equals to coefficient* $2^{10}$ |

#### 5.4.4.48. DE BACKEND OUTPUT COLOR B CONSTANT REGISTER

| Offset: 0x9FC |                |                 | Register Name: DEBE_OCBCONS_REG                                             |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/H<br>ex | Description                                                                 |
| 31:15         | /              | /               | /                                                                           |
| 14:0          | R/W            | UDF             | <b>OC_BCONS</b><br>the B constant<br>the value equals to coefficient* $2^4$ |

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

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 |
| P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |     |     |     |     |     |     |     |     |

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 |    |    |    |    |    |    |    |    |
| P03 | P02 | P01 | P00 |     |     |     |     |    |    |    |    |    |    |    |    |

8bpp:

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| P3 |    |    |    |    |    |    |    | P2 |    |    |    |    |    |    |    |
| P1 |    |    |    |    |    |    |    | P0 |    |    |    |    |    |    |    |

| Offset:<br>0x4800-0x4BFF |                |                 | DE-HW cursor pattern memory block                                                                    |
|--------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------|
| Bit                      | Read/W<br>rite | Default/<br>Hex | Description                                                                                          |
| 31:0                     | R/W            | UDF             | Hardware cursor pixel pattern<br>Specify the color displayed for each of the hardware cursor pixels. |

#### 5.4.4.50. DE-HWC PALETTE TABLE

| Offset:<br><b>0x4C00-0x4FFF</b> |                        |                         | <b>DE-HW palette table</b> |
|---------------------------------|------------------------|-------------------------|----------------------------|
| <b>Bit</b>                      | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>         |
| 31:24                           | R/W                    | UDF                     | Alpha value                |
| 23:16                           | R/W                    | UDF                     | Red value                  |
| 15:8                            | R/W                    | UDF                     | Green value                |
| 7:0                             | 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.



#### 5.4.4.51. SPRITE PALETTE TABLE

| Offset:<br><b>0x4000-0x43FF</b> | <b>DE-sprite palette SRAM block</b> |
|---------------------------------|-------------------------------------|
|---------------------------------|-------------------------------------|

| <b>Bit</b> | <b>Read/W<br/>rite</b> | <b>Default/H<br/>ex</b> | <b>Description</b> |
|------------|------------------------|-------------------------|--------------------|
| 31:24      | R/W                    | UDF                     | Alpha value        |
| 23:16      | R/W                    | UDF                     | Red value          |
| 15:8       | R/W                    | UDF                     | Green value        |
| 7:0        | R/W                    | UDF                     | Blue value         |

In this mode, the sprite RAM array is used for palette lookup table, each pixel in the sprite 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.



#### 5.4.4.52. PALETTE MODE

| <b>Offset:</b><br><b>Pipe0:0x5000-0x53FF</b><br><b>Pipe1:0x5400-0x57FF</b> |                        |                         | <b>Pipe palette color table SRAM block</b> |
|----------------------------------------------------------------------------|------------------------|-------------------------|--------------------------------------------|
| <b>Bit</b>                                                                 | <b>Read/W<br/>rite</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                         |
| 31:24                                                                      | R/W                    | UDF                     | Alpha value                                |
| 23:16                                                                      | R/W                    | UDF                     | Red value                                  |
| 15:8                                                                       | R/W                    | UDF                     |                                            |

|                            |     |     |                                            |
|----------------------------|-----|-----|--------------------------------------------|
| <b>Offset:</b>             |     |     | <b>Pipe palette color table SRAM block</b> |
| <b>Pipe0:0x5000-0x53FF</b> |     |     |                                            |
| <b>Pipe1:0x5400-0x57FF</b> |     |     |                                            |
|                            |     |     | Green value                                |
| 7:0                        | 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.



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

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 |

|     |     |     |     |     |     |     |     |    |
|-----|-----|-----|-----|-----|-----|-----|-----|----|
| P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |    |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 08  | 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/W<br>rite | Default/H<br>ex | Description                                                                                                      |
| 31:0                     | R/W            | UDF             | Internal frame buffer pixel pattern<br>Specify the color displayed for each of the internal frame buffer pixels. |

#### 5.4.4.54. INTERNAL FRAME BUFFER MODE PALETTE TABLE

| Address:<br>Pipe0:0x5000-0x53FF<br>Pipe1:0x5400-0x57FF |                |                 | Pipe palette table |
|--------------------------------------------------------|----------------|-----------------|--------------------|
| Bit                                                    | Read/W<br>rite | Default/<br>Hex | Description        |
| 31:24                                                  | R/W            | UDF             | Alpha value        |
| 23:16                                                  | R/W            | UDF             | Red value          |
| 15:8                                                   | R/W            | UDF             | Green value        |
| 7:0                                                    | R/W            | UDF             | Blue value         |

The following figure shows the RAM array used for internal frame buffer mode and the corresponding colors output.



#### 5.4.4.55. GAMMA CORRECTION MODE

| Offset:<br><b>0x4400-0x47FF</b> |                |                 | DE-on chip SRAM block   |
|---------------------------------|----------------|-----------------|-------------------------|
| Bit                             | Read/W<br>rite | Default/H<br>ex | Description             |
| 31:24                           | R/W            | UDF             | Alpha channel intensity |
| 23:16                           | R/W            | UDF             | Red channel intensity   |
| 15:8                            | R/W            | UDF             | Green channel intensity |
| 7:0                             | 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

### 5.4.4.56. DISPLAY ENGINE MEMORY MAPPING

Base Address:  
BE0: 0x01e60000  
BE1: 0x01e40000

Offset:

|        |                     |
|--------|---------------------|
| 0x0000 | Reserved            |
| 0x07FF |                     |
| 0x0800 | Registers           |
| 0x0DFF |                     |
| 0x0E00 |                     |
| 0x3FFF | Reserved            |
| 0x4000 |                     |
| 0x43FF | Reserved            |
| 0x4400 |                     |
| 0x47FF | Gamma Table         |
| 0x4800 |                     |
| 0x4BFF | HWC Memory Block    |
| 0x4C00 |                     |
| 0x4FFF | HWC Palette Table   |
| 0x5000 |                     |
| 0x53FF | PIPE0 Palette Table |
| 0x5400 |                     |
| 0x57FF | PIPE1 Palette Table |
| 0x5800 |                     |
| 0xFFFF | Reserved            |

## 5.5. TV Encoder

### 5.5.1. Overview

- Support CVBS NTSC,PAL, 4-channel CVBS output
- Support YPbPr 1080p60,1080p50,720p60,720p50,576p,480p,576i,480i
- Support VGA up to 1920x1200@60Hz
- Plug auto detection in CVBS and YPbPr

### 5.5.2. TV Encoder Block Diagram



### 5.5.3. TV Encoder Register List

| Module Name | Base Address |
|-------------|--------------|
| TVE0        | 0x01C0a000   |
| TVE1        | 0x01c1b000   |

| Register Name | Offset | Description                                               |
|---------------|--------|-----------------------------------------------------------|
| TVE_000_REG   | 0x0000 | TV Encoder Enable Register                                |
| TVE_004_REG   | 0x0004 | TV Encoder Configuration Register                         |
| TVE_008_REG   | 0x0008 | TV Encoder DAC Register1                                  |
| TVE_00C_REG   | 0x000C | TV Encoder Notch and DAC Delay Register                   |
| TVE_010_REG   | 0x0010 | TV Encoder chroma frequency Register                      |
| TVE_014_REG   | 0x0014 | TV Encoder Front/Back Porch Register                      |
| TVE_018_REG   | 0x0018 | TV Encoder HD mode VSYNC Register                         |
| TVE_01C_REG   | 0x001C | TV Encoder Line Number Register                           |
| TVE_020_REG   | 0x0020 | TV Encoder Level Register                                 |
| TVE_024_REG   | 0x0024 | TV Encoder DAC Register2                                  |
| TVE_030_REG   | 0x0030 | TV Encoder Auto Detection Enable Register                 |
| TVE_034_REG   | 0x0034 | TV Encoder Auto Detection Interrupt Status Register       |
| TVE_038_REG   | 0x0038 | TV Encoder Auto Detection Status Register                 |
| TVE_03C_REG   | 0x003C | TV Encoder Auto Detection de-bounce Setting Register      |
| TVE_040_REG   | 0x0040 | TV Encoder CSC signed coefficient1 with 9bit fraction     |
| TVE_044_REG   | 0x0044 | TV Encoder CSC signed coefficient2 with 9bit fraction     |
| TVE_048_REG   | 0x0048 | TV Encoder CSC signed coefficient3 with 9bit fraction     |
| TVE_04C_REG   | 0x004C | TV Encoder CSC unsigned coefficient4(integer)             |
| TVE_100_REG   | 0x0100 | TV Encoder Color Burst Phase Reset Configuration Register |
| TVE_104_REG   | 0x0104 | TV Encoder VSYNC Number Register                          |
| TVE_108_REG   | 0x0108 | TV Encoder Notch Filter Frequency Register                |
| TVE_10C_REG   | 0x010C | TV Encoder Cb/Cr Level/Gain Register                      |
| TVE_110_REG   | 0x0110 | TV Encoder Tint and Color Burst Phase Register            |
| TVE_114_REG   | 0x0114 | TV Encoder Burst Width Register                           |

| Register Name | Offset | Description                                      |
|---------------|--------|--------------------------------------------------|
| TVE_118_REG   | 0x0118 | TV Encoder Cb/Cr Gain Register                   |
| TVE_11C_REG   | 0x011C | TV Encoder Sync and VBI Level Register           |
| TVE_120_REG   | 0x0120 | TV Encoder White Level Register                  |
| TVE_124_REG   | 0x0124 | TV Encoder Video Active Line Register            |
| TVE_128_REG   | 0x0128 | TV Encoder Video Chroma BW and CompGain Register |
| TVE_12C_REG   | 0x012C | TV Encoder Register                              |
| TVE_130_REG   | 0x0130 | TV Encoder Re-sync parameters Register           |
| TVE_134_REG   | 0x0134 | TV Encoder Slave Parameter Register              |
| TVE_138_REG   | 0x0138 | TV Encoder Configuration Register                |
| TVE_13C_REG   | 0x013C | TV Encoder Configuration Register                |

## 5.5.4. TV Encoder Register Description

### 5.5.4.1. TV ENCODER ENABLE REGISTER

| Offset: 0x000 |                |                 | Register Name: TVE_000_REG                                                                                                                    |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                   |
| 31            | R/W            | 0               | <b>Clock_Gate_Dis</b><br>0: enable<br>1: disable                                                                                              |
| 30:20         | R/W            | 0               | /                                                                                                                                             |
| 19:16         | R/W            | 0               | <b>DAC3_Map</b><br>0: disable<br>1: TV0_DOUT0<br>2: TV0_DOUT1<br>3: TV0_DOUT2<br>4: TV0_DOUT3<br>5: TV1_DOUT0<br>6: TV1_DOUT1<br>7: TV1_DOUT2 |

| Offset: 0x000 |                |                 | Register Name: TVE_000_REG                                                                                                                                    |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                   |
|               |                |                 | 8: TV1_DOUT3                                                                                                                                                  |
| 15:12         | R/W            | 0               | <b>DAC2_Map</b><br>1: TV0_DOUT0<br>2: TV0_DOUT1<br>3: TV0_DOUT2<br>4: TV0_DOUT3<br>5: TV1_DOUT0<br>6: TV1_DOUT1<br>7: TV1_DOUT2<br>8: TV1_DOUT3               |
| 11:8          | R/W            | 0               | <b>DAC1 map</b><br>0: disable<br>1: TV0_DOUT0<br>2: TV0_DOUT1<br>3: TV0_DOUT2<br>4: TV0_DOUT3<br>5: TV1_DOUT0<br>6: TV1_DOUT1<br>7: TV1_DOUT2<br>8: TV1_DOUT3 |
| 7:4           | R/W            | 0               | <b>DAC0 map</b><br>0: disable<br>1: TV0_DOUT0<br>2: TV0_DOUT1<br>3: TV0_DOUT2<br>4: TV0_DOUT3<br>5: TV1_DOUT0<br>6: TV1_DOUT1<br>7: TV1_DOUT2<br>8: TV1_DOUT3 |
| 3:1           | /              | /               | /                                                                                                                                                             |
| 0             | R/W            | 0               | <b>TVE_En</b><br>0: disable<br>1: enable<br>Note: Video Encoder enable, default disable, write 1 to take it out                                               |

| Offset: 0x000 |                |                 | Register Name: TVE_000_REG |
|---------------|----------------|-----------------|----------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                |
|               |                |                 | of the reset state         |

#### 5.5.4.2. TV ENCODER CONFIGURATION REGISTER

| Offset: 0x004 |                |                 | Register Name: TVE_004_REG                                                                                                                                    |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                   |
| 31:29         | /              | /               | /                                                                                                                                                             |
| 28:27         | R/W            | 0               | /                                                                                                                                                             |
| 26            | R/W            | 0               | <b>DAC_Control_Logic_Clock_Sel</b><br>0: Using 27M clock or 74.25M clock depend on CCU setting<br>1: Using 54M clock or 148.5M clock depend on CCU setting    |
| 25            | R/W            | 0               | <b>Core_Datapath_Logic_Clock_Sel</b><br>0: Using 27M clock or 74.25M clock depend on CCU setting<br>1: Using 54M clock or 148.5M clock depend on CCU setting  |
| 24            | R/W            | 0               | <b>Core_Control_Logic_Clock_Sel</b><br>0: Using 27M clock or 74.25M clock depend on CCU setting<br>1: Using 54M clock or 148.5M clock depend on CCU setting   |
| 23:21         | /              | /               | /                                                                                                                                                             |
| 20            | R/W            | 0               | <b>Cb_Cr_Seq_For_422_Mode</b><br>0: Cb first<br>1: Cr first                                                                                                   |
| 19            | R/W            | 0               | <b>Input_Chroma_Data_Sampling_Rate_Sel</b><br>0: 4:4:4<br>1: 4:2:2                                                                                            |
| 18            | R/W            | 0               | <b>YUV_RGB_Output_En</b><br>0: CVBS or/and Y/C<br>1: YUV (or RGB)<br>Note: only apply to SD interlace mode, when in progressive mode, output YPbPr (RGB) only |
| 17            | R/W            | 0               | <b>YC_En</b><br>0: Y/C is disable                                                                                                                             |

| Offset: 0x004 |                |                 | Register Name: TVE_004_REG                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|               |                |                 | <p>1: Y/C enable<br/>           Note: S-port Video enable Selection.<br/>           This bit selects whether the S-port(Y/C) video output is enabled or disabled.</p>                                                                                                                                                                                                                                            |
| 16            | R/W            | 1               | <p><b>CVBS_En</b><br/>           0 - Composite video is disabled, Only Y/C is enable<br/>           1 - Composite video is enabled., CVBS and Y/C enable<br/>           Note:Composite Video enable Selection<br/>           This bit selects whether the composite video output (CVBS) is enabled or disabled.</p>                                                                                              |
| 15:10         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9             | R/W            | 0               | <p><b>Color_Bar_Type</b><br/>           0: 75/7.5/75/7.5 (NTSC), 100/0/75/0(PAL)<br/>           1: 100/7.5/100/7.5(NTSC), 100/0/100/0(PAL)</p>                                                                                                                                                                                                                                                                   |
| 8             | R/W            | 0               | <p><b>Color_Bar_Mode</b><br/>           0: The Video Encoder input is coming from the Display Engineer<br/>           1: The Video Encoder input is coming from an internal standard color bar generator.<br/>           Note: 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.</p> |
| 7:5           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4             | R/W            | 0               | <p><b>Mode_1080i_1250Line_Sel</b><br/>           0: 1125 Line mode<br/>           1: 1250 Line mode</p>                                                                                                                                                                                                                                                                                                          |
| 3:0           | R/W            | 0               | <p><b>TVMode Select</b><br/>           0000: 480i<br/>           0001: 576i<br/>           0010: 480p<br/>           0011: 576p<br/>           01xx: Reserved<br/>           100x: Reserved<br/>           101x: 720p<br/>           110x: 1080i<br/>           111x: 1080p<br/>           note: changing this register value will cause some relative register</p>                                              |

| Offset: 0x004 |                |                 | Register Name: TVE_004_REG |
|---------------|----------------|-----------------|----------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                |
|               |                |                 | setting to relative value. |

#### 5.5.4.3. TV ENCODER DAC REGISTER1

| Offset: 0x008 |                |                 | Register Name: TVE_008_REG                                                                                          |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                         |
| 31:28         | R/W            | 0100            | <b>Low_Bias</b><br>500uA to 4mA                                                                                     |
| 27:25         | /              | /               | /                                                                                                                   |
| 24            | R/W            | 1               | <b>DAC_Clock_Invert</b><br>0: not invert<br>1: invert                                                               |
| 23:22         | /              | /               | /                                                                                                                   |
| 21:20         | R/W            | 10              | <b>DAC_Ref2_Connect3</b><br>00: 0.25<br>01: 0.3<br>10: 0.35<br>11: 0.4<br>Note: ref2 used to detect luma            |
| 19:18         | R/W            | 10              | <b>DAC_Ref1_Connect2</b><br>00: 0.6<br>01: 0.65<br>10: 0.7<br>11: 0.75<br>Note: ref1 used to detect chroma          |
| 17:16         | R/W            | 11              | <b>Internal_DAC_Mode_Sel</b><br>0: 175 ohms terminal mode<br>2: 75 ohms terminal mode<br>3: 37.5 ohms terminal mode |
| 15:13         | R/W            | 0               | <b>DAC3_Src_Sel</b><br>000: Composite<br>001: Luma                                                                  |

| Offset: 0x008 |                |                 | Register Name: TVE_008_REG                                                                                                                             |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                            |
|               |                |                 | 010: Chroma<br>011: Reserved<br>100: Y/Green<br>101: U/Pb/Blue<br>110: V/Pr/Red<br>111: Reserved                                                       |
| 12:10         | R/W            | 0               | <b>DAC2_Src_Sel</b><br>000: Composite<br>001: Luma<br>010: Chroma<br>011: Reserved<br>100: Y/Green<br>101: U/Pb/Blue<br>110: V/Pr/Red<br>111: Reserved |
| 9:7           | R/W            | 0               | <b>DAC1_Src_Sel</b><br>000: Composite<br>001: Luma<br>010: Chroma<br>011: Reserved<br>100: Y/Green<br>101: U/Pb/Blue<br>110: V/Pr/Red<br>111: Reserved |
| 6:4           | R/W            | 0               | <b>DAC0_Src_Sel</b><br>000: Composite<br>001: Luma<br>010: Chroma<br>011: Reserved<br>100: Y/Green<br>101: U/Pb/Blue<br>110: V/Pr/Red<br>111: Reserved |
| 3             | R/W            | 0               | <b>Internal_DAC3_En</b><br>0:disable                                                                                                                   |

| Offset: 0x008 |                |                 | Register Name: TVE_008_REG                       |
|---------------|----------------|-----------------|--------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                      |
|               |                |                 | 1:enable                                         |
| 2             | R/W            | 0               | <b>Internal_DAC2_En</b><br>0:disable<br>1:enable |
| 1             | R/W            | 0               | <b>Internal_DAC1_En</b><br>0:disable<br>1:enable |
| 0             | R/W            | 0               | <b>Internal_DAC0_En</b><br>0:disable<br>1:enable |

#### 5.5.4.4. TV ENCODER NOTCH AND DAC DELAY REGISTER

| Offset: 0x00C |                |                 | Register Name: TVE_00C_REG                                                                        |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                       |
|               |                |                 | <b>Chroma_Filter_Active_Valid</b><br>0: Disable<br>1: Enable                                      |
| 31            | R/W            | 0               |                                                                                                   |
| 30:25         | /              | /               | /                                                                                                 |
| 24            | R/W            | 0               | <b>HD_Mode_CB_Filter_Bypass</b><br>0: Bypass Enable<br>1: Bypass Disable                          |
| 23            | R/W            | 0-              | <b>HD_Mode_CR_Filter_Bypass</b><br>0: Bypass Enable<br>1: Bypass Disable                          |
| 22            | R/W            | 0               | <b>Chroma_Filter_1_444_En</b><br>0 : Chroma Filter 1 444 Disable<br>1: Chroma Filter 1 444 Enable |
| 21            | R/W            | 0               | <b>Chroma_HD_Mode_Filter_E</b><br>0 : Chroma HD Filter Disable<br>1: Chroma HD Filter Enable      |

| Offset: 0x00C |                |                 | Register Name: TVE_00C_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 20            | R/W            | 0               | <b>Chroma_Filter_Stage_1_Bypass</b><br>0 : Chroma Filter stage 1 Enable<br>1: Chroma Filter stage 1 bypass                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 19            | R/W            | 0               | <b>Chroma_Filter_Stage_2_Bypass</b><br>0 : Chroma Filter stage 2 Enable<br>1: Chroma Filter stage 2 bypass                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 18            | R/W            | 0               | <b>Chroma_Filter_Stage_3_Bypass</b><br>0 : Chroma Filter stage 3 Enable<br>1: Chroma Filter stage 3 bypass                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 17            | R/W            | 0               | <b>Luma_Filter_Bypass</b><br>0: Luma Filter Enable<br>1: Luma Filter bypass                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16            | R/W            | 1               | <b>Notch_En</b><br>0: The luma notch filter is bypassed<br>1: The luma notch filter is operating<br>Luma notch filter on/off selection<br>Note: This bit selects if the luma notch filter is operating or bypassed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:12         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:9          | R/W            | 4               | <b>DAC3_Delay</b><br>000: The DAC3 lags DAC0 by 4 encoder clock cycles<br>001: The DAC3 lags DAC0 by 3 encoder clock cycles<br>010: The DAC3 lags DAC0 by 2 encoder clock cycles<br>011: The DAC3 lags DAC0 by 1 encoder clock cycle<br>100: There is no delay between the DAC0 and DAC3 signals<br>001: The DAC0 lags DAC3 by 1 encoder clock cycle<br>010: The DAC0 lags DAC3 by 2 encoder clock cycles<br>011: The DAC0 lags DAC3 by 3 encoder clock cycles<br>DAC3 and DAC0 paths relative delays (default=4 stages)<br>Relative delay between DAC3 and DAC0 selection.<br>These bits select the relative delay between the DAC3 samples and DAC0 samples. The delay range from 4 encoder clock cycles of DAC3 lagging the DAC0 samples to 3 encoder clock cycles of DAC3 preceding the DAC0 samples. |
| 8:6           | R/W            | 4               | <b>DAC2_Delay</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x00C |                |                 | Register Name: TVE_00C_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               |                |                 | <p>000: The DAC2 lags DAC0 by 4 encoder clock cycles<br/>     001: The DAC2 lags DAC0 by 3 encoder clock cycles<br/>     010: The DAC2 lags DAC0 by 2 encoder clock cycles<br/>     011: The DAC2 lags DAC0 by 1 encoder clock cycle<br/>     100: There is no delay between the DAC0 and DAC2 signals<br/>     001: The DAC0 lags DAC2 by 1 encoder clock cycle<br/>     010: The DAC0 lags DAC2 by 2 encoder clock cycles<br/>     011: The DAC0 lags DAC2 by D encoder clock cycles<br/>     DAC2 and DAC0 paths relative delays (default=4 stages)<br/>     Relative delay between DAC2 and DAC0 selection.<br/>     These bits select the relative delay between the DAC2 samples and DAC0 samples. The delay range from 4 encoder clock cycles of DAC2 lagging the DAC0 samples to 3 encoder clock cycles of DAC2 preceding the DAC0 samples.</p>                          |
| 5:3           | R/W            | 4               | <p><b>DAC1_Delay</b><br/>     000: The DAC1 lags DAC0 by 4 encoder clock cycles<br/>     001: The DAC1 lags DAC0 by 3 encoder clock cycles<br/>     010: The DAC1 lags DAC0 by 2 encoder clock cycles<br/>     DAC1 and DAC0 paths relative delays (default=4 stages)<br/>     Relative delay between DAC1 and DAC0 selection.<br/>     These bits select the relative delay between the DAC1 samples and DAC0 samples. The delay range from 4 encoder clock cycles of DAC1 lagging the DAC0 samples to 3 encoder clock cycles of DAC1 preceding the DAC0 samples.</p> <p>011: The DAC1 lags DAC0 by 1 encoder clock cycle<br/>     100: There is no delay between the DAC1 and DAC0 signals<br/>     001: The DAC0 lags DAC1 by 1 encoder clock cycle<br/>     010: The DAC0 lags DAC1 by 2 encoder clock cycles<br/>     011: The DAC0 lags DAC1 by D encoder clock cycles</p> |
| 2:0           | R/W            | 4               | <p><b>YC_Delay</b><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 range 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.</p> <p>000: The Y lags C by 4 encoder clock cycles</p>                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Offset: 0x00C |                |                 | Register Name: TVE_00C_REG                                                                                                                                                                                                                                                                                                                 |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                |
|               |                |                 | 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 |

#### 5.5.4.5. TV ENCODER CHROMA FREQUENCY REGISTER

| Offset: 0x010 |                |                 | Register Name: TVE_010_REG                                                                                                                                                                                                                                                                                                                                   |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                  |
| 31:0          | R/W            | 21f07c1f        | <b>Chroma_Freq</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 |

#### 5.5.4.6. TV ENCODER FRONT/BACK PORCH REGISTER

| Offset: 0x014 |                |                 | Register Name: TVE_014_REG                                                                                                                                                                             |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | 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 ( <b>burst_width+breeze_way+17</b> ). 8 bit unsigned integer. Default value is 118<br>720p mode, is 260 |

| Offset: 0x014 |                |                 | Register Name: TVE_014_REG                                                                                                                                                                                       |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                      |
|               |                |                 | 1080i/p mode, is 192                                                                                                                                                                                             |
| 15:12         | /              | /               | /                                                                                                                                                                                                                |
| 11:0          | R/W            | 20              | <p><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<br/>in 1080i mode is 44</p> |

#### 5.5.4.7. TV ENCODER HD MODE VSYNC REGISTER

| Offset: 0x018 |                |                 | Register Name: TVE_018_REG               |
|---------------|----------------|-----------------|------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                              |
| 31:28         | /              | /               | /                                        |
| 27:16         | R/W            | 0               | Broad_Plus_Cycle_Number_In_HD_Mode_VSYNC |
| 15:12         | /              | /               | /                                        |
| 11:0          | R/W            | 16              | Front_Porch_Like_In_HD_Mode_VSYNC        |

#### 5.5.4.8. TV ENCODER LINE NUMBER REGISTER

| Offset: 0x01C |                |                 | Register Name: TVE_01C_REG                                                                                                                                                                                                                                                                                                     |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                    |
| 31:24         | /              | /               | /                                                                                                                                                                                                                                                                                                                              |
| 23:16         | R/W            | 16              | <p><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 greater than 7. When VSync5=B'1', FirstVideoLine is restricted to be greater than 9. Default value is 21.</p> |
| 15:11         | /              | /               | /                                                                                                                                                                                                                                                                                                                              |

| Offset: 0x01C |                |                 | Register Name: TVE_01C_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10:0          | R/W            | 20D             | <p><b>Num_Lines</b><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.</p> <p>For interlaced video: When NTSC, and FirstVideoLine is greater than 20, then NumLines is restricted to be greater than <math>2 * (\text{FirstVideoLine} + 18)</math>. When NTSC, and FirstVideoLine is not greater than 20, then NumLines is restricted to be greater than 77. When PAL, and FirstVideoLine is greater than 22, then NumLines is restricted to be greater than <math>2 * (\text{FirstVideoLine} + 18)</math>. When PAL, and FirstVideoLine is not greater than 22, then NumLines is restricted to be greater than 81.</p> <p>If NumLines is even, then it is restricted to be divisible by 4. If NumLines is odd, then it is restricted to be divisible by 4 with a remainder of 1.</p> |

#### 5.5.4.9. TV ENCODER LEVEL REGISTER

| Offset: 0x020 |                |                 | Register Name: TVE_020_REG                                                                                                                                                   |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                  |
| 31:26         | /              | /               | /                                                                                                                                                                            |
| 25:16         | R/W            | 0F0             | <p><b>Blank_Level</b><br/>           Specify the blank level setting for active lines. 10 bit unsigned integer. Allowed range 0 to 1023. Default value is hexF0(dec240).</p> |
| 15:10         | /              | /               | /                                                                                                                                                                            |
| 9:0           | R/W            | 11a             | <p><b>Black_Level</b><br/>           Specify the black level setting. 10 bit unsigned integer. Allowed range is 240?? to 1023. Default value is 282</p>                      |

#### 5.5.4.10. TV ENCODER DAC REGISTER2

| Offset: 0x024 |                |                 | Register Name: TVE_024_REG |
|---------------|----------------|-----------------|----------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                |

| Offset: 0x024 |                |                 | Register Name: TVE_024_REG                                                |
|---------------|----------------|-----------------|---------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                               |
| 31:29         | /              | /               | /                                                                         |
| 28:24         | R/W            | 0000            | <b>Internal_DAC3_Amplitude_Control</b><br>00000:smallest<br>11111:biggest |
| 23:21         | /              | /               | /                                                                         |
| 20:16         | R/W            | 0000            | <b>Internal_DAC2_Amplitude_Control</b><br>00000:smallest<br>11111:biggest |
| 15:13         | /              | /               | /                                                                         |
| 12:8          | R/W            | 0000            | <b>Internal_DAC1_Amplitude_Control</b><br>00000:smallest<br>11111:biggest |
| 7:5           | /              | /               | /                                                                         |
| 4:0           | R/W            | 0000            | <b>Internal_DAC0_Amplitude_Control</b><br>00000:smallest<br>11111:biggest |

#### 5.5.4.11. TV ENCODER AUTO DETECTION ENABLE REGISTER

| Offset: 0x030 |                |                 | Register Name: TVE_030_REG    |
|---------------|----------------|-----------------|-------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                   |
| 31:20         | /              | /               | /                             |
| 19            | R/W            | 0               | DAC3_Auto_Detect_Interrupt_En |
| 18            | R/W            | 0               | DAC2_Auto_Detect_Interrupt_En |
| 17            | R/W            | 0               | DAC1_Auto_Detect_Interrupt_En |
| 16            | R/W            | 0               | DAC0_Auto_Detect_Interrupt_En |
| 15:4          | /              | /               | /                             |
| 3             | R/W            | 0               | DAC3_Auto_Detect_Enable       |
| 2             | R/W            | 0               | DAC2_Auto_Detect_Enable       |
| 1             | R/W            | 0               | DAC1_Auto_Detect_Enable       |

| Offset: 0x030 |                |                 | Register Name: TVE_030_REG |
|---------------|----------------|-----------------|----------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                |
| 0             | R/W            | 0               | DAC0_Auto_Detect_Enable    |

#### 5.5.4.12. TV ENCODER AUTO DETECTION INTERRUPT STATUS REGISTER

| Offset: 0x034 |                |                 | Register Name: TVE_034_REG                                                                         |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                        |
| 31:4          | /              | /               | /                                                                                                  |
| 3             | R/W            | 0               | <b>DAC3_Auto_Detect_Interrupt_Active_Flag</b><br>write 1 to inactive DAC3 auto detection interrupt |
| 2             | R/W            | 0               | <b>DAC2_Auto_Detect_Interrupt_Active_Flag</b><br>write 1 to inactive DAC2 auto detection interrupt |
| 1             | R/W            | 0               | <b>DAC1_Auto_Detect_Interrupt_Active_Flag</b><br>write 1 to inactive DAC1 auto detection interrupt |
| 0             | R/W            | 0               | <b>DAC0_Auto_Detect_Interrupt_Active_Flag</b><br>write 1 to inactive DAC0 auto detection interrupt |

#### 5.5.4.13. TV ENCODER AUTO DETECTION STATUS REGISTER

| Offset: 0x038 |                |                 | Register Name: TVE_038_REG                                                                    |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                   |
| 31:26         | /              | /               | /                                                                                             |
| 25:24         | R/W            | 0               | <b>DAC3_Status</b><br>00: Unconnected<br>01: Connected<br>11: Short to ground<br>10: Reserved |
| 23:18         | /              | /               | /                                                                                             |
| 17:16         | R/W            | 0               | <b>DAC2_Status</b><br>00: Unconnected                                                         |

| Offset: 0x038 |                |                 | Register Name: TVE_038_REG                                                                    |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                   |
|               |                |                 | 01: Connected<br>11: Short to ground<br>10: Reserved                                          |
| 15:10         | /              | /               | /                                                                                             |
| 9:8           | R/W            | 0               | <b>DAC1_Status</b><br>00: Unconnected<br>01: Connected<br>11: Short to ground<br>10: Reserved |
| 7:2           | /              | /               | /                                                                                             |
| 1:0           | R/W            | 0               | <b>DAC0_Status</b><br>00: Unconnected<br>01: Connected<br>11: Short to ground<br>10: Reserved |

#### 5.5.4.14. TV ENCODER AUTO DETECTION DE-BOUNCE SETTING REGISTER

| Offset: 0x03C |                |                 | Register Name: TVE_03C_REG |
|---------------|----------------|-----------------|----------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                |
| 31:26         | /              | /               | /                          |
| 25:16         | R/W            | 0               | /                          |
| 15:12         | R/W            | 0               | DAC3_De_Bounce_Times       |
| 11:8          | R/W            | 0               | DAC2_De_Bounce_Times       |
| 7:4           | R/W            | 0               | DAC1_De_Bounce_Times       |
| 3:0           | R/W            | 0               | DAC0_De_Bounce_Times       |

#### 5.5.4.15. TV ENCODER CSC SIGNED COEFFICIENT1 WITH 9BIT FRACTION

| Offset: 0x040 | Register Name: TVE_040_REG |
|---------------|----------------------------|
|---------------|----------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                       |
|------------|------------------------|-------------------------|------------------------------------------|
| 31         | R/W                    | 0                       | <b>CSC_En</b><br>0: Disable<br>1: Enable |
| 30         | /                      | /                       | /                                        |
| 29:20      | R/W                    | 0                       | Coeff_Yr                                 |
| 19:10      | R/W                    | 0                       | Coeff_Yg                                 |
| 9:0        | R/W                    | 0                       | Coeff_Yb                                 |

#### 5.5.4.16. TV ENCODER CSC SIGNED COEFFICIENT2 WITH 9BIT FRACTION

| <b>Offset: 0x044</b> |                        |                         | <b>Register Name: TVE_044_REG</b> |
|----------------------|------------------------|-------------------------|-----------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                |
| 31:30                | /                      | /                       | /                                 |
| 29:20                | R/W                    | 0                       | Coeff_Ur                          |
| 19:10                | R/W                    | 0                       | <b>Coeff_Ug</b>                   |
| 9:0                  | R/W                    | 0                       | Coeff_Ub                          |

#### 5.5.4.17. TV ENCODER CSC SIGNED COEFFICIENT3 WITH 9BIT FRACTION

| <b>Offset: 0x048</b> |                        |                         | <b>Register Name: TVE_048_REG</b> |
|----------------------|------------------------|-------------------------|-----------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                |
| 31:30                | /                      | /                       | /                                 |
| 29:20                | R/W                    | 0                       | Coeff_Vr                          |
| 19:10                | R/W                    | 0                       | Coeff_Vg                          |
| 9:0                  | R/W                    | 0                       | Coeff_Vb                          |

#### 5.5.4.18. TV ENCODER CSC UNSIGNED COEFFICIENT4(INTEGER)

| Offset: 0x04C |                |                 | Register Name: TVE_04C_REG |
|---------------|----------------|-----------------|----------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                |
| 31:24         | /              | /               | /                          |
| 23:16         | R/W            | 0               | Coeff_Yc                   |
| 15:8          | R/W            | 0               | Coeff_Uc                   |
| 7:0           | R/W            | 0               | Coeff_Vc                   |

#### 5.5.4.19. TV ENCODER COLOR BURST PHASE RESET CONFIGURATION REGISTER

| Offset: 0x100 |                |                 | Register Name: TVE_100_REG                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/H<br>ex | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:2          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1:0           | R/W            | 1               | <p><b>Color_Phase_Reset</b></p> <p>Color burst phase period selection</p> <p>These bits select the number of fields or lines after which the color burst phase is reset to its initial value as specified by the ChromaPhase parameter, This parameter is application only for interlaced video.</p> <ul style="list-style-type: none"> <li>0 – 8 field</li> <li>1 – 4 field</li> <li>2 – 2 lines</li> <li>3 – only once</li> </ul> |

#### 5.5.4.20. TV ENCODER VSYNC NUMBER REGISTER

| Offset: 0x104 |                |                 | Register Name: TVE_104_REG                                         |
|---------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                        |
| 31:1          | /              | /               | /                                                                  |
| 0             | R/W            | 1               | <p><b>VSync5</b></p> <p>Number of equalization pulse selection</p> |

|  |  |                                                                                                                                                                                                |
|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | This bit selects whether the number of equalization pulses is 5 or 6. This parameter is applicable only for interlaced video<br>0 – 5 equalization pulse(default)<br>1 – 6 equalization pulses |
|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 5.5.4.21. TV ENCODER NOTCH FILTER FREQUENCY REGISTER

| Offset: 0x108 |                |                 | Register Name: TVE_108_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:3          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2:0           | R/W            | 2               | <p><b>Notch_Freq</b><br/> Luma notch filter center frequency selection<br/> These bits select the luma notch filter (which is a band-reject filter) center frequency. In two of the selections, the filter width affects also the selection of the center frequency.</p> <p>000: 1.1875<br/> 001: 1.1406<br/> 010: 1.0938 when notch_wide value is B'1' (this selection is proper for CCIR-NTSC), or 1.0000 when notch_wide value is B'0'<br/> 011: 0.9922. This selection is proper for NTSC with square pixels<br/> 100: 0.9531. This selection is proper for PAL with square pixel<br/> 101: 0.8359 when notch_wide value is B'1' (this selection is proper for CCIR-PAL), or 0.7734 when notch_wide value is B'0'<br/> 110: 0.7813<br/> 111: 0.7188<br/> Default value is B'010'.???</p> |

#### 5.5.4.22. TV ENCODER CB/CR LEVEL/GAIN REGISTER

| Offset: 0x10C |                |                 | Register Name: TVE_10C_REG                                                                    |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                   |
| 31:16         | /              | /               | /                                                                                             |
| 15:8          | R/W            | 0               | <p><b>Cr_Burst_Level</b><br/> Specify the amplitude of the Cr burst. 8 bit 2's complement</p> |

| Offset: 0x10C |                |                 | Register Name: TVE_10C_REG                                                                                                                        |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                       |
|               |                |                 | integer. Allowed range is (-127) to 127. Default value is 0.                                                                                      |
| 7:0           | R/W            | 3C              | <b>Cb_Burst_Level</b><br>Specify the amplitude of the Cb burst. 8 bit 2's complement integer. Allowed range is (-127) to 127. Default value is 60 |

#### 5.5.4.23. TV ENCODER TINT AND COLOR BURST PHASE REGISTER

| Offset: 0x110 |                |                 | Register Name: TVE_110_REG                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:24         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23:16         | R/W            | 0               | <b>Tint</b><br>Specify the tint adjustment of the chroma signal for CVBS and Y/C outputs. The adjustment is effected by setting the sub-carrier phase to the value of this parameter. 8.8 bit unsigned fraction. Units are cycles of the color burst frequency. Default value is 0.                                                                                                                         |
| 15:8          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7:0           | R/W            | 0               | <b>Chroma_Phase</b><br>Specify the color burst initial phase ( <i>ChromaPhase</i> ). 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 <b>H SYNC</b> and then reset to the same value at further <b>H SYNCs</b> as specified by the <i>CPhaseRset</i> bits of the <i>EncConfig5</i> parameter (see above) |

#### 5.5.4.24. TV ENCODER BURST WIDTH REGISTER

| Offset: 0x114 |                |                 | Register Name: TVE_114_REG                                                                                      |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                     |
| 31:24         | R/W            | 58              | <b>Back_Porch</b><br><b>Breezeway like in HD mode VSync</b><br>720p mode, is 220<br>2080i/p mode is 88(default) |

| Offset: 0x114 |                |                 | Register Name: TVE_114_REG                                                                                                                                                                                                                                                                                                                                                       |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                      |
| 23            | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                |
| 22:16         | R/W            | 16              | <p><b>Breezeway</b><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<br/>           In 1080i mode, is 44<br/>           In 1080p mode, is 44<br/>           In 720p mode, is 40</p>                                                                  |
| 15            | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                |
| 14:8          | R/W            | 44              | <p><b>Burst_Width</b><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.<br/>           In hd mode, ignored</p>                                                                                                                                                      |
| 7:0           | R/W            | 7E              | <p><b>HSync_Width</b><br/>           Specify the width of the horizontal sync pulse in encoder clock cycles. Min value is 16. Max value is (<i>FrontPorch + ActiveLine - BackPorch</i>). Default value is 126. The sum of <i>HSyncSize</i> and <i>BackPorch</i> is restricted to be divisible by 4.<br/>           In 720p mode, is 40<br/>           In 1080i/p mode, is 44</p> |

#### 5.5.4.25. TV ENCODER CB/CR GAIN REGISTER

| Offset: 0x118 |                |                 | Register Name: TVE_118_REG                                                                                     |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                    |
| 31:16         | /              | /               | /                                                                                                              |
| 15:8          | R/W            | 89              | <p><b>Cr_Gain</b><br/>           Specify the Cr color gain. 8 bit unsigned fraction. Default value is 139</p>  |
| 7:0           | R/W            | 89              | <p><b>Cb_Gain</b><br/>           Specify the Cb color gain. 8 bit unsigned fraction. Default value is 139.</p> |

#### 5.5.4.26. TV ENCODER SYNC AND VBI LEVEL REGISTER

| Offset: 0x11C |                |                 | Register Name: TVE_11C_REG                                                                                                                                                                           |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                          |
| 31:26         | /              | /               | /                                                                                                                                                                                                    |
| 25:16         | R/W            | 48              | <b>Sync_Level</b><br>Specify the sync pulse level setting. 8 bit unsigned integer. Allowed range is 0 to <i>ABlankLevel</i> -1 or <i>VBlankLevel</i> -1 (whichever is smaller). Default value is 72. |
| 15:10         | /              | /               | /                                                                                                                                                                                                    |
| 9:0           | R/W            | 128             | <b>VBlank_Level</b><br>Specify the blank level setting for non active lines. 10 bit unsigned integer. Allow range 0 to 1023. Default value is hex128(dec296)                                         |

#### 5.5.4.27. TV ENCODER WHITE LEVEL REGISTER

| Offset: 0x120 |                |                 | Register Name: TVE_120_REG                                                                                                                                                                                |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                               |
| 31:26         | /              | /               | /                                                                                                                                                                                                         |
| 25:16         | R/W            | 1e8             | <b>HD_Sync_Breezeway_Level</b><br>Specify the breezeway level setting. 10 bit unsigned integer. Allowed range is 0 to 1023. Default value is 1e8.                                                         |
| 15:10         | /              | /               | /                                                                                                                                                                                                         |
| 9:0           | R/W            | 320             | <b>White_Level</b><br>Specify the white level setting. 10 bit unsigned integer. Allowed range is <i>black_level</i> +1 or <i>vbi_blank_level</i> +1 (whichever is greater) to 1023. Default value is 800. |

#### 5.5.4.28. TV ENCODER VIDEO ACTIVE LINE REGISTER

|               |                            |
|---------------|----------------------------|
| Offset: 0x124 | Register Name: TVE_124_REG |
|---------------|----------------------------|

| <b>Bit</b> | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                                          |
|------------|------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | /                      | /                       | /                                                                                                                                                                           |
| 11:0       | R/W                    | 5A0                     | <b>Active_Line</b><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. |

#### 5.5.4.29. TV ENCODER VIDEO CHROMA BW AND COMPGAIN REGISTER

| <b>Offset: 0x128</b> |                        |                         | <b>Register Name: TVE_128_REG</b>                                                                                                                                                                                                                                  |
|----------------------|------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                                                                                                                                                                                                                                 |
| 31:18                | /                      | /                       | /                                                                                                                                                                                                                                                                  |
| 17:16                | R/W                    | 00                      | <b>Chroma_BW</b><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)     |
| 15:2                 | /                      | /                       | /                                                                                                                                                                                                                                                                  |
| 1:0                  | R/W                    | 0                       | <b>Comp_Ch_Gain</b><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'). |

#### 5.5.4.30. TV ENCODER REGISTER

| <b>Offset: 0x12C</b> |                        |                         | <b>Register Name: TVE_12C_REG</b>                       |
|----------------------|------------------------|-------------------------|---------------------------------------------------------|
| <b>Bit</b>           | <b>Read/<br/>Write</b> | <b>Default/<br/>Hex</b> | <b>Description</b>                                      |
| 31:9                 | /                      | /                       | /                                                       |
| 8                    | R/W                    | 0                       | <b>Notch_Width</b><br>Luma notch filter width selection |

| Offset: 0x12C |                |                 | Register Name: TVE_12C_REG                                                                            |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                           |
|               |                |                 | This bit selects the luma notch filter (which is a band-reject filter) width.<br>0: Narrow<br>1: Wide |
| 7:1           | /              | /               | /                                                                                                     |

  

| Offset: 0x130 |                |                 | Register Name: TVE_130_REG                                      |
|---------------|----------------|-----------------|-----------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                     |
| 31            | R/W            | 0               | Re_Sync_Field                                                   |
| 30            | R/W            | 0               | <b>Re_Sync_Dis</b><br>0 – Re-Sync Enable<br>1 – Re-Sync Disable |
| 29:27         | /              | /               | /                                                               |
| 26:16         | R/W            | 0               | Re_Sync_Line_Num                                                |
| 15:11         | /              | /               | /                                                               |
| 10:0          | R/W            | 0               | Re_Sync_Pixel_Num                                               |

#### 5.5.4.31. TV ENCODER RE-SYNC PARAMETERS REGISTER

| Offset: 0x130 |                |                 | Register Name: TVE_130_REG                                      |
|---------------|----------------|-----------------|-----------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                     |
| 31            | R/W            | 0               | Re_Sync_Field                                                   |
| 30            | R/W            | 0               | <b>Re_Sync_Dis</b><br>0 – Re-Sync Enable<br>1 – Re-Sync Disable |
| 29:27         | /              | /               | /                                                               |
| 26:16         | R/W            | 0               | Re_Sync_Line_Num                                                |
| 15:11         | /              | /               | /                                                               |
| 10:0          | R/W            | 0               | Re_Sync_Pixel_Num                                               |

#### 5.5.4.32. TV ENCODER SLAVE PARAMETER REGISTER

| Offset: 0x134 |                |                 | Register Name: TVE_134_REG |
|---------------|----------------|-----------------|----------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                |
| 31:9          | /              | /               | /                          |

| Offset: 0x134 |                |                 | Register Name: TVE_134_REG                                                                                                                                                                                                                                                                                                                                                    |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                   |
| 8             | R/W            | 0               | <p><b>Slave_Thresh</b><br/>           Horizontal line adjustment threshold selection<br/>           This bit selects whether the number of lines after which the Video Encoder starts the horizontal line length adjustment is slave mode is 0 or 30.<br/>           0 – Number of lines is 0<br/>           1 – Number of lines is 30<br/>           Default values is 0</p> |
| 7:1           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                             |
| 0             | R/W            | 0               | <p><b>Slave_Mode</b><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: Reserved</p>                                         |

#### 5.5.4.33. TV ENCODER CONFIGURATION REGISTER

| Offset: 0x138 |                |                 | Register Name: TVE_138_REG                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:9          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8             | R/W            | 0               | <p><b>Invert_Top</b><br/>           Field parity input signal (top_field) polarity selection.<br/>           This bit selects whether the top field is indicated by a high level of the field parity signal or by the low level. The bit is applicable both when the Video Encoder is the sync master and when the Video Encoder is the sync slave<br/>           0: Top field is indicated by low level<br/>           1: Top field is indicated by high level</p> |
| 7:1           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0             | R/W            | 0               | <p><b>UV_Order</b><br/>           This bit selects if the sample order at the chroma input to the Video Encoder is Cb first (i.e. Cb 0 Cr 0 Cb 1 Cr 1) or Cr first (i.e.</p>                                                                                                                                                                                                                                                                                        |

| Offset: 0x138 |                |                 | Register Name: TVE_138_REG                                                                                            |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                           |
|               |                |                 | Cr 0 Cb 0 Cr 1 Cb 1).<br>0: The chroma sample input order is Cb first<br>1: The chroma sample input order is Cr first |

#### 5.5.4.34. TV ENCODER CONFIGURATION REGISTER

| Offset: 0x13C |                |                 | Register Name: TVE_13C_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/<br>Write | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:27         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 26:24         | R/W            | 0               | <b>RGB_Sync</b><br>R, G and B signals sync embedding selection.<br>These bits specify whether the sync signal is added to each of the R, G and B components (B'1') or not (B'0'). Bit [26] specify if the R signal have embedded syncs, bit [25] specify if the G signal have embedded syncs and bit [24] specify if the B signal have embedded syncs. When comp_yuv is equal to B'1', these bits are N.A. and should be set to B'000'. When the value is different from B'000', RGBSetup should be set to B'1' |
| 23:17         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16            | R/W            | 0               | <b>RGB_Setup</b><br>“Set-up” enable for RGB outputs.<br>This bit specifies if the “set-up” implied value (black_level – blank_level) specified for the CVBS signal is used also for the RGB signals.<br>0: The “set-up” is not used, or N.A. i.e. comp_yuv is equal to B'1'.<br>1: The implied “set-up” is used for the RGB signals                                                                                                                                                                             |
| 15:1          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0             | R/W            | 0               | <b>Bypass_YClamp</b><br>Y input clamping selection<br>This bit selects whether the Video Encoder Y input is clamped to 64 to 940 or not. When not clamped the expected range is 0 to 1023. The U and V inputs are always clamped to the range 64 to 960.<br>0: The Video Encoder Y input is clamped<br>1: The Video Encoder Y input is not clamped                                                                                                                                                              |

For Allwinnertech Only

# Chapter 6 Interface

This section details the interfaces that provided in A20, mainly includes:

- SD3.0
- TWI
- SPI
- UART
- PS2
- IR
- USB OTG
- USB HOST
- DIGITAL AUDIO INTERFACE
- AC97
- EMAC
- GMAC
- TRANSPORT STREAM
- SMART CARD READER
- SATA HOST
- CAN
- KEYPAD

## 6.1. SD3.0

### 6.1.1. Overview

The SD3.0 controller can be configured as a Secure Digital Multimedia Card controller, which simultaneously supports Secure Digital memory (SD Memo), UHS-1 Card, Secure Digital I/O (SDIO), Multimedia Cards (MMC), eMMC Card and Consumer Electronics Advanced Transport Architecture (CE-ATA).

It features:

- Support industry-standard AMBA High-Performance Bus (AHB) and it is fully compliant with the AMBA Specification, Revision 2.0. Supports 32-bit Little Endian bus.
- Support AMBA AHB Slave mode
- Support Secure Digital memory protocol commands (up to SD3.0)
- Support Secure Digital I/O protocol commands
- Support Multimedia Card protocol commands (up to MMC4.3)
- Support CE-ATA digital protocol commands
- Support eMMC boot operation and alternative boot operation
- Support Command Completion signal and interrupt to host processor and Command Completion Signal disable feature
- Support one SD (Version1.0 to 3.0) or MMC (Version3.3 to 4.3) or CE-ATA device
- Support hardware CRC generation and error detection
- Support programmable baud rate
- 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 32x32-bit (128 bytes total) FIFO for data transfer
- Support 3.3 V IO pad

### 6.1.2. SD3.0 Timing Diagram

Please refer to related specifications:

- Physical Layer Specification Ver3.00 Final, 2009.04.16
- SDIO Specification Ver2.00
- Consumer Electronics Advanced Transport Architecture (CE-ATA – version 1.1)
- Multimedia Cards (MMC – version 4.2)
- JEDEC Standard – JESD84-44, Embedded Multimedia Card (eMMC) Card Product Standard

## 6.2. TWI

### 6.2.1. Overview

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

The TWI features:

- Support industry-standard AMBA Peripheral Bus (APB) and it is fully compliant with the AMBA Specification, Revision 2.0.
- Software-programmable for Slave or Master
- Support Repeated START signal
- Support multi-master systems
- Allow 10-bit addressing with 2-Wire bus
- Perform arbitration and clock synchronization
- Own address and General Call address detection
- Interrupt on address detection
- Support speed up to 400Kbits/s ('fast mode')
- Allow operation from a wide range of input clock frequencies

## 6.2.2. TWI Controller Timing Diagram

Data transferred are always in a unit of 8-bit (byte), followed by an acknowledge bit. The number of bytes that can be transmitted per transfer is unrestricted. Data is transferred in serial with the MSB first. Between each byte of data transfer, a receiver device will hold the clock line SCL low to force the transmitter into a wait state while waiting the response from microprocessor.

Data transfer with acknowledgement is obligatory. The clock line is driven by the master all the time, including the acknowledgement-related clock cycle, except for the SCL holding between each bytes. After sending each byte, the transmitter releases the SDA line to allow the receiver to pull down the SDA line and send an acknowledgement signal (or leave it high to send a “not acknowledge”) to the transmitter.

When a slave receiver doesn't acknowledge the slave address (unable to receive because of no resource available), the data line must be left high by the slave so that the master can then generate a STOP condition to abort the transfer. Slave receiver can also indicate not to want to send more data during a transfer by leave the acknowledgement signal high. And the master should generate the STOP condition to abort the transfer.

Following diagram provides an illustration the relation of SDA signal line and SCL signal line on the 2-Wire serial bus.



## 6.2.3. TWI Controller Register List

| Module Name | Base Address |
|-------------|--------------|
| TWI0        | 0x01C2AC00   |
| TWI1        | 0x01C2B000   |
| TWI2        | 0x01C2B400   |
| TWI3        | 0x01C2B800   |
| TWI4        | 0x01C2C000   |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>           |
|----------------------|---------------|------------------------------|
| 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    |

## 6.2.4. TWI Register Description

### 6.2.4.1. TWI SLAVE ADDRESS REGISTER

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

Note:

For 7-bit addressing:

SLA6 – SLA0 is the 7-bit address of the TWI when in slave mode. When the TWI receives this address after a START condition, it will generate an interrupt and enter slave mode. (SLA6 corresponds to the first bit received from the 2-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.

#### 6.2.4.2. TWI EXTEND ADDRESS REGISTER

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

#### 6.2.4.3. TWI DATA REGISTER

| Offset: 0x08 |            |         | Register Name: TWI_DATA                            |
|--------------|------------|---------|----------------------------------------------------|
| Bit          | Read/Write | Default | Description                                        |
| 31:8         | /          | /       | /                                                  |
| 7:0          | R/W        | 0       | TWI_DATA<br>Data byte for transmitting or received |

#### 6.2.4.4. TWI CONTROL REGISTER

| Offset: 0x0C |            |         | Register Name: TWI_CNTR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7            | R/W        | 0       | <p>INT_EN</p> <p>Interrupt Enable</p> <p>1'b0: The interrupt line always low</p> <p>1'b1: The interrupt line will go high when INT_FLAG is set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6            | R/W        | 0       | <p>BUS_EN</p> <p>2-Wire Bus Enable</p> <p>1'b0: The 2-Wire bus inputs ISDA/ISCL are ignored and the 2-Wire Controller will not respond to any address on the bus</p> <p>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.</p> <p>Notes: In master operation mode, this bit should be set to '1'</p>                                                                                                                                                                                                                                                                                             |
| 5            | R/W        | 0       | <p>M_STA</p> <p>Master Mode Start</p> <p>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 has been sent: writing a '0' to this bit has no effect.</p> |
| 4            | R/W        | 0       | <p>M_STP</p> <p>Master Mode Stop</p> <p>If M_STP is set to '1' in master mode, a STOP condition is transmitted on the 2-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 2-Wire bus. If both M_STA and M_STP bits are set, the TWI will first transmit the STOP condition (if in master mode) then transmit the START condition.</p> <p>The M_STP bit is cleared automatically: writing a '0' to this</p>                                                                                                                                                      |

| Offset: 0x0C |                   |                | <b>Register Name: TWI_CNTR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>   | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|              |                   |                | bit has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3            | R/W               | 0              | <p><b>INT_FLAG</b><br/>Interrupt Flag</p> <p>INT_FLAG is automatically set to '1' when any of 28 (out of the possible 29) states is entered (see 'STAT Register' below). The only state that does not set INT_FLAG is state F8h. If the INT_EN bit is set, the interrupt line goes high when IFLG is set to '1'. If the TWI is operating in slave mode, data transfer is suspended when INT_FLAG is set and the low period of the 2-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/>Assert Acknowledge</p> <p>When A_ACK is set to '1', an Acknowledge (low level on SDA) will be sent during the acknowledge clock pulse on the 2-Wire bus if:</p> <ul style="list-style-type: none"> <li>a. Either the whole of a matching 7-bit slave address or the first or the second byte of a matching 10-bit slave address has been received.</li> <li>b. The general call address has been received and the GCE bit in the ADDR register is set to '1'.</li> <li>c. A data byte has been received in master or slave mode.</li> </ul> <p>When A_ACK is '0', a Not Acknowledge (high level on SDA) will be sent when a data byte is received in master or slave mode.</p> <p>If A_ACK is cleared to '0' in slave transmitter mode, the byte in the DATA register is assumed to be the 'last byte'. After this byte has been transmitted, the TWI will enter state C8h then return to the idle state (status code F8h) when INT_FLAG is cleared.</p> <p>The TWI will not respond as a slave unless A_ACK is set.</p> |
| 1:0          | R/W               | 0              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 6.2.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>STA<br/>Status Information Byte</p> <p><b>Code Status</b></p> <ul style="list-style-type: none"> <li>0x00: Bus error</li> <li>0x08: START condition transmitted</li> <li>0x10: Repeated START condition transmitted</li> <li>0x18: Address + Write bit transmitted, ACK received</li> <li>0x20: Address + Write bit transmitted, ACK not received</li> <li>0x28: Data byte transmitted in master mode, ACK received</li> <li>0x30: Data byte transmitted in master mode, ACK not received</li> <li>0x38: Arbitration lost in address or data byte</li> <li>0x40: Address + Read bit transmitted, ACK received</li> <li>0x48: Address + Read bit transmitted, ACK not received</li> <li>0x50: Data byte received in master mode, ACK transmitted</li> <li>0x58: Data byte received in master mode, not ACK transmitted</li> <li>0x60: Slave address + Write bit received, ACK transmitted</li> <li>0x68: Arbitration lost in address as master, slave address + Write bit received, ACK transmitted</li> <li>0x70: General Call address received, ACK transmitted</li> <li>0x78: Arbitration lost in address as master, General Call address received, ACK transmitted</li> <li>0x80: Data byte received after slave address received, ACK transmitted</li> <li>0x88: Data byte received after slave address received, not ACK transmitted</li> <li>0x90: Data byte received after General Call received, ACK transmitted</li> <li>0x98: Data byte received after General Call received, not ACK transmitted</li> <li>0xA0: STOP or repeated START condition received in slave mode</li> <li>0xA8: Slave address + Read bit received, ACK transmitted</li> <li>0xB0: Arbitration lost in address as master, slave address + Read bit received, ACK transmitted</li> <li>0xB8: Data byte transmitted in slave mode, ACK received</li> <li>0xC0: Data byte transmitted in slave mode, ACK not received</li> </ul> |

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: TWI_STAT</b><br><b>Default Value: 0x0000_00F8</b>                                                                                                                                                                                                       |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                        |
|                     |                   |                | 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 |

#### 6.2.4.6. TWI CLOCK REGISTER

| <b>Offset: 0x14</b> |                   |                | <b>Register Name: TWI_CCR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:7                | /                 | /              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6:3                 | R/W               | 0              | CLK_M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2:0                 | R/W               | 0              | CLK_N<br>The 2-Wire bus is sampled by the TWI at the frequency defined by F0:<br>$F_{samp} = F_0 = F_{in} / 2^{CLK\_N}$<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>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}$ |

#### TWI SOFT RESET REGISTER

| <b>Offset: 0x18</b> |                   |                | <b>Register Name: TWI_SRST</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |

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

#### 6.2.4.7. TWI ENHANCE FEATURE REGISTER

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

#### 6.2.4.8. TWI LINE CONTROL REGISTER

| <b>Offset: 0x20</b> |                   |                | <b>Register Name: TWI_LCR</b><br><b>Default Value: 0x0000_003a</b>  |
|---------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:6                | /                 | /              | /                                                                   |
| 5                   | R                 | 1              | <b>SCL_STATE</b><br>Current state of TWI_SCL<br>0 – low<br>1 - high |
| 4                   | R                 | 1              | <b>SDA_STATE</b><br>Current state of TWI_SDA                        |

| <b>Offset: 0x20</b> |                   |                | <b>Register Name: TWI_LCR</b><br><b>Default Value: 0x0000_003a</b>                                                                                                                                            |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                            |
|                     |                   |                | 0 – low<br>1 - high                                                                                                                                                                                           |
| 3                   | R/W               | 1              | SCL_CTL<br>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              | SCL_CTL_EN<br>TWI_SCL line state control enable<br>When this bit is set, the state of TWI_SCL is control 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              | SDA_CTL<br>TWI_SDA line state control bit<br>When line control mode is enabled (bit[0] set), value of this bit decide the output level of TWI_SDA<br>0 – output low level<br>1 – output high level            |
| 0                   | R/W               | 0              | SDA_CTL_EN<br>TWI_SDA line state control enable<br>When this bit is set, the state of TWI_SDA is control by the value of bit[1].<br>0-disable TWI_SDA line control mode<br>1-enable TWI_SDA line control mode |

#### 6.2.4.9. TWI DVFS CONTROL REGISTER

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: TWI_DVFSCR</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                    |
| 31:2                | /                 | /              | /                                                                     |

| Offset: 0x24               |            |         | Register Name: TWI_DVFSCR                                                                                         |
|----------------------------|------------|---------|-------------------------------------------------------------------------------------------------------------------|
| Default Value: 0x0000_0000 |            |         |                                                                                                                   |
| Bit                        | Read/Write | Default | Description                                                                                                       |
| 2                          | R/W        | 0       | MS_PRIORITY<br>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<br>CPU Busy set                                                                                      |
| 0                          | R/W        | 0       | DVFC_BUSY_SET<br>DVFS Busy set                                                                                    |

Note: This register is only implemented in TWI0.

## 6.2.5. TWI Controller Special Requirement

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

### 6.2.5.2. TWI CONTROLLER OPERATION

There are four operation modes on the 2-Wire bus which dictates the communications method. They are 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 conditions 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 interrupt 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.

## 6.3. SPI

### 6.3.1. Overview

The SPI allows rapid data communication with fewer software interrupts. The SPI module contains one 64x8 receiver buffer (RXFIFO) and one 64x8 transmit buffer (TXFIFO). It can work at two modes: Master mode and Slave mode.

It features:

- Support industry-standard AMBA High-Performance Bus (AHB) and it is fully compliant with the AMBA Specification, Revision 2.0. Supports 32-bit Little Endian bus.
- Support AMBA AHB Slave mode
- Full-duplex synchronous serial interface
- Master/Slave configurable
- Four chip selects to support multiple peripherals for SPI0 and SPI1 has one chip select
- 8-bit wide by 64-entry FIFO for both transmit and receive data
- Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable
- Support dedicated DMA

### 6.3.2. SPI Timing Diagram

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

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

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

The POL defines the signal polarity when SPI\_SCLK is in idle state. The SPI\_SCLK is high level when POL is '1' and it is low level when POL is '0'. The PHA decides whether the leading edge of SPI\_SCLK is used for setup or sample data. The leading edge is used for setup data when PHA is '1' and for sample data when PHA is '0'. The four kind of 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   | Failing, Setup  | Rising, Sample  |





Phase 1  
SPI Phase 1 Timing Diagram

### 6.3.3. SPI Register List

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

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

| Register Name | Offset | Description                   |
|---------------|--------|-------------------------------|
| SPI_TC        | 0x24   | SPI Transmit Counter Register |
| SPI_FIFO_STA  | 0x28   | SPI FIFO Status register      |

### 6.3.4. SPI Register Description

#### 6.3.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       | <p>RDATa<br/>Receive Data</p> <p>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 is decrease by 2. In word accessing method, the four SPI bursts are returned and the RXFIFO depth is decreased by 4.</p> |

#### 6.3.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       | <p>TDATa<br/>Transmit Data</p>                          |

### 6.3.4.3. SPI CONTROL REGISTER

| Offset: 0x08 |            |         | Register Name: SPI_CTL<br>Default Value: 0x0012_001C                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:21        | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 20           | R/W        | 1       | <p><b>SDM</b><br/>         Master Sample Data Mode<br/>         1 - Normal Sample Mode<br/>         0 - Delay Sample Mode<br/>         In Normal Sample Mode, SPI master samples the data at the correct edge for each SPI mode;<br/>         In Delay Sample Mode, SPI master samples data at the edge that is half cycle delayed by the correct edge defined in respective SPI mode.</p>                                                  |
| 19           | R/W        | 0       | <p><b>SDC</b><br/>         Master Sample Data Control<br/>         Set this bit to '1' to make the internal read sample point with a delay of half cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK propagating between master and slave.<br/>         1 – delay internal read sample point<br/>         0 – normal operation, do not delay internal read sample point</p> |
| 18           | R/W        | 0       | <p><b>TP_EN</b><br/>         Transmit Pause Enable<br/>         In master mode, it is used to control transmit state machine to stop smart burst sending when RX FIFO is full.<br/>         1 – stop transmit data when RXFIFO full<br/>         0 – normal operation, ignore RXFIFO status</p>                                                                                                                                             |
| 17           | R/W        | 1       | <p><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</p>                                                                                                                                                                                                                 |
| 16           | R/W        | 0       | <p><b>SS_CTRL</b><br/>         SS Output Mode Select<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.</p>                                                                                                                                                           |

| Offset: 0x08 |            |         | Register Name: SPI_CTL<br>Default Value: 0x0012_001C                                                                                                                                                                                                                       |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                |
|              |            |         | 1 – manual output SS<br>0 – automatic output SS                                                                                                                                                                                                                            |
| 15           | R/W        | 0       | DHB<br>Discard Hash Burst<br>In master mode it controls whether discarding unused SPI bursts<br>0: Receiving all SPI bursts in BC period<br>1: Discard unused SPI bursts, only fetching the SPI bursts during dummy burst period. The bursts number is specified by WTC.   |
| 14           | R/W        | 0       | DDB<br>Dummy Burst Type<br>0: The bit value of dummy SPI burst is zero<br>1: The bit value of dummy SPI burst is one                                                                                                                                                       |
| 13:12        | R/W        | 0       | SS<br>SPI Chip Select<br>Select one of four external SPI Master/Slave Devices<br>00: SPI_SS0 will be asserted<br>01: SPI_SS1 will be asserted<br>10: SPI_SS2 will be asserted<br>11: SPI_SS3 will be asserted<br>Notes: This two bits can't be configured for SPI1 Engine. |
| 11           | R/W        | 0       | RPSM<br>Rapids mode select<br>Select rapids operation for high speed read.<br>0: normal read mode<br>1: rapids read mode                                                                                                                                                   |
| 10           | R/W        | 0       | XCH<br>Exchange Burst<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       | RF_RST<br>RXFIFO Reset<br>Write '1' to reset the control portion of the receiver FIFO and                                                                                                                                                                                  |

| Offset: 0x08 |            |         | Register Name: SPI_CTL<br>Default Value: 0x0012_001C                                                                                                                                 |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                          |
|              |            |         | treats the FIFO as empty.<br>It is 'self-clearing'. It is not necessary to clear this bit.                                                                                           |
| 8            | R/W        | 0       | TF_RST<br>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       | DMAMC<br>SPI DMA Mode Control<br>0: Normal DMA mode<br>1: Dedicate DMA mode                                                                                                          |
| 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                                                                                                                                                     |

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: SPI_CTL</b><br><b>Default Value: 0x0012_001C</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
|                     |                   |                | 0: Slave Mode<br>1: Master Mode                                    |
| 0                   | R/W               | 0              | EN<br>SPI Module Enable Control<br>0: Disable<br>1: Enable         |

#### 6.3.4.4. SPI INTERRUPT CONTROL REGISTER

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: SPI_INTCTL</b><br><b>Default Value: 0x0000_0000</b>                                                      |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                         |
| 31:18               | /                 | /              | /                                                                                                                          |
| 17                  | R/W               | 0              | SS_INT_EN<br>SSI Interrupt Enable<br>Chip Select Signal (SSx) from valid state to invalid state<br>0: Disable<br>1: Enable |
| 16                  | R/W               | 0              | TX_INT_EN<br>Transfer Completed Interrupt Enable<br>0: Disable<br>1: Enable                                                |
| 15                  | /                 | /              | /                                                                                                                          |
| 14                  | R/W               | 0              | TF_UR_INT_EN<br>TXFIFO under run Interrupt Enable<br>0: Disable<br>1: Enable                                               |
| 13                  | R/W               | 0              | TF_OF_INT_EN<br>TX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable                                               |
| 12                  | R/W               | 0              | TF_E34_INT_EN                                                                                                              |

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: SPI_INTCTL</b><br><b>Default Value: 0x0000_0000</b>                |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                   |
|                     |                   |                | TX FIFO 3/4 Empty Interrupt Enable<br>0: Disable<br>1: Enable                        |
| 11                  | R/W               | 0              | TF_E14_INT_EN<br>TX FIFO 1/4 Empty Interrupt Enable<br>0: Disable<br>1: Enable       |
| 10                  | R/W               | 0              | TF_FL_INT_EN<br>TX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable             |
| 9                   | R/W               | 0              | TF_HALF_EMP_INT_EN<br>TX FIFO Half Empty Interrupt Enable<br>0: Disable<br>1: Enable |
| 8                   | R/W               | 0              | TX_EMP_INT_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable           |
| 7                   | /                 | /              | /                                                                                    |
| 6                   | R/W               | 0              | RF_UR_INT_EN<br>RXFIFO under run Interrupt Enable<br>0: Disable<br>1: Enable         |
| 5                   | R/W               | 0              | RF_OF_INT_EN<br>RX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable         |
| 4                   | R/W               | 0              | RF_F34_INT_EN<br>RXFIFO 3/4 Full Interrupt Enable<br>0: Disable<br>1: Enable         |
| 3                   | R/W               | 0              | RF_F14_INT_EN<br>RX FIFO 1/4 Full Interrupt Enable                                   |

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: SPI_INTCTL</b><br><b>Default Value: 0x0000_0000</b>              |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                 |
|                     |                   |                | 0: Disable<br>1: Enable                                                            |
| 2                   | R/W               | 0              | RF_FU_INT_EN<br>RX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable           |
| 1                   | R/W               | 0              | RF_HALF_FU_INT_EN<br>RX FIFO Half Full Interrupt Enable<br>0: Disable<br>1: Enable |
| 0                   | R/W               | 0              | RF_RDY_INT_EN<br>RX FIFO Ready Interrupt Enable<br>0: Disable<br>1: Enable         |

#### 6.3.4.5. SPI INTERRUPT STATUS REGISTER

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: SPI_INT_STA</b><br><b>Default Value: 0x0000_1B00</b>                                                                              |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                  |
| 31                  | R                 | 0              | INT_CBF<br>Interrupt Clear Busy Flag<br>0: clear interrupt flag done<br>1: clear interrupt flag busy                                                |
| 30: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 |

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: SPI_INT_STA</b><br><b>Default Value: 0x0000_1B00</b>                                                                                                                                 |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                     |
|                     |                   |                | 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<br>TXFIFO Overflow<br>This bit is set when if the TXFIFO is overflow. Writing 1 to this bit clears it.<br>0: TXFIFO is not overflow<br>1: TXFIFO is overflowed                                      |
| 12                  | R/W               | 1              | TE34<br>TXFIFO 3/4 empty<br>This bit is set if the TXFIFO is more than 3/4 empty. Writing 1 to this bit clears it.                                                                                     |
| 11                  | R/W               | 1              | TE14<br>TXFIFO 1/4 empty<br>This bit is set if the TXFIFO is more than 1/4 empty. Writing 1 to this bit clears it.                                                                                     |
| 10                  | R/W               | 0              | TF<br>TXFIFO Full<br>This bit is set when if the TXFIFO is full . Writing 1 to this bit clears it.<br>0: TXFIFO is not Full<br>1: TXFIFO is Full                                                       |
| 9                   | R/W               | 1              | THE<br>TXFIFO Half empty<br>This bit is set if the TXFIFO is more than half empty. Writing 1 to this bit clears it.                                                                                    |

| Offset: 0x10 |            |         | Register Name: SPI_INT_STA<br>Default Value: 0x0000_1B00                                                                                                                   |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                |
|              |            |         | 0: TXFIFO holds more than half words<br>1: TXFIFO holds half or fewer words                                                                                                |
| 8            | R/W        | 1       | TE<br>TXFIFO Empty<br>This bit is set if the TXFIFO is empty. Writing 1 to this bit clears it.<br>0: TXFIFO contains one or more words.<br>1: TXFIFO is empty              |
| 7            | /          | /       | /                                                                                                                                                                          |
| 6            | R/W        | 0       | RU<br>RXFIFO Underrun<br>When set, this bit indicates that RXFIFO has underrun. Writing 1 to this bit clears it.                                                           |
| 5            | R/W        | 0       | RO<br>RXFIFO Overflow<br>When set, this bit indicates that RXFIFO has overflowed. Writing 1 to this bit clears it.<br>0: RXFIFO is available.<br>1: RXFIFO has overflowed. |
| 4            | R/W        | 0       | RF34<br>RXFIFO 3/4 Full<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                                |
| 3            | R/W        | 0       | RF14<br>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                                                             |

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: SPI_INT_STA</b><br><b>Default Value: 0x0000_1B00</b>                                                                                                                                                                                          |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                              |
|                     |                   |                | 1: Full                                                                                                                                                                                                                                                         |
| 1                   | R/W               | 0              | <p>RHF</p> <p>RXFIFO Half Full. This bit is set if the RXFIFO is half full (<math>\geq 4</math> words in RXFIFO) . Writing 1 to this bit clears it.</p> <p>0: Less than 4 words are stored in RXFIFO.</p> <p>1: Four or more words are available in RXFIFO.</p> |
| 0                   | R/W               | 0              | <p>RR</p> <p>RXFIFO Ready</p> <p>This bit is set any time there is one or more words stored in RXFIFO (<math>\geq 1</math> words) . Writing 1 to this bit clears it.</p> <p>0: No valid data in RXFIFO</p> <p>1: More than 1 word in RXFIFO</p>                 |

#### 6.3.4.6. SPI DMA CONTROL REGISTER

| <b>Offset: 0x14</b> |                   |                | <b>Register Name: SPI_DMACTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                              |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                 |
| 31:13               | /                 | /              | /                                                                                                                                                                                                  |
| 12                  | R/W               | 0              | <p>TF_EMP34_DMA</p> <p>TXFIFO3/4 Empty DMA Request Enable</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                   |
| 11                  | R/W               | 0              | <p>TF_EMP14_DMA</p> <p>TXFIFO 1/4 Empty DMA Request Enable</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                  |
| 10                  | R/W               | 0              | <p>TF_NF_DMA</p> <p>TXFIFO Not Full DMA Request Enable</p> <p>When enable, if more than one free room for burst, DMA request is asserted, else de-asserted.</p> <p>0: Disable</p> <p>1: Enable</p> |

| Offset: 0x14 |            |         | Register Name: SPI_DMACTL<br>Default Value: 0x0000_0000                                                                                                     |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                 |
| 9            | R/W        | 0       | TF_HE_DMA<br>TXFIFO Half Empty DMA Request Enable<br>0: Disable<br>1: Enable                                                                                |
| 8            | R/W        | 0       | TF_EMP_DMA<br>TXFIFO Empty DMA Request Enable<br>0: Disable<br>1: Enable                                                                                    |
| 7:5          | /          | /       | /                                                                                                                                                           |
| 4            | R/W        | 0       | RF_FU34_DMA<br>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       | RF_FU14_DMA<br>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       | RF_FU_DMA<br>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       | RF_HF_DMA<br>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       | RF_RDY_DMA<br>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 |

| <b>Offset: 0x14</b> |                   |                | <b>Register Name: SPI_DMACTL</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                    |
|                     |                   |                | 1: Enable                                                             |

#### 6.3.4.7. SPI WAIT CLOCK REGISTER

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

#### 6.3.4.8. SPI CLOCK CONTROL REGISTER

| <b>Offset: 0x1C</b> |                   |                | <b>Register Name: SPI_CCTL</b><br><b>Default Value: 0x0000_0002</b>                                                                                                                                                                                                                                                                                                                      |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                       |
| 31:13               | /                 | /              | /                                                                                                                                                                                                                                                                                                                                                                                        |
| 12                  | R/W               | 0              | <p>DRS<br/>Divide Rate Select (Master Mode Only)</p> <p>0: Select Clock Divide Rate 1<br/>1: Select Clock Divide Rate 2</p>                                                                                                                                                                                                                                                              |
| 11:8                | R/W               | 0              | <p>CDR1<br/>Clock Divide Rate 1 (Master Mode Only)</p> <p>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: <math>2^{(n+1)}</math>. The</p> |

| <b>Offset: 0x1C</b> |                   |                | <b>Register Name: SPI_CCTL</b><br><b>Default Value: 0x0000_0002</b>                                                                                        |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                         |
|                     |                   |                | SPI_SCLK is determined according to the following equation:<br>$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: $SPI\_CLK = AHB\_CLK / (2^{*(n + 1)})$ . |

#### 6.3.4.9. SPI BURST COUNTER REGISTER

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

#### 6.3.4.10. SPI TRANSMIT COUNTER REGISTER

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: SPI_TC</b><br><b>Default Value: 0x0000_0000</b>                                                                                 |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                |
| 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 |

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: SPI_TC</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                             |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                            |
|                     |                   |                | <p>dummy burst when SMC is 1. For saving bus bandwidth, the dummy burst (all zero bits or all one bits) is sent by SPI Controller automatically.</p> <p>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> |

#### 6.3.4.11. SPI FIFO STATUS REGISTER

| <b>Offset: 0x28</b> |                   |                | <b>Register Name: SPI_FIFO_STA</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                              |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                   |
| 31:25               | /                 | /              | /                                                                                                                                                                                                    |
| 22:16               | R                 | 0x0            | <p>TF_CNT<br/>TXFIFO Counter<br/>These bits indicate the number of words in TXFIFO<br/>0: 0 byte in TXFIFO<br/>1: 1 byte in TXFIFO<br/>...<br/>63: 63 bytes in TXFIFO<br/>64: 64 bytes in TXFIFO</p> |
| 15:7                | /                 | /              | /                                                                                                                                                                                                    |
| 6:0                 | R                 | 0x0            | <p>RF_CNT<br/>RXFIFO Counter<br/>These bits indicate the number of words in RXFIFO<br/>0: 0 byte in RXFIFO<br/>1: 1 byte in RXFIFO<br/>...<br/>63: 63 bytes in RXFIFO<br/>64: 64 bytes in RXFIFO</p> |

### 6.3.5. SPI Special Requirement

#### 6.3.5.1. SPI PIN LIST

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

| <b>Port Name</b> | <b>Width</b> | <b>Direction(M)</b> | <b>Direction(S)</b> | <b>Description</b>                        |
|------------------|--------------|---------------------|---------------------|-------------------------------------------|
| 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 for pin saving.

#### 6.3.5.2. SPI MODULE CLOCK SOURCE AND FREQUENCY

The SPI module uses two clock source: AHB\_CLK and SPI\_CLK. The SPI\_SCLK can in the range from 3Khz to 100 MHZ and  $\text{AHB\_CLK} \geq 2 \times \text{SPI\_SCLK}$ .

| <b>Clock Name</b> | <b>Description</b>                               | <b>Requirement</b>                               |
|-------------------|--------------------------------------------------|--------------------------------------------------|
| AHB_CLK           | AHB bus clock, as the clock source of SPI module | $\text{AHB\_CLK} \geq 2 \times \text{SPI\_SCLK}$ |
| SPI_CLK           | SPI serial input clock                           |                                                  |

## 6.4. UART

### 6.4.1. Overview

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

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

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

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

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

For integration in systems where Infrared SIR serial data format is required, the UART can be configured to have a software-programmable IrDA SIR Mode. If this mode is not selected, only the UART (RS232 standard) serial data format is available.

It features:

- Support industry-standard AMBA Peripheral Bus (APB) and it is fully compliant with the AMBA Specification, Revision 2.0
- Supports APB 16-bit bus width
- 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
- Support IrDa 1.0 SIR
- Interrupt support for FIFOs, Status Change

## 6.4.2. UART Timing Diagram



## 6.4.3. UART Register List

There are 8 UART controllers. UART1 has full modem control signals, including RTS, CTS, DTR, DSR, DCD and RING signal. UART2/3 has two data flow control singals, including RTS and CTS. Other UART controller has 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   |
| UART4       | 0x01C29000   |
| UART5       | 0x01C29400   |
| UART6       | 0x01C29800   |

| <b>Module Name</b> | <b>Base Address</b> |
|--------------------|---------------------|
| UART7              | 0x01C29C00          |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>               |
|----------------------|---------------|----------------------------------|
| 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            |

## 6.4.4. UART Register Description

### 6.4.4.1. UART RECEIVER BUFFER REGISTER

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

| <b>Offset: 0x00</b> |                   |                | <b>Register Name: UART_RBR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 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, then the data already in the FIFO is preserved, but any incoming data are lost and an overrun error occurs.</p> |

#### 6.4.4.2. UART TRANSMIT HOLDING REGISTER

| <b>Offset: 0x00</b> |                   |                | <b>Register Name: UART_THR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 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 in the write data being lost.</p> |

#### 6.4.4.3. UART DIVISOR LATCH LOW REGISTER

| Offset: 0x00 |            |         | Register Name: <b>UART_DLL</b><br>Default Value: <b>0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7:0          | R/W        | 0       | <p>DLL<br/>Divisor Latch Low</p> <p>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).</p> <p>The output baud rate is equal to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that 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.</p> |

#### 6.4.4.4. UART DIVISOR LATCH HIGH REGISTER

| Offset: 0x04 |            |         | Register Name: <b>UART_DLH</b><br>Default Value: <b>0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7:0          | R/W        | 0       | <p>DLH<br/>Divisor Latch High</p> <p>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).</p> <p>The output baud rate is equal to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that 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</p> |

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: UART_DLH</b><br><b>Default Value: 0x0000_0000</b>                                     |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                      |
|                     |                   |                | clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data. |

#### 6.4.4.5. UART INTERRUPT ENABLE REGISTER

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: UART_IER</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                 |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                  |
| 31:8                | /                 | /              | /                                                                                                                                                                                                   |
| 7                   | R/W               |                | <b>PTIME</b><br>Programmable THRE Interrupt Mode Enable<br>This is used to enable/disable the generation of THRE Interrupt.<br>0: Disable<br>1: Enable                                              |
| 6:4                 | /                 | /              | /                                                                                                                                                                                                   |
| 3                   | R/W               | 0              | <b>EDSSI</b><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              | <b>ELSI</b><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      |

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: UART_IER</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                 |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                  |
|                     |                   |                | 1: Enable                                                                                                                                                                                                                                                                                                                                           |
| 1                   | R/W               | 0              | <p><b>ETBEI</b><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.</p> <p>0: Disable<br/>           1: Enable</p>                                                          |
| 0                   | R/W               | 0              | <p><b>ERBFI</b><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.</p> <p>0: Disable<br/>           1: Enable</p> |

#### 6.4.4.6. UART INTERRUPT IDENTITY REGISTER

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: UART_IIR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                   |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                    |
| 31:8                | /                 | /              | /                                                                                                                                                                                     |
| 7:6                 | R                 | 0              | <p><b>FEFLAG</b><br/>           FIFOs Enable Flag<br/>           This is used to indicate whether the FIFOs are enabled or disabled.</p> <p>00: Disable<br/>           11: Enable</p> |
| 5:4                 | /                 | /              | /                                                                                                                                                                                     |
| 3:0                 | R                 | 0x1            | <p><b>IID</b><br/>           Interrupt ID<br/>           This indicates the highest priority pending interrupt which can be one of the following types:</p>                           |

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: UART_IIR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                          |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                           |
|                     |                   |                | <p>0000: modem status<br/>     0001: no interrupt pending<br/>     0010: THR empty<br/>     0100: received data available<br/>     0110: receiver line status<br/>     0111: busy detect<br/>     1100: character timeout</p> <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 1 character 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                                                      | Reading the Modem status Register                                                                                                                                                              |

| <b>Interrupt ID</b> | <b>Priority Level</b> | <b>Interrupt Type</b>  | <b>Interrupt Source</b>                                                                                                              | <b>Interrupt Reset</b>           |
|---------------------|-----------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
|                     |                       |                        | that if auto flow control mode is enabled, a change in CTS (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 |

#### 6.4.4.7. UART FIFO CONTROL REGISTER

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: UART_FCR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:8                | /                 | /              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:6                 | W                 | 0              | <p><b>RT</b><br/>RCVR Trigger</p> <p>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.</p> <p>00: 1 character in the FIFO<br/>01: FIFO ¼ full<br/>10: FIFO ½ full<br/>11: FIFO-2 less than full</p> |
| 5:4                 | W                 | 0              | <p><b>TFT</b><br/>TX Empty Trigger</p> <p>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.</p> <p>00: FIFO empty<br/>01: 2 characters in the FIFO</p>                                                                                 |

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: UART_FCR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                    |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                     |
|                     |                   |                | 10: FIFO ¼ full<br>11: FIFO ½ full                                                                                                                                                                                     |
| 3                   | 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              | RFIFOR<br>RCVR FIFO Reset<br>This resets the control portion of the receive FIFO and treats the FIFO as empty. This also de-asserts the DMA RX request. It is ‘self-clearing’. It is not necessary to clear this bit.  |
| 0                   | W                 | 0              | FIFOE<br>Enable FIFOs<br>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.                    |

#### 6.4.4.8. UART LINE CONTROL REGISTER

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: UART_LCR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                      |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                       |
| 31:8                | /                 | /              | /                                                                                                                                                                                                                                                                                        |
| 7                   | R/W               | 0              | DLAB<br>Divisor Latch Access Bit<br>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This bit is used to enable reading and writing of the Divisor Latch register (DLL and DLH) to set the baud rate of the UART. This bit must be cleared after initial |

| Offset: 0x0C |            |         | Register Name: UART_LCR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|              |            |         | baud rate setup in order to access other registers.<br>0: Select RX Buffer Register (RBR) / TX Holding Register(THR) and Interrupt Enable Register (IER)<br>1: Select Divisor Latch LS Register (DLL) and Divisor Latch MS Register (DLM)                                                                                                                                                                                                                                                                                          |
| 6            | R/W        | 0       | BC<br>Break Control Bit<br>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. |
| 5            | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4            | R/W        | 0       | EPS<br>Even Parity Select<br>It is writeable only when UART is not busy (USR[0] is zero) and always writable readable. This is used to select between even and odd parity, when parity is enabled (PEN set to one).<br>0: Odd Parity<br>1: Even Parity                                                                                                                                                                                                                                                                             |
| 3            | R/W        | 0       | PEN<br>Parity Enable<br>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This bit is used to enable and disable parity generation and detection in transmitted and received serial character respectively.<br>0: parity disabled<br>1: parity enabled                                                                                                                                                                                                                                              |
| 2            | R/W        | 0       | STOP<br>Number of stop bits<br>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This is used to select the number of stop bits per character that the peripheral transmits and receives. If 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                                                                                                 |

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: UART_LCR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                 |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  |
|                     |                   |                | <p>transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.</p> <p>0: 1 stop bit</p> <p>1: 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit</p>                                                                                                                                                |
| 1:0                 | R/W               | 0              | <p>DLS</p> <p>Data Length Select</p> <p>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This is used to select the number of data bits per character that the peripheral transmits and receives. The number of bit that may be selected areas follows:</p> <p>00: 5 bits</p> <p>01: 6 bits</p> <p>10: 7 bits</p> <p>11: 8 bits</p> |

#### 6.4.4.9. UART MODEM CONTROL REGISTER

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: UART_MCR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                      |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                       |
| 31:7                | /                 | /              | /                                                                                                                                                                                                                                                        |
| 6                   | R/W               | 0              | <p>SIRE</p> <p>SIR Mode Enable</p> <p>0: IrDA SIR Mode disabled</p> <p>1: IrDA SIR Mode enabled</p>                                                                                                                                                      |
| 5                   | R/W               | 0              | <p>AFCE</p> <p>Auto Flow Control Enable</p> <p>When FIFOs are enabled and the Auto Flow Control Enable (AFCE) bit is set, Auto Flow Control features are enabled.</p> <p>0: Auto Flow Control Mode disabled</p> <p>1: Auto Flow Control Mode enabled</p> |
| 4                   | R/W               | 0              | /                                                                                                                                                                                                                                                        |
| 3:2                 | /                 | /              | /                                                                                                                                                                                                                                                        |
| 1                   | R/W               | 0              | RTS                                                                                                                                                                                                                                                      |

| Offset: 0x10 |            |         | Register Name: UART_MCR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              |            |         | <p>Request to Send</p> <p>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.</p> <p>0: rts_n de-asserted (logic 1)<br/>1: rts_n asserted (logic 0)</p> <p>Note that in Loopback mode (MCR[4] set to one), the rts_n output is held inactive high while the value of this location is internally looped back to an input.</p> |
| 0            | R/W        | 0       | <p>DTR</p> <p>Data Terminal Ready</p> <p>This is used to directly control the Data Terminal Ready (dtr_n) output. The value written to this location is inverted and driven out on dtr_n.</p> <p>0:dtr_n de-asserted (logic 1)<br/>1:dtr_n asserted (logic 0)</p> <p>The Data Terminal Ready output is used to inform the modem or data set that the UART is ready to establish communications.</p> <p>Note that in Loopback mode (MCR[4] 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>                                                                                                                                                                                                                                                                                                                                                                   |

#### 6.4.4.10. UART LINE STATUS REGISTER

| Offset: 0x14 |            |         | Register Name: UART_LSR<br>Default Value: 0x0000_0060 |
|--------------|------------|---------|-------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                           |

| Offset: 0x14 |            |         | Register Name: UART_LSR<br>Default Value: 0x0000_0060                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7            | R          | 0       | <p>FIFOERR<br/>RX Data Error in FIFO</p> <p>When FIFOs are disabled, this bit is always 0. When FIFOs are enabled, this bit is set to 1 when there is at least one PE, FE, or BI in the RX FIFO. It is cleared by a read from the LSR register provided there are no subsequent errors in the FIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6            | R          | 1       | <p>TEMT<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>THRE<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>BI<br/>Break Interrupt</p> <p>This is used to indicate the detection of a break sequence on the serial input data.</p> <p>If in UART mode (SIR_MODE == Disabled), it is set whenever the serial input, sin, is held in a logic '0' state for longer than the sum of <i>start time + data bits + parity + stop bits</i>.</p> <p>If in infrared mode (SIR_MODE == Enabled), it is set whenever the serial input, sir_in, is continuously pulsed to logic '0' for longer than the sum of <i>start time + data bits + parity + stop bits</i>. A break condition on serial input causes one and only one character, consisting of all zeros, to be received by the UART.</p> <p>In the FIFO mode, the character associated with the break condition is carried through the FIFO and is revealed when the character is at the top of the FIFO. Reading the LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs</p> |

| Offset: 0x14 |            |         | Register Name: UART_LSR<br>Default Value: 0x0000_0060                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|              |            |         | immediately and persists until the LSR is read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3            | R          | 0       | <p>FE<br/>Framing Error<br/>This is used to indicate the occurrence of a framing error in the receiver. A framing error occurs when the receiver does not detect a valid STOP bit in the received data.<br/>In the FIFO mode, since the framing error is associated with a character received, it is revealed when the character with the framing error is at the top of the FIFO. When a framing error occurs, the UART tries to resynchronize. It does this by assuming that the error was due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).<br/>0: no framing error<br/>1:framing error<br/>Reading the LSR clears the FE bit.</p> |
| 2            | R          | 0       | <p>PE<br/>Parity Error<br/>This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (LCR[3]) is set. In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO. It should be noted that the Parity Error (PE) bit (LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).<br/>0: no parity error<br/>1: parity error<br/>Reading the LSR clears the PE bit.</p>                                                                                                                                                                                                                                                                                          |

| Offset: 0x14 |            |         | Register Name: UART_LSR<br>Default Value: 0x0000_0060                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1            | R          | 0       | <p>OE<br/>Overrun Error</p> <p>This occurs if a new data character was received before the previous data was read. In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character was read from the 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>                                                                                                                                                                                                                                                                                                           |

#### 6.4.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 <code>dcd_n</code>. This bit is the complement of <code>dcd_n</code>. When the Data Carrier Detect input (<code>dcd_n</code>) is asserted it is an indication that the carrier has been detected by the modem or data set.</p> <p>0: <code>dcd_n</code> input is de-asserted (logic 1)<br/>1: <code>dcd_n</code> input is asserted (logic 0)</p> |

| Offset: 0x18 |            |         | Register Name: UART_MSR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 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 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</p>                                                |

| <b>Offset: 0x18</b> |                   |                | <b>Register Name: UART_MSR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                     |                   |                | the DDCD bit is set when the reset is removed if the dcd_n signal remains asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2                   | R                 | 0              | <p><b>TERI</b><br/> <b>Trailing Edge Ring Indicator</b><br/> This is used to indicate that a change on the input ri_n (from an active-low to an inactive-high state) has occurred since the last time the MSR was read.<br/> 0: no change on ri_n since last read of MSR<br/> 1: change on ri_n since last read of MSR<br/> Reading the MSR clears the TERI bit.</p>                                                                                                                                                                                                                                          |
| 1                   | R                 | 0              | <p><b>DDSR</b><br/> <b>Delta Data Set Ready</b><br/> This is used to indicate that the modem control line dsr_n has changed since the last time the MSR was read.<br/> 0: no change on dsr_n since last read of MSR<br/> 1: change on dsr_n since last read of MSR<br/> Reading the MSR clears the DDSR bit. In Loopback Mode (MCR[4] = 1), DDSR reflects changes on MCR[0] (DTR).<br/> Note: If the DDSR bit is not set and the dsr_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDSR bit is set when the reset is removed if the dsr_n signal remains asserted.</p>      |
| 0                   | R                 | 0              | <p><b>DCTS</b><br/> <b>Delta Clear to Send</b><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/> Reading the MSR clears the DCTS bit. In Loopback Mode (MCR[4] = 1), DCTS reflects changes on MCR[1] (RTS).<br/> Note: If the DCTS bit is not set and the cts_n signal is asserted (low) and a reset occurs (software or otherwise), then the DCTS bit is set when the reset is removed if the cts_n signal remains asserted.</p> |

#### 6.4.4.12. UART SCRATCH REGISTER

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

#### 6.4.4.13. UART STATUS REGISTER

| <b>Offset: 0x7C</b> |                   |                | <b>Register Name: UART_USR</b><br><b>Default Value: 0x0000_0006</b>                                                                                                                                                                                         |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                          |
| 31:5                | /                 | /              | /                                                                                                                                                                                                                                                           |
| 4                   | R                 | 0              | <p><b>RFF</b><br/> <b>Receive FIFO Full</b><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/> This bit is cleared when the RX FIFO is no longer full.</p>                |
| 3                   | R                 | 0              | <p><b>RFNE</b><br/> <b>Receive FIFO Not Empty</b><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/> This bit is cleared when the RX FIFO is empty.</p> |
| 2                   | R                 | 1              | <p><b>TFE</b><br/> <b>Transmit FIFO Empty</b><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> |

| <b>Offset: 0x7C</b> |                   |                | <b>Register Name: UART_USR</b><br><b>Default Value: 0x0000_0006</b>                                                                                                                                                                    |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                     |
| 1                   | R                 | 1              | <p>TFNF</p> <p>Transmit FIFO Not Full</p> <p>This is used to indicate that the transmit FIFO is not full.</p> <p>0: Transmit FIFO is full</p> <p>1: Transmit FIFO is not full</p> <p>This bit is cleared when the TX FIFO is full.</p> |
| 0                   | R                 | 0              | <p>BUSY</p> <p>UART Busy Bit</p> <p>0: Idle or inactive</p> <p>1: Busy</p>                                                                                                                                                             |

#### 6.4.4.14. UART TRANSMIT FIFO LEVEL REGISTER

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

#### 6.4.4.15. UART RECEIVE FIFO LEVEL REGISTER

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

#### 6.4.4.16. UART HALT TX REGISTER

| Offset: 0xA4 |            |         | Register Name: <b>UART_HALTI</b><br>Default Value: <b>0x0000_0000</b>                                                                                                                                                                                                                      |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                |
| 31:6         | /          | /       | /                                                                                                                                                                                                                                                                                          |
| 5            | R/W        | 0       | SIR_RX_INVERT<br>SIR Receiver Pulse Polarity Invert<br>0: Not invert receiver signal<br>1: Invert receiver signal                                                                                                                                                                          |
| 4            | R/W        | 0       | SIR_TX_INVERT<br>SIR Transmit Pulse Polarity Invert<br>0: Not invert transmit pulse<br>1: Invert transmit pulse                                                                                                                                                                            |
| 3            | /          | /       | /                                                                                                                                                                                                                                                                                          |
| 2            | R/W        | 0       | CHANGE_UPDATE<br>After the user using HALT[1] to change the baudrate or LCR configuration, write 1 to update the configuration and waiting this bit self clear to 0 to finish update process. Write 0 to this bit has no effect.<br>1: Update trigger, Self clear to 0 when finish update. |
| 1            | R/W        | 0       | CHCFG_AT_BUSY<br>This is an enable bit for the user to change LCR register configuration (except for the DLAB bit) and baudrate register (DLH and DLL) when the UART is busy (USB[0] is 1).<br>1: Enable change when busy                                                                  |
| 0            | R/W        | 0       | /                                                                                                                                                                                                                                                                                          |

#### 6.4.5. UART Special Requirement

##### 6.4.5.1. UART PIN LIST

| Port Name | Width | Direction | Description |
|-----------|-------|-----------|-------------|
|           |       |           |             |

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

| Port Name | Width | Direction | Description            |
|-----------|-------|-----------|------------------------|
| UART4_TX  | 1     | OUT       | UART Serial Bit output |
| UART4_RX  | 1     | IN        | UART Serial Bit input  |
| UART5_TX  | 1     | OUT       | UART Serial Bit output |
| UART5_RX  | 1     | IN        | UART Serial Bit input  |
| UART6_TX  | 1     | OUT       | UART Serial Bit output |
| UART6_RX  | 1     | IN        | UART Serial Bit input  |
| UART7_TX  | 1     | OUT       | UART Serial Bit output |
| UART7_RX  | 1     | IN        | UART Serial Bit input  |

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

## 6.5. PS2

### 6.5.1. Overview

The PS2 is a Dual-Role controller that supports both device and host functions.

It is fully compliant with IBM PS2 in Personal Computer. It can be configured as a Host to connect PS2 Keyboard or PS2 Mouse, or as a Device to connect computers.

The PS2 module can be integrated with industry-standard AMBA Peripheral Bus (APB) for communication with other system modules, such as ARM CPU, and System Memory.

It features:

- Comply with the AMBA Specification (Rev 2.0) for easy integration into SOC implementation
- Compliant with IBM PS2 and AT-Compatible Keyboard and Mouse Interface
- Dual Role controller, either a PS2 Host or a PS2 Device
- 4-byte TXFIFO and 4-byte RXFIFO for data buffering
- Odd parity generation and checking
- Register bits for override of keyboard clock and data lines
- Internal clock divider for simple clock interface

## 6.5.2. PS2 Block Diagram



## 6.5.3. PS2 Timing Diagram

The Data and Clock lines of PS2 Bus are both open-collector with pull-up resistors to power, and so, Data and Clock signals on PS2 Bus are both wire-and by corresponding signal of Host and Device. Data is transferred after start bit, starting with the least significant bit(LSB). These are followed by the parity bit, followed by one stop bit. If data is transferred from master to device, there is an additional acknowledge bit(ACK) sent by device, following the stop bit.

Timing for Device Transmit Data and Master Receive Data:



### Timing for Master Transmit Data and Device Receive Data:



### Timing for Master sending command then Device sending response



Device drive and sample data at rising edge of CLOCK. Master drive and sample data at falling edge of CLOCK.

| Name  | Comment                                                               | Min.  | Typical | Max.     |
|-------|-----------------------------------------------------------------------|-------|---------|----------|
| Tckl  | Clock LOW time                                                        | 30us  | 40us    | 50us     |
| Tckh  | Clock HIGH time                                                       | 30us  | 40us    | 50us     |
| Tinh  | Time for Host inhibit clock for send data request                     | 100us | -       | -        |
| Td2f  | Data change to clock falling edge time during device to host transfer | 5us   | -       | Tckh-5us |
| Tr2d  | Clock rising edge to data change time during device to host transfer  | 5us   | -       | Tckh-5us |
| Td2r  | Data change to clock rising edge time during host to device transfer  | 5us   | -       | Tckl-5us |
| Tf2d  | Clock falling edge to data change time during host to device transfer | 5us   | -       | Tckl-5us |
| Tc2c  | Host pull low Clock to Device drive Clock                             | -     | -       | 15ms     |
| Tdata | Time for packet to send                                               | -     | -       | 2ms      |

| Name | Comment                                        | Min. | Typical | Max. |
|------|------------------------------------------------|------|---------|------|
| Trsp | Time for device responding to the host command | -    | -       | 20ms |

## 6.5.4. PS2 Register List

| Module Name | Base Address |
|-------------|--------------|
| PS2-0       | 0x01C2A000   |
| PS2-1       | 0x01C2A400   |

| Register Name | Offset | Description                        |
|---------------|--------|------------------------------------|
| PS2_GCTL      | 0x00   | PS2 Module Global Control Register |
| PS2_DATA      | 0x04   | PS2 Module Data Register           |
| PS2_LCTL      | 0x08   | PS2 Module Line Control Register   |
| PS2_LSTS      | 0x0C   | PS2 Module Line Status Register    |
| PS2_FCTL      | 0x10   | PS2 Module FIFO Control Register   |
| PS2_FSTS      | 0x14   | PS2 Module FIFO Status Register    |
| PS2_CKDR      | 0x18   | PS2 Module Clock Divider Register  |

## 6.5.5. PS2 Register Description

### 6.5.5.1. PS2 GLOBAL CONTROL REGISTER

| Offset: 0x0000 |            |         | Register Name: PS2_GCTL<br>Default Value: 0x0000_0002                                                                                                                                                                                                                                      |
|----------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                                                                                                                                                |
| 31:5           | /          | /       | /                                                                                                                                                                                                                                                                                          |
| 4              | R          | 0       | <p>INT_FLAG<br/>Interrupt Flag</p> <p>The interrupt flag is set when any bit in FIFO Status and the corresponding enable bit in FIFO Control are set at the same time. This interrupt flag is also set when error flag bit in line status register (PS2_LSTS) is set at the same time.</p> |

| <b>Offset: 0x0000</b> |                   |                | <b>Register Name: PS2_GCTL</b><br><b>Default Value: 0x0000_0002</b>                                                                                                                                                                                                                                                                   |
|-----------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                    |
|                       |                   |                | <i>Note: This bit is just a status flag, it can not be cleared directly, it can be cleared by clearing the status bits in FIFO Status Register.</i>                                                                                                                                                                                   |
| 3                     | R/W               | 0              | <p><b>INT_EN</b><br/>Interrupt Enable<br/>0 – the interrupt signal is always low<br/>1 – the interrupt signal will be high when INT_FLAG is set</p>                                                                                                                                                                                   |
| 2                     | R/W               | 0              | <p><b>SOFT_RST</b><br/>Soft Reset<br/>Setting this bit will reset transmitter and receiver of PS2 Module, and the status of transmitter and receiver will revert to the default state, but not affect any control bits in register, and data in TXFIFO/RXFIFO.<br/>This bit will be cleared by hardware after reset is completed.</p> |
| 1                     | R/W               | 1              | <p><b>FUNC_SEL</b><br/>Master/Device Function Select<br/>1 – Master Function, connect to PS2 Keyboard or Mouse<br/>0 – Device Function, connect to Computer</p>                                                                                                                                                                       |
| 0                     | R/W               | 0              | <p><b>BUS_EN</b><br/>PS2 Bus Enable<br/>0 – Ignore PS2 Bus Input<br/>1 – Response to PS2 Bus Input</p>                                                                                                                                                                                                                                |

#### 6.5.5.2. PS2 DATA REGISTER

| <b>Offset: 0x0004</b> |                   |                | <b>Register Name: PS2_DATA</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                          |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                           |
| 31:8                  | /                 | /              | /                                                                                                                                                                                            |
| 7:0                   | R/W               | 0              | <p><b>PS2_DATA</b><br/>When write, data will be write into TXFIFO, and will be transmit on to the PS2 Bus.<br/>When read, data is read out from RXFIFO, and it is received from PS2 Bus.</p> |

| <b>Offset: 0x0004</b> |                   |                | <b>Register Name: PS2_DATA</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                               |
|-----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|                       |                   |                | <i>Note: (1) After TXFIFO is full, writing does not affect anything except the overflow flag of TXFIFO in FIFO Status Register.<br/>(2) After RXFIFO is empty, reading has no effect on anything except the underflow flag of RXFIFO in FIFO Status Register.</i> |

### 6.5.5.3. PS2 LINE CONTROL REGISTER

| <b>Offset: 0x0008</b> |                   |                | <b>Register Name: PS2_LCTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                            |
|-----------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                             |
| 31:19                 | /                 | /              | /                                                                                                                                                                                                                                                                                                                              |
| 18                    | R/W               | 0              | <p><b>NO_ACK</b><br/>ACK Control<br/>0 – In Host function mode, must check ACK after transmitted data; In Device function mode, must send ACK after received data from Host.<br/>1 – In Host function mode, don't check ACK after transmitted data; In Device function mode, don't send ACK after received data from Host.</p> |
| 17                    | R/W               | 0              | <p><b>FORCE_DATA</b><br/>Force Data to LOW<br/>0 – Data Line works in Normal Mode<br/>1 – Data Line is forced to LOW</p>                                                                                                                                                                                                       |
| 16                    | R/W               | 0              | <p><b>FORCE_CLK</b><br/>Force Clock to LOW<br/>0 – Clock Line works in Normal Mode<br/>1 – Clock Line is forced to LOW</p>                                                                                                                                                                                                     |
| 15:9                  | /                 | /              | /                                                                                                                                                                                                                                                                                                                              |
| 8                     | R/W               | 0              | <p><b>TXDTO_IEN</b><br/>TX Data Timeout Interrupt Enable</p>                                                                                                                                                                                                                                                                   |
| 7:4                   | /                 | /              | /                                                                                                                                                                                                                                                                                                                              |
| 3                     | R/W               | 0              | <p><b>STOP_IEN</b><br/>Stop Error Interrupt Enable</p>                                                                                                                                                                                                                                                                         |
| 2                     | R/W               | 0              | <b>ACKERR_IEN</b>                                                                                                                                                                                                                                                                                                              |

| <b>Offset: 0x0008</b> |                   |                | <b>Register Name: PS2_LCTL</b><br><b>Default Value: 0x0000_0000</b> |
|-----------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
|                       |                   |                | Acknowledge Error Interrupt Enable                                  |
| 1                     | R/W               | 0              | PARERR_IEN<br>Parity Error Interrupt Enable                         |
| 0                     | R/W               | 0              | RXDTO_IEN<br>RX Data Timeout Interrupt Enable                       |

#### 6.5.5.4. PS2 LINE STATUS REGISTER

| <b>Offset: 0x000C</b> |                   |                | <b>Register Name: PS2_LSTS</b><br><b>Default Value: 0x0003_0000</b>                                                                                                                                                  |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                   |
| 31:20                 | /                 | /              | /                                                                                                                                                                                                                    |
| 19                    | R                 | 0              | <p>TX_BUSY<br/>Transmit Busy</p> <p>0 – PS2 Module Transmit Engine is Idle.<br/>1 – PS2 Module is currently sending data.</p> <p><i>Note: This bit can be cleared by writing ‘1’, writing ‘0’ has no effect.</i></p> |
| 18                    | R                 | 0              | <p>RX_BUSY<br/>Receive Busy</p> <p>0 – PS2 Module Receive Engine is Idle.<br/>1 – PS2 Module is currently receiving data.</p> <p><i>Note: This bit can be cleared by writing ‘1’, writing ‘0’ has no effect.</i></p> |
| 17                    | R                 | 1              | <p>LS_DATA</p> <p>Line State of DATA. Invalid before BUS_EN set.</p>                                                                                                                                                 |
| 16                    | R                 | 1              | <p>LS_CLK</p> <p>Line State of CLOCK. Invalid before BUS_EN set.</p>                                                                                                                                                 |
| 15:9                  | /                 | /              | /                                                                                                                                                                                                                    |
| 8                     | R/W               | 0              | <p>TX.DTO</p> <p>Transmit Data Timeout</p> <p>Timers include:</p>                                                                                                                                                    |

| <b>Offset: 0x000C</b> |                   |                | <b>Register Name: PS2_LSTS</b><br><b>Default Value: 0x0003_0000</b>                                                                                                                                                                                                                                       |
|-----------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                        |
|                       |                   |                | <p>Tc2c&lt;15ms (Host pull low Clock to Device drive Clock)<br/> Tdata&lt;2ms (Time for packet to send)<br/> Tckl+Tckh&lt;100us(one cycle time, as host)</p> <p><i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p>                                                       |
| 7:4                   | /                 | /              | /                                                                                                                                                                                                                                                                                                         |
| 3                     | R/W               | 0              | <p>STOP_ERR<br/> Stop Bit Error<br/> 0 –No Error<br/> 1 –Stop Error</p> <p><i>This bit can be cleared by writing '1', writing '0' has no effect.</i></p>                                                                                                                                                  |
| 2                     | R/W               | 0              | <p>ACK_ERR<br/> Acknowledge Error<br/> 0 – ACK is received after data transmitted.<br/> 1 – ACK is not received after data transmitted.</p> <p><i>Note: 1) Only for Master Function; 2) This bit can be cleared by writing '1', writing '0' has no effect.</i></p>                                        |
| 1                     | R/W               | 0              | <p>PAR_ERR<br/> Parity Error<br/> 0 – No Error<br/> 1 – Parity Error</p> <p><i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p>                                                                                                                                           |
| 0                     | R/W               | 0              | <p>RX.DTO<br/> Receive Data Timeout<br/> Timers include:<br/> Trsp&lt;20ms(time from the host releases the Clock line to device sends corresponding response)<br/> Tckl+Tckh&lt;100us(one cycle time, as host)</p> <p><i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p> |

#### 6.5.5.5. PS2 FIFO CONTROL REGISTER

| <b>Offset: 0x0010</b> |                   |                | <b>Register Name: PS2_FCTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                             |
|-----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                              |
| 31:8                  | /                 | /              | /                                                                                                                                                                                                                                               |
| 17                    | R/W               | 0              | <p><b>TXFIFO_RST</b><br/>TXFIFO Reset<br/>After this bit is set, data in TXFIFO is flushed, and the pointer of TXFIFO is reset.</p> <p><i>Note: This bit is cleared automatically after TXFIFO is reset, and writing '0' has no effect.</i></p> |
| 16                    | R/W               | 0              | <p><b>RXFIFO_RST</b><br/>RXFIFO Reset<br/>After this bit is set, data in RXFIFO is flushed, and the pointer of RXFIFO is reset.</p> <p><i>Note: This bit is cleared automatically after RXFIFO is reset, and writing '0' has no effect.</i></p> |
| 15:11                 | /                 | /              | /                                                                                                                                                                                                                                               |
| 10                    | R/W               | 0              | <p><b>TXUF_IEN</b><br/>TXFIFO Underflow Interrupt Enable</p>                                                                                                                                                                                    |
| 9                     | R/W               | 0              | <p><b>TXOF_IEN</b><br/>TXFIFO Overflow Interrupt Enable</p>                                                                                                                                                                                     |
| 8                     | R/W               | 0              | <p><b>TXRDY_IEN</b><br/>TXFIFO Ready Interrupt Enable</p>                                                                                                                                                                                       |
| 7:3                   | /                 | /              | /                                                                                                                                                                                                                                               |
| 2                     | R/W               | 0              | <p><b>RXUF_IEN</b><br/>RXFIFO Underflow Interrupt Enable</p>                                                                                                                                                                                    |
| 1                     | R/W               | 0              | <p><b>RXOF_IEN</b><br/>RXFIFO Overflow Interrupt Enable</p>                                                                                                                                                                                     |
| 0                     | R/W               | 0              | <p><b>RXRDY_IEN</b><br/>RXFIFO Ready Interrupt Enable</p>                                                                                                                                                                                       |

#### 6.5.5.6. PS2 FIFO STATUS REGISTER

| <b>Offset: 0x0014</b> |                   |                | <b>Register Name: PS2_FSTS</b><br><b>Default Value: 0x0000_0100</b> |
|-----------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |

| Offset: 0x0014 |            |         | Register Name: PS2_FSTS<br>Default Value: 0x0000_0100                                                                                                                                                                                                                                                                                 |
|----------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                           |
| 31:23          | /          | /       | /                                                                                                                                                                                                                                                                                                                                     |
| 22:20          | R          | 0       | <p>TX_LEVEL<br/>TXFIFO Level<br/>The number of 8-bit data, which will be transmitted on to PS2 Bus, in the TXFIFO. The value must be in the range 0-4.</p>                                                                                                                                                                            |
| 19             | /          | /       | /                                                                                                                                                                                                                                                                                                                                     |
| 18:16          | R          | 0       | <p>RX_LEVEL<br/>RXFIFO Level<br/>The number of 8-bit data, which is received from PS2 bus, in the RXFIFO. The value must be in the range 0-4.</p>                                                                                                                                                                                     |
| 15:11          | /          | /       | /                                                                                                                                                                                                                                                                                                                                     |
| 10             | R/W        | 0       | <p>TX_UF<br/>TXFIFO Underflow<br/>When this bit is set, TXFIFO is underflow, and it means that the TXFIFO is read by transmit engine after empty. This bit is just a flag of illegal operation, which should not affect any state of TXFIFO.<br/> <i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p> |
| 9              | R/W        | 0       | <p>TX_OF<br/>TXFIFO Overflow<br/>When this bit is set, TXFIFO is overflow, and it means that the TXFIFO is wrote by CPU after TXFIFO is full. This bit is just a flag of illegal operation, which should not affect any state of TXFIFO.<br/> <i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p>     |
| 8              | R/W        | 1       | <p>TX_RDY<br/>Transmit Ready<br/>0 – TXFIFO is full<br/>1 – TXFIFO is not full.<br/> <i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p>                                                                                                                                                              |
| 7:3            | /          | /       | /                                                                                                                                                                                                                                                                                                                                     |
| 2              | R/W        | 0       | <p>RX_UF<br/>RXFIFO Underflow<br/>When this bit is set, RXFIFO is underflow, and it means that</p>                                                                                                                                                                                                                                    |

| <b>Offset: 0x0014</b> |                   |                | <b>Register Name: PS2_FSTS</b><br><b>Default Value: 0x0000_0100</b>                                                                                                                                                                                                                                                                                      |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                       |
|                       |                   |                | <p>the RXFIFO is read by CPU after empty. This bit is just a flag of illegal operation, which should not affect any state of RXFIFO.</p> <p><i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p>                                                                                                                          |
| 1                     | R/W               | 0              | <p><b>RX_OF</b><br/>RXFIFO Overflow</p> <p>When this bit is set, RXFIFO is overflow, and it means that the RXFIFO is wrote by receive engine after RXFIFO is full. This bit is just a flag of illegal operation, which should not affect any state of RXFIFO.</p> <p><i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p> |
| 0                     | R/W               | 0              | <p><b>RX_RDY</b><br/>Receive Ready</p> <p>0 – RXFIFO is empty</p> <p>1 – RXFIFO is not empty, there are at least one byte data, which is received from PS2 bus, in the RXFIFO.</p> <p><i>Note: This bit can be cleared by writing '1', writing '0' has no effect.</i></p>                                                                                |

#### 6.5.5.7. PS2 CLOCK DIVIDER REGISTER

| <b>Offset: 0x0018</b> |                   |                | <b>Register Name: PS2_CKDR</b><br><b>Default Value: 0x0000_2F4F</b>                                                                                                                                                                                                           |
|-----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                            |
| 31:16                 | /                 | /              | /                                                                                                                                                                                                                                                                             |
| 15:8                  | R/W               | 0x2F           | <p><b>SCLK_DIV</b><br/>Sample Clock Divider Factor (SCDF)</p> <p>Sample Clock is a 1MHz clock for internal timing control.</p> <p>SCDF = APB_CLK/SAMPLE_CLK – 1</p> <p>Frequency of sample clock is constant, and so, frequency of APB_CLK must be in the range 1-256MHz.</p> |
| 7                     | /                 | /              | /                                                                                                                                                                                                                                                                             |
| 6:0                   | R/W               | 0x4F           | <b>CLK_DIV</b>                                                                                                                                                                                                                                                                |

| <b>Offset: 0x0018</b> |                   |                | <b>Register Name: PS2_CKDR</b><br><b>Default Value: 0x0000_2F4F</b>                                                                                                                                                     |
|-----------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                      |
|                       |                   |                | PS2 Clock Divider Factor (PCDF)<br>$PCDF = SAMPLE\_CLK / PS2\_CLK - 1 = 1\text{MHz}/PS2\_CLK - 1$<br>The frequency of PS2_CLK must be in the range 10-16.7KHz.<br><i>Note: This factor is used in device mode only.</i> |

## 6.5.6. PS2 Special Requirements

### 6.5.6.1. PS2 INTERFACE PIN LIST

| <b>Port Name</b> | <b>Width</b> | <b>Direction</b> | <b>Description</b> |
|------------------|--------------|------------------|--------------------|
| PS2_CLK          | 1            | IN/OUT           | PS2 clock signal   |
| PS2_DATA         | 1            | IN/OUT           | PS2 data signal    |

### 6.5.6.2. PS2 CLOCK REQUIREMENT

| <b>Clock Name</b> | <b>Description</b> | <b>Requirement</b> |
|-------------------|--------------------|--------------------|
| apb_clk           | APB bus clock      | $\geq 1\text{MHz}$ |

## 6.6. IR

### 6.6.1. Overview

The CIR (Consumer IR) interface is used for remote control through infra-red light.

The CIR receiver samples the input signal on the programmable frequency and records these samples into RX FIFO when one CIR signal is found on the air. The CIR receiver uses Run-Length Code (RLC) to encode pulse width. The encoded data is buffered in a 64 levels and 8-bit width RX FIFO; the MSB bit is used to record the polarity of the receiving CIR signal. The high level is represented as '1' while the low level is represented as '0'. The rest 7 bits are used for the length of RLC. The maximum length is 128. If the duration of one level (high or low level) is more than 128, another byte is used.

Since there is always some noise in the air, a threshold can be set to filter the noise to reduce system loading and improve system stability.

The CIR interface features:

- Full physical layer implementation
- Support CIR for remote control or wireless keyboard
- Support dual 64x8bits FIFO for data buffer
- Programmable FIFO thresholds
- Support Interrupt and DMA

## 6.6.2. IR Block Diagram

The IR block diagram is shown below:



## 6.6.3. IR Register List

| Module Name | Base Address |
|-------------|--------------|
| IR0         | 0x01C21800   |
| IR1         | 0x01C21C00   |

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| IR_CTL        | 0x00   | IR Control Register               |
| IR_TXCTL      | 0x04   | IR Transmitter Configure Register |

| Register Name | Offset | Description                               |
|---------------|--------|-------------------------------------------|
| IR_TXADR      | 0x08   | IR Transmitter Address Register           |
| IR_TXCNT      | 0x0C   | IR Transmitter Counter Register           |
| IR_RXCTL      | 0x10   | IR Receiver Configure Register            |
| IR_RXADR      | 0x14   | IR Receiver Address Register              |
| IR_RXCNT      | 0x18   | IR Receiver Counter Register              |
| IR_TXFIFO     | 0x1C   | IR Transmitter FIFO Register              |
| IR_RXFIFO     | 0x20   | IR Receiver FIFO Register                 |
| IR_TXINT      | 0x24   | IR Transmitter Interrupt Control Register |
| IR_TXSTA      | 0x28   | IR Transmitter Status Register            |
| IR_RXINT      | 0x2C   | IR Receiver Interrupt Control Register    |
| IR_RXSTA      | 0x30   | IR Receiver Status Register               |
| IR_CIR        | 0x34   | CIR Configure Register                    |

## 6.6.4. IR Register Description

### 6.6.4.1. IR CONTROL REGISTER

| Offset: 0x00 |            |         | Register Name: IR_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       | MD<br>Irda Mode<br>00: 0.576 Mbit/s MIR mode<br>01: 1.152 Mbit/s MIR mode<br>10: 4.0 Mbit/s FIR mode |

| <b>Offset: 0x00</b> |                   |                | <b>Register Name: IR_CTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                   |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                  |
|                     |                   |                | 11: CIR mode for Remote control or wireless keyboard                                                                                                |
| 3                   | R/W               | 0              | /                                                                                                                                                   |
|                     |                   |                | <b>TXEN</b><br>Transmitter Block Enable<br>0: Disable<br>1: Enable                                                                                  |
|                     |                   |                | <b>RXEN</b><br>Receiver Block Enable<br>0: Disable<br>1: Enable                                                                                     |
|                     |                   |                | <b>GEN</b><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 |

#### 6.6.4.2. IR TRANSMITTER CONFIGURE REGISTER

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: IR_TXCTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:6                |                   |                | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5                   | R/W               | 0              | <b>PCF</b><br>Packet Complete by FIFO<br>This bit determines how a packet is completed if a TX FIFO underrun event occurs. Do not write software intentionally to cause underrun events. However, if due to erroneous conditions, the value of this bit selects between two recovery modes. Set the PCF based on system and upper layer IrDA protocol requirements.<br>0: Send CRC and STO fields<br>Send CRC16 and STO for MIR or CRC32 and STO for FIR<br>1: Send packet abort symbol<br>Send 7'b111,1111 for MIR or 8'b0000,0000 for FIR |

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: IR_TXCTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4                   | /                 | /              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3                   | R/W               | 0              | <p>SIP<br/>Transmit SIP<br/>Writing ‘1’ to this bit produces a “Serial Infrared Interaction Pulse” transmission.<br/>Writing a ‘0’ to this bit is ignored. This bit is always read as “0”. If this bit is set while in the middle of the transfer, the packet will be ignored by IRDA controller.</p> <p>Don’t Set SIP bit in the middle of transfer.</p> <p>A SIP is defined as a 1.6us optical pulse of the transmitter followed by a 7.1us off time of the transmitter. It simulates a start pulse, causing the potentially interfering system to listen for at least 500 ms.</p> |
| 2                   | R/W               | 1              | <p>TPPI<br/>Transmit Pulse Polarity Invert<br/>0: Not invert transmit pulse<br/>1: Invert transmit pulse</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1:0                 | /                 | /              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 6.6.4.3. IR TRANSMITTER ADDRESS REGISTER

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: IR_TXADR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                 |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                  |
| 31:9                | /                 | /              | /                                                                                                                                                                                                                                                                                   |
| 8                   | R/W               | 0              | <p>HAG<br/>Hardware Address Generator. When this bit is set, the content of the TPA bits is transmitted as a packet address. When the bit is cleared, the packet address is read from TX FIFO.</p> <p>0: Read packet address from TX FIFO<br/>1: Use TPA bits as packet address</p> |
| 7:0                 | R/W               | 0              | <p>TPA<br/>Transmit Packet Address<br/>This field contains the 8-bit Transmit Packet Address. If the HAG bit is cleared, the TPA bits have no effect.</p>                                                                                                                           |

#### 6.6.4.4. IR TRANSMITTER COUNTER REGISTER

| Offset: 0x0C |            |         | Register Name: IR_TXCNT<br>Default Value: 0x0000_0000                                                                                                                                                                                                            |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                      |
| 31:11        | /          | /       | /                                                                                                                                                                                                                                                                |
| 10:0         | R/W        | 0       | <p>TPL<br/>Transmit Packet Length<br/>This field contains the length of the address, control and data.<br/>The length are (N+1) bytes.</p> <p>11'd0: 1 bytes<br/>11'd1: 2 bytes<br/>11'd2: 3 bytes<br/>...<br/>11'd2046: 2047 bytes<br/>11'd2047: 2048 bytes</p> |

#### 6.6.4.5. IR RECEIVER CONFIGURE REGISTER

| Offset: 0x10 |            |         | Register Name: IR_RXCTL<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:4         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3            | R/W        | 0       | <p>RPA<br/>Receiver Packet Abort bit.<br/>Determines behavior of the RX FIFO upon detection of an illegal symbol. When an illegal symbol is detected, the DDE or CRCE bit in the receiver status register is set. If the RPA bit is set, the RX FIFO pointers are cleared and the receiver starts to search for the PA or STA fields for FIR and MIR mode, respectively. If RPA is cleared, the receiver continues to write to the RX FIFO.</p> <p>0: Does not clear the RX FIFO upon detection of an illegal symbol<br/>1: Clears the RX FIFO upon detection of illegal symbol</p> |

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

#### 6.6.4.6. IR RECEIVER ADDRESS REGISTER

| <b>Offset: 0x14</b> |                   |                | <b>Register Name: IR_RXADR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                         |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:9                | /                 | /              | /                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8                   | R/W               | 0              | RAM<br>Receiver Address Match<br>0: Does not need match address (RA). When an new packet is received, the address, control and data fields are filled into RX FIFO.<br>1: Should match packet address to RA bits when an new packet is received. If address matched, the control and data fields are filled into RX FIFO excluding the address field.<br>The value of this bit can be changed when the RXEN bit is cleared. |
| 7:0                 | R/W               | 0              | RA<br>Receiver Address<br>The value of this bit can be changed when the RXEN bit is cleared.                                                                                                                                                                                                                                                                                                                                |

#### 6.6.4.7. IR RECEIVER COUNTER REGISTER

| <b>Offset: 0x18</b> |                   |                | <b>Register Name: IR_RXCNT</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |

| <b>Offset: 0x18</b> |                   |                | <b>Register Name: IR_RXCNT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                        |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                         |
| 31:12               | /                 | /              | /                                                                                                                                                                                                                                                                          |
| 11:0                | R                 | 0              | <p>RPL<br/>Receiver Packet Length<br/>This field contains the length of the address, control and data.<br/>The length are (N+1) bytes.</p> <p>0: no bytes received<br/>N: N bytes received<br/>It can automatically clear by Irda Controller when new packet is found.</p> |

#### 6.6.4.8. IR TRANSMITTER FIFO REGISTER

| <b>Offset: 0x1C</b> |                   |                | <b>Register Name: IR_TXFIFO</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:8                | /                 | /              | /                                                                    |
| 7:0                 | W                 | 0              | <p>TX_DATA<br/>Transmitter Byte FIFO</p>                             |

#### 6.6.4.9. IR RECEIVER FIFO REGISTER

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

#### 6.6.4.10. IR TRANSMITTER INTERRUPT CONTROL REGISTER

| Offset: 0x24 |                   |                | <b>Register Name: IR_TXINT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                         |
|--------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>   | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                          |
| 31:12        | /                 | /              | /                                                                                                                                                                                                                                                           |
| 11:8         | R/W               | 0              | TEL<br>TX FIFO Empty Level for interrupt and DMA request<br>TRIGGER_LEVEL = TEL + 1                                                                                                                                                                         |
| 7:6          | /                 | /              | /                                                                                                                                                                                                                                                           |
| 5            | R/W               | 0              | DRQ_EN<br>TX FIFO Empty DMA Enable<br>0: Disable<br>1: Enable<br>When set to '1', the Transmitter FIFO DRQ is asserted if reaching TEL. The DRQ is de-asserted when condition fails or specified number data has been sent from host CPU.                   |
| 4            | R/W               | 0              | TEI_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable<br>When set to '1', the Transmitter FIFO interrupt is asserted if reaching TEL. The interrupt is de-asserted when condition fails or specified number data has been sent from host CPU. |
| 3            | R/W               | 0              | TCL_EN<br>Transmit (including the CRC and STO fields) Complete Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                                  |
| 2            | R/W               | 0              | SIPEI_EN<br>Transmitter SIP End Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                 |
| 1            | R/W               | 0              | TPEI_EN<br>Transmitter Packet (the address, control and data fields) End Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                        |
| 0            | R/W               | 0              | TUI_EN                                                                                                                                                                                                                                                      |

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: IR_TXINT</b><br><b>Default Value: 0x0000_0000</b>    |
|---------------------|-------------------|----------------|------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                     |
|                     |                   |                | Transmitter FIFO Under run Interrupt Enable<br>0: Disable<br>1: Enable |

#### 6.6.4.11. IR TRANSMITTER STATUS REGISTER

| <b>Offset: 0x28</b> |                   |                | <b>Register Name: IR_TXSTA</b><br><b>Default Value: 0x0000_1000</b>                                                                                                                                                                                             |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                              |
| 31:13               | /                 | /              | /                                                                                                                                                                                                                                                               |
| 12:8                | R                 | 0x10           | TA<br>TX FIFO Available Room Counter<br>0: TX FIFO full<br>1: TX FIFO 1 byte room for new data<br>2: TX FIFO 2 byte room for new data<br>...<br>15: TX FIFO 15 byte room for new data<br>16: TX FIFO 16 byte room for new data (full empty)<br>Others: Reserved |
| 7:5                 | /                 | /              | /                                                                                                                                                                                                                                                               |
| 4                   | R/W               | 1              | TE<br>TX FIFO Empty<br>0: TX FIFO not empty<br>1: TX FIFO empty by its level<br>This bit is cleared by writing a '1'.                                                                                                                                           |
| 3                   | R/W               | 0              | TC<br>Transmit (including the CRC and STO fields) Complete<br>0: Transmission not completed<br>1: Transmission completed<br>This bit is cleared by writing a '1'.                                                                                               |
| 2                   | R/W               | 0              | SIPE<br>Transmitter SIP End                                                                                                                                                                                                                                     |

| <b>Offset: 0x28</b> |                   |                | <b>Register Name: IR_TXSTA</b><br><b>Default Value: 0x0000_1000</b>                                                                                                                                            |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                             |
|                     |                   |                | 0: Transmission of SIP not completed<br>1: Transmission of SIP completed<br>This bit is cleared by writing a '1'.                                                                                              |
| 1                   | R/W               | 0              | TPE<br>Transmitter Packet End<br>0: Transmissions of address, control and data fields not completed<br>1: Transmissions of address, control and data fields completed<br>This bit is cleared by writing a '1'. |
| 0                   | R/W               | 0              | TU<br>Transmitter FIFO Under Run<br>0: No transmitter FIFO under run<br>1: Transmitter FIFO under run<br>This bit is cleared by writing a '1'.                                                                 |

#### 6.6.4.12. IR RECEIVER INTERRUPT CONTROL REGISTER

| <b>Offset: 0x2C</b> |                   |                | <b>Register Name: IR_RXINT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                         |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                          |
| 31:12               | /                 | /              | /                                                                                                                                                                           |
| 11:8                | R/W               | 0              | RAL<br>RX FIFO Available Received Byte Level for interrupt and DMA request<br>TRIGGER_LEVEL = RAL + 1                                                                       |
| 7:6                 | /                 | /              | /                                                                                                                                                                           |
| 5                   | R/W               | 0              | DRQ_EN<br>RX FIFO DMA Enable<br>0: Disable<br>1: Enable<br>When set to '1', the Receiver FIFO DRQ is asserted if reaching RAL. The DRQ is de-asserted when condition fails. |
| 4                   | R/W               | 0              | RAI_EN                                                                                                                                                                      |

| <b>Offset: 0x2C</b> |                   |                | <b>Register Name: IR_RXINT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                               |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                |
|                     |                   |                | RX FIFO Available Interrupt Enable<br>0: Disable<br>1: Enable<br>When set to '1', the Receiver FIFO IRQ is asserted if reaching RAL. The IRQ is de-asserted when condition fails. |
| 3                   | R/W               | 0              | CRCI_EN<br>Receiver CRC Error Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                         |
| 2                   | R/W               | 0              | RISI_EN<br>Receiver Illegal Symbol Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                    |
| 1                   | R/W               | 0              | RPEI_EN<br>Receiver Packet End Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                        |
| 0                   | R/W               | 0              | ROI_EN<br>Receiver FIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                       |

#### 6.6.4.13. IR RECEIVER STATUS REGISTER

| <b>Offset: 0x30</b> |                   |                | <b>Register Name: IR_RXSTA</b><br><b>Default Value: 0x0000_0000</b>                                                                               |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                |
| 31:13               | /                 | /              | /                                                                                                                                                 |
| 12:8                | R                 | 0              | 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 |

| Offset: 0x30 |            |         | Register Name: IR_RXSTA<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                      |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                |
|              |            |         | ...<br>16: 16 byte available data in RX FIFO                                                                                                                                                                                                                                                               |
| 7:5          | /          | /       | /                                                                                                                                                                                                                                                                                                          |
| 4            | R/W        | 0       | 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'.                                                                                                                                               |
| 3            | R/W        | 0       | CRC<br>Receiver CRC Error Flag<br>0: No CRC failure<br>1: CRC failure<br>This bit is cleared by writing a '1'.                                                                                                                                                                                             |
| 2            | R/W        | 0       | RIS<br>Receiver Illegal Symbol Flag<br>0: No illegal symbols in address, control, data or CRC field<br>1: Illegal symbol in address, control, data or CRC field<br>This bit is cleared by writing a '1'.                                                                                                   |
| 1            | R/W        | 0       | RPE<br>Receiver Packet End Flag<br>0: STO was not detected. In CIR mode, one CIR symbol is receiving or not detected.<br>1: STO field or packet abort symbol (7'b0000,000 and 8'b0000,0000 for MIR and FIR) is detected. In CIR mode, one CIR symbol is received.<br>This bit is cleared by writing a '1'. |
| 0            | R/W        | 0       | 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'.                                                                                                                                                                          |

#### 6.6.4.14. CIR CONFIGURE REGISTER

| Offset: 0x34 |            |         | Register Name: IR_CIR<br>Default Value: 0x0000_1828                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--------|--------------|---|---|---|-----------|---|---|---|------------|---|---|---|------------|---|---|---|------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 31:25        | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 24           | R/W        | 0x0     | SCS2<br>Bit2 of Sample Clock Select for CIR<br>This bit is defined by SCS bits below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 15:8         | R/W        | 0x18    | ITHR<br>Idle Threshold for CIR<br>The Receiver uses it to decide whether the CIR command has been received. If there is no CIR signal on the air, the receiver is staying in IDLE status. One active pulse will bring the receiver from IDLE status to Receiving status. After the CIR is end, the inputting signal will keep the specified level (high or low level) for a long time. The receiver can use this idle signal duration to decide that it has received the CIR command. The corresponding flag is asserted. If the corresponding interrupt is enable, 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. |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 7:2          | R/W        | 0xa     | NTHR<br>Noise Threshold for CIR<br>When the duration of signal pulse (high or low level) is less than NTHR, the pulse is taken as noise and should be discarded by hardware.<br>0: all samples are recorded into RX FIFO<br>1: If the signal is only one sample duration, it is taken as noise and discarded.<br>2: If the signal is less than (<=) two sample duration, it is taken as noise and discarded.<br>...<br>61: if the signal is less than (<=) sixty-one sample duration, it is taken as noise and discarded.                                                                                                                                                                                                                                                                            |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 1:0          | R/W        | 0       | SCS<br>Sample Clock Select for CIR <table border="1" data-bbox="627 1830 1349 2021"> <tr> <th>SCS[2]</th> <th>SCS[1]</th> <th>SCS[0]</th> <th>Sample Clock</th> </tr> <tr> <td>1</td> <td>0</td> <td>0</td> <td>ir_clk/64</td> </tr> <tr> <td>0</td> <td>0</td> <td>1</td> <td>ir_clk/128</td> </tr> <tr> <td>0</td> <td>1</td> <td>0</td> <td>ir_clk/256</td> </tr> <tr> <td>0</td> <td>1</td> <td>1</td> <td>ir_clk/512</td> </tr> </table>                                                                                                                                                                                                                                                                                                                                                        | SCS[2] | SCS[1] | SCS[0] | Sample Clock | 1 | 0 | 0 | ir_clk/64 | 0 | 0 | 1 | ir_clk/128 | 0 | 1 | 0 | ir_clk/256 | 0 | 1 | 1 | ir_clk/512 |
| SCS[2]       | SCS[1]     | SCS[0]  | Sample Clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 1            | 0          | 0       | ir_clk/64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 0            | 0          | 1       | ir_clk/128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 0            | 1          | 0       | ir_clk/256                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |
| 0            | 1          | 1       | ir_clk/512                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |        |        |              |   |   |   |           |   |   |   |            |   |   |   |            |   |   |   |            |

| <b>Offset: 0x34</b>               |                   |                | <b>Register Name: IR_CIR</b>                                                                                                                                                                                                                             |   |   |   |        |   |   |   |          |   |   |   |          |   |   |   |          |
|-----------------------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|--------|---|---|---|----------|---|---|---|----------|---|---|---|----------|
| <b>Default Value: 0x0000_1828</b> |                   |                |                                                                                                                                                                                                                                                          |   |   |   |        |   |   |   |          |   |   |   |          |   |   |   |          |
| <b>Bit</b>                        | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                       |   |   |   |        |   |   |   |          |   |   |   |          |   |   |   |          |
|                                   |                   |                | <table border="1"><tr><td>1</td><td>0</td><td>0</td><td>ir_clk</td></tr><tr><td>1</td><td>0</td><td>1</td><td>Reserved</td></tr><tr><td>1</td><td>1</td><td>0</td><td>Reserved</td></tr><tr><td>1</td><td>1</td><td>1</td><td>Reserved</td></tr></table> | 1 | 0 | 0 | ir_clk | 1 | 0 | 1 | Reserved | 1 | 1 | 0 | Reserved | 1 | 1 | 1 | Reserved |
| 1                                 | 0                 | 0              | ir_clk                                                                                                                                                                                                                                                   |   |   |   |        |   |   |   |          |   |   |   |          |   |   |   |          |
| 1                                 | 0                 | 1              | Reserved                                                                                                                                                                                                                                                 |   |   |   |        |   |   |   |          |   |   |   |          |   |   |   |          |
| 1                                 | 1                 | 0              | Reserved                                                                                                                                                                                                                                                 |   |   |   |        |   |   |   |          |   |   |   |          |   |   |   |          |
| 1                                 | 1                 | 1              | Reserved                                                                                                                                                                                                                                                 |   |   |   |        |   |   |   |          |   |   |   |          |   |   |   |          |

## 6.7. USB OTG

### 6.7.1. Overview

The USB OTG is a Dual-Role Device (DRD) controller, which supports both device and host functions and is full compliant with the On-The-Go Supplement to the USB 2.0 Specification, Revision 1.0a. It can also be configured as a Host-only or Device-only controller, fully compliant with the USB 2.0 Specification.

It can support high-speed (HS, 480-Mbps), full-speed (FS, 12-Mbps), and low-speed (LS, 1.5-Mbps) transfers in Host mode. It can support high-speed (HS, 480-Mbps), and full-speed (FS, 12-Mbps) in Device mode.

It features:

- Comply with USB 2.0 Specification
- Support high-speed (HS, 480-Mbps), full-speed (FS, 12-Mbps), and low-speed (LS, 1.5-Mbps) in host mode and support high-Speed (HS, 480-Mbps), full-Speed (FS, 12-Mbps) in Device mode
- 64-Byte endpoint 0 for control transfer (Endpoint0)
- Support up to 5 user-configurable Endpoints for Bulk , Isochronous, Control and Interrupt bi-directional transfers (Endpoint1, Endpoint2, Endpoint3, Endpoint4, Endpoint5)

### 6.7.2. USB OTG Timing Diagram

Please refer USB2.0 Specification and its On-The-Go Supplement to the USB 2.0 Specification.

## 6.8. USB Host

### 6.8.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 speed through one or more integrated OHCI host controllers.

The USB host controller features:

- Support industry-standard AMBA High-Performance Bus (AHB) and it is fully compliant with the AMBA Specification, Revision 2.0. Supports bus.
- Support 32-bit Little Endian AMBA AHB Slave bus for register access
- Support 32-bit Little Endian AMBA AHB Master bus for memory access.
- 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 the UTMI+ Level 3 interface. The 8-bit bidirectional data buses are used.
- Support only 1 USB Root Port shared between EHCI and OHCI
- The USB HOST system contains two HCI controllers. The HCI controllers are composed of an EHCI controller and an OHCI companion controller.

### 6.8.2. USB Host Block Diagram



### 6.8.3. USB Host Timing Diagram

Please refer USB2.0 Specification and EHCI Specification V1.0.

### 6.8.4. USB Host Register List

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

| Register Name             | Offset | Description                                     |
|---------------------------|--------|-------------------------------------------------|
| EHCI Capability Register  |        |                                                 |
| 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           |
| EHCI Operational Register |        |                                                 |
| 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_CTRLDSSEGMENT           | 0x020  | EHCI 4G Segment Selector Register               |
| E_PERIODICLISTBASE        | 0x024  | EHCI Frame List Base Address Register           |
| E_ASYNCLISTADDR           | 0x028  | EHCI Next Asynchronous List Address Register    |
| E_CONFIGFLAG              | 0x050  | EHCI Configured Flag Register                   |
| E_PORTSC                  | 0x054  | EHCI Port Status/Control Register               |

## 6.8.5. EHCI Register Description

### 6.8.5.1. EHCI IDENTIFICATION REGISTER

| Offset:0x00 |            |         | Register Name: CAPLENGTH<br>Default Value: Implementation Dependent                                                                              |
|-------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/Write | Default | Description                                                                                                                                      |
| 7:0         | R          | 0x10    | <b>CAPLENGTH</b><br>The value in these bits indicates an offset to add to register base to find the beginning of the Operational Register Space. |

### 6.8.5.2. EHCI HOST INTERFACE VERSION NUMBER REGISTER

| <b>Offset: 0x02</b> |                   |                | <b>Register Name: HCIVERSION</b><br><b>Default Value:0x0100</b>                                                                                                                                                                                                                  |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                               |
| 15:0                | R                 | 0x0100         | <p><b>HCIVERSION</b></p> <p>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.</p> |

### 6.8.5.3. EHCI HOST CONTROL STRUCTURAL PARAMETER REGISTER

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: HCSPARAMS</b><br><b>Default Value: Implementation Dependent</b>                                                                                                                                                                                                                                                                                                                     |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:24               | /                 | 0              | <p><b>Reserved</b></p> <p>These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                      |
| 23:20               | R                 | 0              | /                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19:16               | /                 | 0              | <p><b>Reserved.</b></p> <p>These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                     |
| 15:12               | R                 | 0              | <p><b>N_CC</b></p> <p><b>Number of Companion Controller (N_CC)</b></p> <p>This field indicates the number of companion controllers associated with this USB2.0 host controller. A zero in this field indicates there are no companion host controllers. And a value larger than zero in this field indicates there are companion USB1.1 host controller(s).</p> <p>This field will always be '0'.</p> |
| 11:8                | R                 | 0              | <p><b>N_PCC</b></p> <p><b>Number of Port per Companion Controller(N_PCC)</b></p> <p>This field indicates the number of ports supported per companion host controller host controller. It is used to indicate the port routing configuration to system software.</p> <p>This field will always fix with '0'.</p>                                                                                       |
| 7                   | R                 | 0              | <p><b>PRR</b></p> <p><b>Port Routing Rules</b></p> <p>This field indicates the method used by this implementation for</p>                                                                                                                                                                                                                                                                             |

| Offset: 0x04 |                                                                                                                                                                                         |         | Register Name: HCSPARAMS<br>Default Value: Implementation Dependent                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write                                                                                                                                                                              | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|              |                                                                                                                                                                                         |         | <p>how all ports are mapped to companion controllers. The value of this field has the following interpretation:</p> <table border="1"> <thead> <tr> <th>Value</th> <th>Meaning</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on.</td> </tr> <tr> <td>1</td> <td>The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTROUTE array.</td> </tr> </tbody> </table> | Value | Meaning | 0 | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. | 1 | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTROUTE array. |
| Value        | Meaning                                                                                                                                                                                 |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 0            | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 1            | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTROUTE array.                                                                                    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 6:4          | /                                                                                                                                                                                       | 0       | <p><b>Reserved.</b><br/>These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 3:0          | R                                                                                                                                                                                       | 1       | <p><b>N_PORTS</b><br/>This field specifies the number of physical downstream ports implemented on this host controller. The value of this field determines how many port registers are addressable in the Operational Register Space. Valid values are in the range of 0x1 to 0x0f.<br/>This field is always 1.</p>                                                                                                                                                                                                                                                                     |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |

#### 6.8.5.4. EHCI HOST CONTROL CAPABILITY PARAMETER REGISTER

| Offset: 0x08 |            |         | Register Name: HCCPARAMS<br>Default Value: Implementation Dependent                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:16        | /          | 0       | <p><b>Reserved</b><br/>These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:18        | R          | 0       | <p><b>EECP</b><br/><b>EHCI Extended Capabilities Pointer (EECP)</b><br/>This optional field indicates the existence of a capabilities list. A value of 00b indicates no extended capabilities are implemented. A non-zero value in this register indicates the offset in PCI configuration space of the first EHCI extended capability. The pointer value must be 40h or greater if implemented to maintain consistency of the PCI header defined for this class of device.<br/>The value of this field is always '00b'.</p> |

| Offset: 0x08 |            |         | Register Name: HCCPARAMS<br>Default Value: Implementation Dependent                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7:4          | R          |         | <p><b>IST</b><br/><b>Isochronous Scheduling Threshold</b><br/>This field indicates, relative to the current position of the executing host controller, where software can reliably update the isochronous schedule.<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.</p>                        |
| 3            | R          | 0       | <p><b>Reserved</b><br/>These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2            | R          |         | <p><b>ASPC</b><br/><b>Asynchronous Schedule Park Capability</b><br/>If this bit is set to a one, then the host controller supports the park feature for high-speed queue heads in the Asynchronous Schedule. The feature can be disabled or enabled and set to a specific level by using the Asynchronous Schedule Park Mode Enable and Asynchronous Schedule Park Mode Count fields in the USBCMD register.</p>                                                                                                                                                                                 |
| 1            | R          |         | <p><b>PFLF</b><br/><b>Programmable Frame List Flag</b><br/>If this bit is set to a zero, then system software must use a frame list length of 1024 elements with this host controller.The USBCMD register<br/>Frame List Size field is a read-only register and should be set to zero.<br/>If set to 1,then system software can specify and use the frame list in the<br/>USBCMD register Frame List Size field to configure the host controller.<br/>The frame list must always aligned on a 4K page boundary.This requirement ensures that the frame list is always physically contiguous.</p> |
| 0            | R          | 0       | <p><b>Reserved</b><br/>These bits are reserved for future use and should return a value of zero when read.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

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

#### 6.8.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       | <p><b>Reserved</b></p> <p>These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |                            |      |          |      |               |      |               |
| 23:16        | R/W                        | 0x08    | <p><b>ITC</b><br/><b>Interrupt Threshold Control</b></p> <p>The value in this field is used by system software to select the maximum rate at which the host controller will issue interrupts. The only valid values are defined below:</p> <table border="1"> <thead> <tr> <th>Value</th> <th>Minimum Interrupt Interval</th> </tr> </thead> <tbody> <tr> <td>0x00</td> <td>Reserved</td> </tr> <tr> <td>0x01</td> <td>1 micro-frame</td> </tr> <tr> <td>0x02</td> <td>2 micro-frame</td> </tr> </tbody> </table> | Value | Minimum Interrupt Interval | 0x00 | Reserved | 0x01 | 1 micro-frame | 0x02 | 2 micro-frame |
| Value        | Minimum Interrupt Interval |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |                            |      |          |      |               |      |               |
| 0x00         | Reserved                   |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |                            |      |          |      |               |      |               |
| 0x01         | 1 micro-frame              |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |                            |      |          |      |               |      |               |
| 0x02         | 2 micro-frame              |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |                            |      |          |      |               |      |               |

| <b>Offset: 0x10</b> |                                         |                | <b>Register Name: USBCMD</b><br><b>Default Value: 0x00080000(0x00080B00 if Asynchronous Schedule Park Capability is a one)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |               |      |                                         |      |                     |      |                     |      |                     |
|---------------------|-----------------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------|------|-----------------------------------------|------|---------------------|------|---------------------|------|---------------------|
| <b>Bit</b>          | <b>Read/Write</b>                       | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |               |      |                                         |      |                     |      |                     |      |                     |
|                     |                                         |                | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0x04</td><td>4 micro-frame</td></tr> <tr><td>0x08</td><td>8 micro-frame(default, equates to 1 ms)</td></tr> <tr><td>0x10</td><td>16 micro-frame(2ms)</td></tr> <tr><td>0x20</td><td>32 micro-frame(4ms)</td></tr> <tr><td>0x40</td><td>64 micro-frame(8ms)</td></tr> </table>                                                                                                                                                                                                                                                                           | 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) |
| 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)                     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |               |      |                                         |      |                     |      |                     |      |                     |
|                     |                                         |                | <p>Any other value in this register yields undefined results.<br/> The default value in this field is 0x08 .<br/> Software modifications to this bit while HC Halted bit is equal to zero results in undefined behavior.</p>                                                                                                                                                                                                                                                                                                                                                                                                      |      |               |      |                                         |      |                     |      |                     |      |                     |
| 15:12               | /                                       | 0              | <p><b>Reserved</b><br/> These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |               |      |                                         |      |                     |      |                     |      |                     |
| 11                  | R/W or R                                | 0              | <p><b>ASPME</b><br/> <b>Asynchronous Schedule Park Mode Enable(OPTIONAL)</b><br/> If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit defaults to a 1 and is R/W. Otherwise the bit must be a zero and is Read Only. Software uses this bit to enable or disable Park mode. When this bit is one, Park mode is enabled. When this bit is zero, Park mode is disabled.</p>                                                                                                                                                                                                                   |      |               |      |                                         |      |                     |      |                     |      |                     |
| 10                  | /                                       | 0              | <p><b>Reserved</b><br/> These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |               |      |                                         |      |                     |      |                     |      |                     |
| 9:8                 | R/W or R                                | 0              | <p><b>ASPMC</b><br/> <b>Asynchronous Schedule Park Mode Count(OPTIONAL)</b><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.<br/> Valid value are 0x1 to 0x3. Software must not write a zero to this bit when Park Mode Enable is a one as it will result in undefined behavior.</p> |      |               |      |                                         |      |                     |      |                     |      |                     |
| 7                   | R/W                                     | 0              | <p><b>LHCR</b><br/> <b>Light Host Controller Reset(OPTIONAL)</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |               |      |                                         |      |                     |      |                     |      |                     |

| <b>Offset: 0x10</b> |                                                                    |         | <b>Register Name: USBCMD</b><br><b>Default Value: 0x00080000(0x00080B00 if Asynchronous Schedule Park Capability is a one)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |   |                                           |   |                                                                    |
|---------------------|--------------------------------------------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|---|-------------------------------------------|---|--------------------------------------------------------------------|
| Bit                 | Read/Write                                                         | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |         |   |                                           |   |                                                                    |
|                     |                                                                    |         | <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><b>IAAD</b><br/><b>Interrupt on Async Advance Doorbell</b></p> <p>This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell.</p> <p>When the host controller has evicted all appropriate cached schedule state, it sets the Interrupt on Async Advance status bit in the USBSTS. If the Interrupt on Async Advance Enable bit in the USBINTR register is a one then the host controller will assert an interrupt at the next interrupt threshold.</p> <p>The host controller sets this bit to a zero after it has set the Interrupt on Async Advance status bit in the USBSTS register to a one.</p> <p>Software should not write a one to this bit when the asynchronous schedule is disabled. Doing so will yield undefined results.</p> |           |         |   |                                           |   |                                                                    |
| 5                   | R/W                                                                | 0       | <p><b>ASE</b><br/><b>Asynchronous Schedule Enable</b></p> <p>This bit controls whether the host controller skips processing the Asynchronous Schedule. Values mean:</p> <table border="1"> <tr> <th>Bit Value</th><th>Meaning</th></tr> <tr> <td>0</td><td>Do not process the Asynchronous Schedule.</td></tr> <tr> <td>1</td><td>Use the ASYNLISTADDR register to access the Asynchronous Schedule.</td></tr> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                    | Bit Value | Meaning | 0 | Do not process the Asynchronous Schedule. | 1 | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |
| Bit Value           | Meaning                                                            |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |   |                                           |   |                                                                    |
| 0                   | Do not process the Asynchronous Schedule.                          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |   |                                           |   |                                                                    |
| 1                   | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |   |                                           |   |                                                                    |
| 4                   | R/W                                                                | 0       | <b>PSE</b><br><b>Periodic Schedule Enable</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |         |   |                                           |   |                                                                    |

| <b>Offset: 0x10</b> |                                                                    |                | <b>Register Name: USBCMD</b><br><b>Default Value: 0x00080000(0x00080B00 if Asynchronous Schedule Park Capability is a one)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |         |     |                                       |     |                                                                    |     |                                                           |     |          |
|---------------------|--------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|-----|---------------------------------------|-----|--------------------------------------------------------------------|-----|-----------------------------------------------------------|-----|----------|
| <b>Bit</b>          | <b>Read/Write</b>                                                  | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |         |     |                                       |     |                                                                    |     |                                                           |     |          |
|                     |                                                                    |                | <p>This bit controls whether the host controller skips processing the Periodic Schedule. Values mean:</p> <table border="1"> <thead> <tr> <th>Bit Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not process the Periodic Schedule.</td></tr> <tr> <td>1</td><td>Use the PERIODICLISTBASE register to access the Periodic Schedule.</td></tr> </tbody> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                  | Bit Value | Meaning | 0   | Do not process the Periodic Schedule. | 1   | Use the PERIODICLISTBASE register to access the Periodic Schedule. |     |                                                           |     |          |
| Bit Value           | Meaning                                                            |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |     |                                       |     |                                                                    |     |                                                           |     |          |
| 0                   | Do not process the Periodic Schedule.                              |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |     |                                       |     |                                                                    |     |                                                           |     |          |
| 1                   | Use the PERIODICLISTBASE register to access the Periodic Schedule. |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |     |                                       |     |                                                                    |     |                                                           |     |          |
| 3:2                 | R/W or R                                                           | 0              | <p><b>FLS</b><br/><b>Frame List Size</b></p> <p>This field is R/W only if Programmable Frame List Flag in the HCCPARAMS registers is set to a one. This field specifies the size of the</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.</p> <p>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><b>HCR</b><br/><b>Host Controller Reset</b></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</p>       |           |         |     |                                       |     |                                                                    |     |                                                           |     |          |

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: USBCMD</b><br><b>Default Value: 0x00080000(0x00080B00 if Asynchronous Schedule Park Capability is a one)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                     |                   |                | <p>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><b>RS</b><br/><b>Run/Stop</b></p> <p>When set to a 1, the Host Controller proceeds with execution of the schedule. When set to 0, the Host Controller completes the current and any actively pipelined transactions on the USB and then halts. The Host Controller must halt within 16 micro-frames after software clears this bit.</p> <p>The HC Halted bit indicates when the Host Controller has finished its pending pipelined transactions and has entered the stopped state.</p> <p>Software must not write a one to this field unless the Host Controller is in the Halt State.</p> <p>The default value is 0x0.</p> |

#### 6.8.5.7. EHCI USB STATUS REGISTER

| <b>Offset: 0x14</b> |                   |                | <b>Register Name: USBSTS</b><br><b>Default Value: 0x00001000</b>                                                                                                                                                                                                                                                                                                          |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                        |
| 31:16               | /                 | 0              | <p><b>Reserved</b></p> <p>These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                          |
| 15                  | R                 | 0              | <p><b>ASS</b><br/><b>Asynchronous Schedule Status</b></p> <p>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</p> |

| Offset: 0x14 |            |         | Register Name: USBSTS<br>Default Value: 0x00001000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              |            |         | 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       | <b>PSS</b><br><b>Periodic Schedule Status</b><br>The bit reports the current real status of the Periodic Schedule. If this bit is a zero then the status of the Periodic Schedule is disabled. If this bit is a one then the status of the Periodic Schedule is enabled. The Host Controller is not required to <i>immediately</i> disable or enable the Periodic Schedule when software transitions the <i>Periodic Schedule Enable</i> bit in the USBCMD register. When this bit and the <i>Periodic Schedule Enable</i> bit are the same value, the Periodic Schedule is either enabled (1) or disabled (0). |
| 13           | R          | 0       | <b>RECL</b><br><b>Reclamation</b><br>This is a read-only status bit, which is used to detect an empty asynchronous schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12           | R          | 1       | <b>HCH</b><br><b>HC Halted</b><br>This bit is a zero whenever the Run/Stop bit is a one. The Host Controller Sets this bit to one after it has stopped executing as a result of the Run/Stop bit being set to 0, either by software or by the Host Controller Hardware (e.g. internal error).<br>The default value is '1'.                                                                                                                                                                                                                                                                                      |
| 11:6         | /          | 0       | <b>Reserved</b><br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5            | R/WC       | 0       | <b>IAA</b><br><b>Interrupt on Async Advance</b><br>System software can force the host controller to issue an interrupt the next time the host controller advances the asynchronous schedule by writing a one to the Interrupt on Async Advance Doorbell bit in the USBCMD register. This status bit indicates the assertion of that interrupt source.                                                                                                                                                                                                                                                           |
| 4            | R/WC       | 0       | <b>HSE</b><br><b>Host System Error</b><br>The Host Controller set this bit to 1 when a serious error occurs during a host system access involving the Host                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x14 |                   |                | <b>Register Name: USBSTS</b><br><b>Default Value: 0x00001000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>   | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|              |                   |                | 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              | <p><b>FLR</b><br/><b>Frame List Rollover</b></p> <p>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.</p>                                                            |
| 2            | R/WC              | 0              | <p><b>PCD</b><br/><b>Port Change Detect</b></p> <p>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.</p> |
| 1            | R/WC              | 0              | <p><b>ERRINT</b><br/><b>USB Error Interrupt(USBERRINT)</b></p> <p>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.</p> <p>This bit and USBINT bit are set.</p>                                                                                                                                                                                                          |
| 0            | R/WC              | 0              | <p><b>USBINT</b><br/><b>USB Interrupt(USBINT)</b></p> <p>The Host Controller sets this bit to a one on the completion of a USB transaction, which results in the retirement of a Transfer Descriptor that had its IOC bit set.</p> <p>The Host Controller also sets this bit to 1 when a short packet is detected</p> <p>(actual number of bytes received was less than the expected number of bytes)</p>                                                                                                                                    |

#### 6.8.5.8. EHCI USB INTERRUPT ENABLE REGISTER

| Offset: 0x18 |            |         | Register Name: USBINTR<br>Default Value: 0x00000000                                                                                                                                                                                                                                                                    |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                            |
| 31:6         | /          | 0       | <b>Reserved</b><br>These bits are reserved and should be zero.                                                                                                                                                                                                                                                         |
| 5            | R/W        | 0       | <b>IAAE</b><br><b>Interrupt on Async Advance Enable</b><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       | <b>HSEE</b><br><b>Host System Error Enable</b><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       | <b>FLRE</b><br><b>Frame List Rollover Enable</b><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       | <b>PCIE</b><br><b>Port Change Interrupt Enable</b><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       | <b>EIE</b><br><b>USB Error Interrupt Enable</b><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       | <b>UIE</b><br><b>USB Interrupt Enable</b><br>When this bit is 1, and the USBINT bit in the USBSTS register                                                                                                                                                                                                             |

| <b>Offset: 0x18</b> |                   |                | <b>Register Name: USBINTR</b><br><b>Default Value: 0x00000000</b>                                                                                                  |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                 |
|                     |                   |                | <p>is 1, the host controller will issue an interrupt at the next interrupt threshold.</p> <p>The interrupt is acknowledged by software clearing the USBINT bit</p> |

#### 6.8.5.9. EHCI FRAME INDEX REGISTER

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

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

#### 6.8.5.10. EHCI PERIODIC FRAME LIST BASE ADDRESS REGISTER

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: PERIODICLISTBASE</b><br><b>Default Value: Undefined</b>                                   |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                          |
| 31:12               | R/W               |                | <p><b>BADDR</b><br/><b>Base Address</b></p> <p>These bits correspond to memory address signals [31:12],</p> |

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: PERIODICLISTBASE</b><br><b>Default Value: Undefined</b>                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                     |                   |                | <p>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. 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><b>Reserved</b></p> <p>Must be written as 0x0 during runtime, the values of these bits are undefined.</p>                                                                                                                                                                                                                                                                                                                                                                                                   |

Note: Writes must be Dword Writes.

#### 6.8.5.11. EHCI CURRENT ASYNCHRONOUS LIST ADDRESS REGISTER

| <b>Offset: 0x28</b> |                   |                | <b>Register Name: ASYNCLISTADDR</b><br><b>Default Value: Undefined</b>                                                                                                                                                   |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                       |
| 31:5                | R/W               |                | <p><b>LP</b></p> <p><b>Link Pointer (LP)</b></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><b>Reserved</b></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.

#### 6.8.5.12. EHCI CONFIGURE FLAG REGISTER

| Offset: 0x50 |                                                                                                            |         | Register Name: CONFIGFLAG<br>Default Value: 0x00000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                                                                                            |   |                                                                             |
|--------------|------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------|
| Bit          | Read/Write                                                                                                 | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                                                                                                            |   |                                                                             |
| 31:1         | /                                                                                                          | 0       | <b>Reserved</b><br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         |   |                                                                                                            |   |                                                                             |
| 0            | R/W                                                                                                        | 0       | <b>CF</b><br><b>Configure Flag(CF)</b><br>Host software sets this bit as the last action in its process of configuring the Host Controller. This bit controls the default port-routing control logic as follow:<br><table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Port routing control logic default-routs each port to an implementation dependent classic host controller.</td></tr> <tr> <td>1</td><td>Port routing control logic default-routs all ports to this host controller.</td></tr> </tbody> </table> <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.

#### 6.8.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       | <b>Reserved</b><br>These bits are reserved for future use and should return a value of zero when read.                                                                                                                                                    |
| 21           | R/W        | 0       | <b>WDE</b><br><b>Wake on Disconnect Enable(WKDSCNNT_E)</b><br>Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events.<br>This field is zero if Port Power is zero.<br>The default value in this field is '0'. |
| 20           | R/W        | 0       | <b>WCE</b><br><b>Wake on Connect Enable(WKCNNT_E)</b><br>Writing this bit to a one enable the port to be sensitive to                                                                                                                                     |

| <b>Offset: 0x54</b> |                   |                                              | <b>Register Name: PORTSC</b><br><b>Default Value: 0x00002000(w/PPC set to one);0x00003000(w/PPC set to a zero)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |           |                |     |     |                                           |     |         |                                           |     |         |                                              |
|---------------------|-------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|----------------|-----|-----|-------------------------------------------|-----|---------|-------------------------------------------|-----|---------|----------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b>                               | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |           |                |     |     |                                           |     |         |                                           |     |         |                                              |
|                     |                   |                                              | 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                                            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |           |                |     |     |                                           |     |         |                                           |     |         |                                              |
| 15:14               | R/W               | 0                                            | <b>Reserved</b><br>These bits are reserved for future use and should return a value of zero when read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |           |                |     |     |                                           |     |         |                                           |     |         |                                              |
| 13                  | R/W               | 1                                            | <b>PO</b><br><b>Port Owner</b><br>This bit unconditionally goes to a 0b when the Configured bit in the CONFIGFLAG register makes a 0b to 1b transition. This bit unconditionally goes to 1b whenever the Configured bit is zero.<br>System software uses this field to release ownership of the port to selected host controller (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that a companion host controller owns and controls the port.<br>Default Value = 1b.                                                                                                                                                                            |                 |           |                |     |     |                                           |     |         |                                           |     |         |                                              |
| 12                  | /                 | 0                                            | <b>Reserved</b><br>These bits are reserved for future use and should return a value of zero when read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |           |                |     |     |                                           |     |         |                                           |     |         |                                              |
| 11:10               | R                 | 0                                            | <b>LS</b><br><b>Line Status</b><br>These bits reflect the current logical levels of the D+ (bit11) and D- (bit10) signal lines. These bits are used for detection of low-speed USB devices prior to port reset and enable sequence. This read only field is valid only when the port enable bit is zero and the current connect status bit is set to a one.<br>The encoding of the bits are:<br><table border="1"> <tr> <th>Bit[11:10]<br/>1</th><th>USB State</th><th>Interpretation</th></tr> <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> </table> | Bit[11:10]<br>1 | USB State | Interpretation | 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. |
| Bit[11:10]<br>1     | USB State         | Interpretation                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |           |                |     |     |                                           |     |         |                                           |     |         |                                              |
| 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. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |           |                |     |     |                                           |     |         |                                           |     |         |                                              |

| <b>Offset: 0x54</b>   |                   |                                           | <b>Register Name: PORTSC</b><br><b>Default Value: 0x00002000(w/PPC set to one);0x00003000(w/PPC set to a zero)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |                       |           |                                           |
|-----------------------|-------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|-----------------------|-----------|-------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b>                            | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |                       |           |                                           |
|                       |                   |                                           | <table border="1"> <tr> <td>11b</td> <td>Undefined</td> <td>Not Low-speed device, perform EHCI reset.</td> </tr> </table> <p>This value of this field is undefined if Port Power is zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  | 11b                   | Undefined | Not Low-speed device, perform EHCI reset. |
| 11b                   | Undefined         | Not Low-speed device, perform EHCI reset. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |                       |           |                                           |
| 9                     | /                 | 0                                         | <p><b>Reserved</b><br/>This bit is reserved for future use, and should return a value of zero when read.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |                       |           |                                           |
| 8                     | R/W               | 0                                         | <p><b>PR</b><br/><b>Port Reset</b><br/>1=Port is in Reset. 0=Port is not in Reset. Default value = 0.<br/>When software writes a one to this bit (from a zero), the bus reset sequence as defined in the USB Specification Revision 2.0 is started. Software writes a zero to this bit to terminate the bus reset sequence. Software must keep this bit at a one long enough to ensure the reset sequence, as specified in the USB Specification Revision 2.0, completes. Notes: when software writes this bit to a one , it must also write a zero to the Port Enable bit.<br/>Note that when software writes a zero to this bit there may be a delay before the bit status changes to a zero. The bit status will not read as a zero until after the reset has completed. If the port is in high-speed mode after reset is complete, the host controller will automatically enable this port (e.g. set the Port Enable bit to a one). A host controller must terminate the reset and stabilize the state of the port within 2 milliseconds of software transitioning this bit from a one to a zero. For example: if the port detects that the attached device is high-speed during reset, then the host controller must have the port in the enabled state with 2ms of software writing this bit to a zero.<br/>The HC Halted bit in the USBSTS register should be a zero before software attempts to use this bit. The host controller may hold Port Reset asserted to a one when the HC Halted bit is a one.<br/>This field is zero if Port Power is zero.</p> |  |  |                       |           |                                           |
| 7                     | R/W               | 0                                         | <p><b>SUSPEND</b><br/><b>Suspend</b><br/>Port Enabled Bit and Suspend bit of this register define the port states as follows:</p> <table border="1"> <tr> <td>Bits[Port<br/>Suspend]</td> <td>Enables,</td> <td>Port State</td> </tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  | Bits[Port<br>Suspend] | Enables,  | Port State                                |
| Bits[Port<br>Suspend] | Enables,          | Port State                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |                       |           |                                           |

| <b>Offset: 0x54</b> |                   |                | <b>Register Name: PORTSC</b><br><b>Default Value: 0x00002000(w/PPC set to one);0x00003000(w/PPC set to a zero)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |         |    |        |    |         |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------|----|--------|----|---------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |         |    |        |    |         |
|                     |                   |                | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>0x</td><td>Disable</td></tr> <tr> <td>10</td><td>Enable</td></tr> <tr> <td>11</td><td>Suspend</td></tr> </table> <p>When in suspend state, downstream propagation of data is blocked on this port, except for port reset. The blocking occurs at the end of the current transaction, if a transaction was in progress when this bit was written to 1. In the suspend state, the port is sensitive to resume detection. Note that the bit status does not change until the port is suspend and that there may be a delay in suspending a port if there is a transaction currently in progress on the USB.</p> <p>A write of zero to this bit is ignored by the host controller. The host controller will unconditionally set this bit to a zero when:</p> <ul style="list-style-type: none"> <li>1) Software sets the Force Port Resume bit to a zero(from a one).</li> <li>2) Software sets the Port Reset bit to a one(from a zero).</li> </ul> <p>If host software sets this bit to a one when the port is not enabled(i.e. Port enabled bit is a zero), the results are undefined.</p> <p>This field is zero if Port Power is zero.</p> <p>The default value in this field is '0'.</p> | 0x | Disable | 10 | Enable | 11 | Suspend |
| 0x                  | Disable           |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |         |    |        |    |         |
| 10                  | Enable            |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |         |    |        |    |         |
| 11                  | Suspend           |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |         |    |        |    |         |
| 6                   | R/W               | 0              | <p><b>FPR</b><br/><b>Force Port Resume</b></p> <p>1 = Resume detected/driven on port. 0 = No resume (K-state) detected/ driven on port. Default value = 0.</p> <p>This functionality defined for manipulating this bit depends on the value of the Suspend bit. For example, if the port is not suspend and software transitions this bit to a one, then the effects on the bus are undefined.</p> <p>Software sets this bit to 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.</p> <p>Note that when the EHCI controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0. The resume signaling (Full-speed 'K') is driven on the port as long as this remains a</p>                                                                                                                                                                           |    |         |    |        |    |         |

| <b>Offset: 0x54</b> |                   |                | <b>Register Name: PORTSC</b><br><b>Default Value: 0x00002000(w/PPC set to one);0x00003000(w/PPC set to a zero)</b>                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                     |                   |                | <p>one. Software must appropriately time the Resume and set this bit to a zero when the appropriate amount of time has elapsed. Writing a zero (from one) causes the port to return high-speed mode (forcing the bus below the port into a high-speed idle). This bit will remain a one until the port has switched to high-speed idle. The host controller must complete this transition within 2 milliseconds of software setting this bit to a zero.</p> <p>This field is zero if Port Power is zero.</p> |
| 5                   | R/WC              | 0              | <p><b>OCC</b><br/><b>Over-current Change</b></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><b>OCA</b><br/><b>Over-current Active</b></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><b>PEDC</b><br/><b>Port Enable/Disable Change</b></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><b>PED</b><br/><b>Port Enabled/Disabled</b></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</p>  |

| <b>Offset: 0x54</b> |                   |                | <b>Register Name: PORTSC</b><br><b>Default Value: 0x00002000(w/PPC set to one);0x00003000(w/PPC set to a zero)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                     |                   |                | <p>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><b>CSC</b><br/><b>Connect Status Change</b><br/>1=Change in Current Connect Status, 0=No change, Default=0.</p> <p>Indicates a change has occurred in the port's Current Connect Status. The host controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status changes twice before system software has cleared the changed condition, hub hardware will be "setting" an already-set bit. Software sets this bit to 0 by writing a 1 to it.</p> <p>This field is zero if Port Power is zero.</p> |
| 0                   | R                 | 0              | <p><b>CCS</b><br/><b>Current Connect Status</b><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.</p> <p>This field is zero if Port Power zero.</p>                                                                                                                                                                                                                         |

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

### 6.8.6. OHCI Register List

| <b>Register Name</b>                             | <b>Offset</b> | <b>Description</b>         |
|--------------------------------------------------|---------------|----------------------------|
| <b>The Control and Status Partition Register</b> |               |                            |
| <b>HcRevision</b>                                | 0x400         | HcRevision Register        |
| <b>HcCtl</b>                                     | 0x404         | HcControl Register         |
| <b>HcCommandStatus</b>                           | 0x408         | HcCommandStatus Register   |
| <b>HcInterruptStatus</b>                         | 0x40c         | HcInterruptStatus Register |
| <b>HcInterruptEnable</b>                         | 0x410         | HcInterruptEnable Register |

|                                          |       |                             |
|------------------------------------------|-------|-----------------------------|
| <b>HcInterruptDisable</b>                | 0x414 | HcInterruptDisable Register |
| <b>Memory Pointer Partition Register</b> |       |                             |
| <b>HcHCCA</b>                            | 0x418 | HcHCCA Register             |
| <b>PCED</b>                              | 0x41c | HcPeriodCurrentED Register  |
| <b>CHED</b>                              | 0x420 | HcControlHeadED Register    |
| <b>CCED</b>                              | 0x424 | HcControlCurrentED Register |
| <b>BHED</b>                              | 0x428 | HcBulkHeadED Register       |
| <b>BCED</b>                              | 0x42c | HcBulkCurrentED Register    |
| <b>HcDoneHead</b>                        | 0x430 | HcDoneHead Register         |
| <b>Frame Counter Partition Register</b>  |       |                             |
| <b>HcFmInterval</b>                      | 0x434 | HcFmInterval Register       |
| <b>HcFmRemaining</b>                     | 0x438 | HcFmRemaining Register      |
| <b>HcFmNumber</b>                        | 0x43c | HcFmNumber Register         |
| <b>HcPeriodicStatus</b>                  | 0x440 | HcPeriodicStart Register    |
| <b>HcLSThreshold</b>                     | 0x444 | HcLSThreshold Register      |
| <b>Root Hub Partition Register</b>       |       |                             |
| <b>HcRhDescriptorA</b>                   | 0x448 | HcRhDescriptorA Register    |
| <b>HcRhDescriptorB</b>                   | 0x44c | HcRhDescriptorB Register    |
| <b>HcRhStatus</b>                        | 0x450 | HcRhStatus Register         |
| <b>HcRhPortStatus</b>                    | 0x454 | HcRhPortStatus Register     |

## 6.8.7. OHCI Register Description

### 6.8.7.1. HCREVISION REGISTER

| Offset: 0x400 |            |    |         | Register Name: HcRevision<br>Default Value:0x10                                                                                                                                                                                                                                                              |
|---------------|------------|----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                                                                  |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                                                              |
| 31:8          |            |    |         | <b>Reserved</b>                                                                                                                                                                                                                                                                                              |
| 7:0           | R          | R  | 0x10    | <b>Revision</b><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. |

### 6.8.7.2. HCCONTROL REGISTER

| Offset: 0x404 |                |     |         | Register Name: HcRevision<br>Default Value:0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |          |         |           |         |                |         |            |
|---------------|----------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|---------|-----------|---------|----------------|---------|------------|
| Bit           | Read/Write     |     | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |          |         |           |         |                |         |            |
| HCD           | HC             |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |         |           |         |                |         |            |
| 31:11         |                |     |         | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |         |           |         |                |         |            |
| 10            | R/W            | R   | 0x0     | <p><b>RemoteWakeupEnable</b><br/>           This bit is used by HCD to enable or disable the remote wakeup feature upon the detection of upstream resume signaling. When this bit is set and the <b>ResumeDetected</b> bit in <b>HcInterruptStatus</b> is set, a remote wakeup is signaled to the host system. Setting this bit has no impact on the generation of hardware interrupt.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |          |         |           |         |                |         |            |
| 9             | R/W            | R/W | 0x0     | <p><b>RemoteWakeupConnected</b><br/>           This bit indicates whether HC supports remote wakeup signaling. If remote wakeup is supported and used by the system, it is the responsibility of system firmware to set this bit during POST. HC clear the bit upon a hardware reset but does not alter it upon a software reset. Remote wakeup signaling of the host system is host-bus-specific and is not described in this specification.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |          |         |           |         |                |         |            |
| 8             | R/W            | R   | 0x0     | <p><b>InterruptRouting</b><br/>           This bit determines the routing of interrupts generated by events registered in <b>HcInterruptStatus</b>. If clear, all interrupt are routed to the normal host bus interrupt mechanism. If set interrupts are routed to the System Management Interrupt. HCD clears this bit upon a hardware reset, but it does not alter this bit upon a software reset. HCD uses this bit as a tag to indicate the ownership of HC.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |          |         |           |         |                |         |            |
| 7:6           | R/W            | R/W | 0x0     | <p><b>HostControllerFunctionalState for USB</b></p> <table border="1"> <tr> <td>00<br/>b</td><td>USBReset</td></tr> <tr> <td>01<br/>b</td><td>USBResume</td></tr> <tr> <td>10<br/>b</td><td>USBOperational</td></tr> <tr> <td>11<br/>b</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 StartFrame field of <b>HcInterruptStatus</b>.</p> <p>This field may be changed by HC only when in the USBSUSPEND state. HC may move from the USBSUSPEND state to the USBRESUME state after detecting the resume signaling from a downstream port.</p> <p>HC enters USBSUSPEND after a software reset, whereas it enters USBRESET after a hardware reset. The latter also resets the Root Hub and asserts subsequent reset signaling to downstream ports.</p> | 00<br>b | USBReset | 01<br>b | USBResume | 10<br>b | USBOperational | 11<br>b | USBSuspend |
| 00<br>b       | USBReset       |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |         |           |         |                |         |            |
| 01<br>b       | USBResume      |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |         |           |         |                |         |            |
| 10<br>b       | USBOperational |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |         |           |         |                |         |            |
| 11<br>b       | USBSuspend     |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |         |           |         |                |         |            |
|               |                |     |         | <p><b>BulkListEnable</b><br/>           This bit is set to enable the processing of the Bulk list in the next Frame. If cleared by HCD, processing of the Bulk list does not occur after the next SOF. HC checks this bit whenever it determines to process the list. When disabled, HCD may modify the list. If <b>HcBulkCurrentED</b> is pointing to an ED to be removed,</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |         |           |         |                |         |            |

| 5    | R/W                                     | R | 0x0 | HCD must advance the pointer by updating <i>HcBulkCurrentED</i> before re-enabling processing of the list.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |                                         |   |     |   |     |   |     |   |     |
|------|-----------------------------------------|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------|---|-----|---|-----|---|-----|---|-----|
| 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 <i>HcControlCurrentED</i> is pointing to an ED to be removed, HCD must advance the pointer by updating <i>HcControlCurrentED</i> before re-enabling processing of the list.</p>                                                                                                                                                                                                                                                                                                                           |      |                                         |   |     |   |     |   |     |   |     |
| 3    | R/W                                     | R | 0x0 | <p><b>IsochronousEnable</b></p> <p>This bit is used by HCD to enable/disable processing of isochronous EDs. While processing the periodic list in a Frame, HC checks the status of this bit when it finds an Isochronous ED (F=1). If set (enabled), HC continues processing the EDs. If cleared (disabled), HC halts processing of the periodic list (which now contains only isochronous EDs) and begins processing the Bulk/Control lists.</p> <p>Setting this bit is guaranteed to take effect in the next Frame (not the current Frame).</p>                                                                                                                                                                                                                                                                               |      |                                         |   |     |   |     |   |     |   |     |
| 2    | R/W                                     | R | 0x0 | <p><b>PeriodicListEnable</b></p> <p>This bit is set to enable the processing of periodic list in the next Frame. If cleared by HCD, processing of the periodic list does not occur after the next SOF. HC must check this bit before it starts processing the list.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |                                         |   |     |   |     |   |     |   |     |
| 1:0  | R/W                                     | R | 0x0 | <p><b>ControlBulkServiceRatio</b></p> <p>This specifies the service ratio between Control and Bulk EDs. Before processing any of the nonperiodic lists, HC must compare the ratio specified with its internal count on how many nonempty Control EDs have been processed, in determining whether to continue serving another Control ED or switching to Bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, HCD is responsible for restoring this value.</p> <table border="1"> <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> <p>The default value is 0x0.</p> | 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                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |                                         |   |     |   |     |   |     |   |     |

### 6.8.7.3. HCCOMMANDSTATUS REGISTER

| Offset: 0x408 |            |    |         | Register Name: HcCommandStatus<br>Default Value:0x0                                                                                                                                                                                                      |
|---------------|------------|----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                              |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                          |
| 31:18         |            |    |         | <p><b>Reserved</b></p> <p><b>SchedulingOverrunCount</b></p> <p>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</p> |
|               |            |    |         |                                                                                                                                                                                                                                                          |

|       |     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16 | R   | R/W | 0x0 | <b>SchedulingOverrun</b> in <i>HcInterruptStatus</i> has already been set. This is used by HCD to monitor any persistent scheduling problem.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15:4  |     |     |     | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 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 <b>OwnershipChange</b> field in <i>HcInterruptStatus</i>. After the changeover, this bit is cleared and remains so until the next request from OS HCD.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2     | R/W | R/W | 0x0 | <p><b>BulkListFilled</b><br/> This bit is used to indicate whether there are any TDs on the Bulk list. It is set by HCD whenever it adds a TD to an ED in the Bulk list. When HC begins to process the head of the Bulk list, it checks BLF. As long as <b>BulkListFilled</b> is 0, HC will not start processing the Bulk list. If <b>BulkListFilled</b> is 1, HC will start processing the Bulk list and will set <b>BFL</b> to 0. If HC finds a TD on the list, then HC will set <b>BulkListFilled</b> to 1 causing the Bulk list processing to continue. If no TD is found on the Bulk list, and if HCD does not set <b>BulkListFilled</b>, then <b>BulkListFilled</b> will still be 0 when HC completes processing the Bulk list and Bulk list processing will stop.</p>                                                         |
| 1     | R/W | R/W | 0x0 | <p><b>ControlListFilled</b><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. When HC begins to process the head of the Control list, it checks <b>CLF</b>. As long as <b>ControlListFilled</b> is 0, HC will not start processing the Control list. If <b>CLF</b> is 1, HC will start processing the Control list and will set <b>ControlListFilled</b> to 0. If HC finds a TD on the list, then HC will set <b>ControlListFilled</b> to 1 causing the Control list processing to continue. If no TD is found on the Control list, and if the HCD does not set <b>ControlListFilled</b>, then <b>ControlListFilled</b> will still be 0 when HC completes processing the Control list and Control list processing will stop.</p> |
| 0     | R/W | R/E | 0x0 | <p><b>HostControllerReset</b><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 <i>HcControl</i>, 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>                                                                                                                                                                                                        |

#### 6.8.7.4. HCINTERRUPTSTATUS REGISTER

| Offset: 0x40c |            |    |         | Register Name: <i>HcInterruptStatus</i><br>Default Value:0x0 |
|---------------|------------|----|---------|--------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                  |
|               | HCD        | HC |         |                                                              |
| 31:7          |            |    |         | <b>Reserved</b>                                              |

|   |     |     |     |                                                                                                                                                                                                                                                                                                           |
|---|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | R/W | R/W | 0x0 | <b>RootHubStatusChange</b><br>This bit is set when the content of <i>HcRhStatus</i> or the content of any of <i>HcRhPortStatus[NumberofDownstreamPort]</i> has changed.                                                                                                                                   |
| 5 | R/W | R/W | 0x0 | <b>FrameNumberOverflow</b><br>This bit is set when the MSb of <i>HcFmNumber</i> (bit 15) changes value, from 0 to 1 or from 1 to 0, and after <i>HccaFrameNumber</i> has been updated.                                                                                                                    |
| 4 | R/W | R/W | 0x0 | <b>UnrecoverableError</b><br>This bit is set when HC detects a system error not related to USB. HC should not proceed with any processing nor signaling before the system error has been corrected. HCD clears this bit after HC has been reset.                                                          |
| 3 | R/W | R/W | 0x0 | <b>ResumeDetected</b><br>This bit is set when HC detects that a device on the USB is asserting resume signaling. It is the transition from no resume signaling to resume signaling causing this bit to be set. This bit is not set when HCD sets the <i>USBResume</i> state.                              |
| 2 | R/W | R/W | 0x0 | <b>StartofFrame</b><br>This bit is set by HC at each start of frame and after the update of <i>HccaFrameNumber</i> . HC also generates a SOF token at the same time.                                                                                                                                      |
| 1 | R/W | R/W | 0x0 | <b>WritebackDoneHead</b><br>This bit is set immediately after HC has written <i>HcDoneHead</i> to <i>HccaDoneHead</i> . Further updates of the <i>HccaDoneHead</i> will not occur until this bit has been cleared. HCD should only clear this bit after it has saved the content of <i>HccaDoneHead</i> . |
| 0 | R/W | R/W | 0x0 | <b>SchedulingOverrun</b><br>This bit is set when the USB schedule for the current Frame overruns and after the update of <i>HccaFrameNumber</i> . A scheduling overrun will also cause the <b>SchedulingOverrunCount</b> of <i>HcCommandStatus</i> to be Incremented.                                     |

#### 6.8.7.5. HCINTERRUPTENABLE REGISTER

| Offset: 0x410 |                                                            |    | Register Name: HcInterruptEnable Register<br>Default Value: 0x0 |                                                                                                                                                          |
|---------------|------------------------------------------------------------|----|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write                                                 |    | Default                                                         | Description                                                                                                                                              |
|               | HCD                                                        | HC |                                                                 |                                                                                                                                                          |
| 31:7          |                                                            |    |                                                                 | <b>Reserved</b>                                                                                                                                          |
| 6             | R/W                                                        | R  | 0x0                                                             | <b>RootHubStatusChange Interrupt Enable</b>                                                                                                              |
|               |                                                            |    |                                                                 | <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Root Hub Status Change;</td></tr> </table> |
| 0             | Ignore;                                                    |    |                                                                 |                                                                                                                                                          |
| 1             | Enable interrupt generation due to Root Hub Status Change; |    |                                                                 |                                                                                                                                                          |
| 5             | R/W                                                        | R  | 0x0                                                             | <b>FrameNumberOverflow Interrupt Enable</b>                                                                                                              |
|               |                                                            |    |                                                                 | <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Frame Number Overflow;</td></tr> </table>  |
| 0             | Ignore;                                                    |    |                                                                 |                                                                                                                                                          |
| 1             | Enable interrupt generation due to Frame Number Overflow;  |    |                                                                 |                                                                                                                                                          |
|               |                                                            |    |                                                                 | <b>UnrecoverableError Interrupt Enable</b>                                                                                                               |

|   |                                                          |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
|---|----------------------------------------------------------|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|----------------------------------------------------------|
| 4 | R/W                                                      | R | 0x0 | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Unrecoverable Error;</td></tr> </table>                                            | 0 | Ignore; | 1 | Enable interrupt generation due to Unrecoverable Error;  |
| 0 | Ignore;                                                  |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 1 | Enable interrupt generation due to Unrecoverable Error;  |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 3 | R/W                                                      | R | 0x0 | <b>ResumeDetected Interrupt Enable</b> <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Resume Detected;</td></tr> </table>         | 0 | Ignore; | 1 | Enable interrupt generation due to Resume Detected;      |
| 0 | Ignore;                                                  |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 1 | Enable interrupt generation due to Resume Detected;      |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 2 | R/W                                                      | R | 0x0 | <b>StartofFrame Interrupt Enable</b> <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Start of Flame;</td></tr> </table>            | 0 | Ignore; | 1 | Enable interrupt generation due to Start of Flame;       |
| 0 | Ignore;                                                  |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 1 | Enable interrupt generation due to Start of Flame;       |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 1 | R/W                                                      | R | 0x0 | <b>WritebackDoneHead Interrupt Enable</b> <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Write back Done Head;</td></tr> </table> | 0 | Ignore; | 1 | Enable interrupt generation due to Write back Done Head; |
| 0 | Ignore;                                                  |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 1 | Enable interrupt generation due to Write back Done Head; |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 0 | R/W                                                      | R | 0x0 | <b>SchedulingOverrun Interrupt Enable</b> <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Scheduling Overrun;</td></tr> </table>   | 0 | Ignore; | 1 | Enable interrupt generation due to Scheduling Overrun;   |
| 0 | Ignore;                                                  |   |     |                                                                                                                                                                                                |   |         |   |                                                          |
| 1 | Enable interrupt generation due to Scheduling Overrun;   |   |     |                                                                                                                                                                                                |   |         |   |                                                          |

#### 6.8.7.6. HCINTERRUPTDISABLE REGISTER

| Offset: 0x414 |                                                             |    |         | Register Name: HcInterruptDisable Register<br>Default Value: 0x0                                                                                                                                                                                       |   |         |   |                                                             |
|---------------|-------------------------------------------------------------|----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|-------------------------------------------------------------|
| Bit           | Read/Write                                                  |    | Default | Description                                                                                                                                                                                                                                            |   |         |   |                                                             |
|               | HCD                                                         | HC |         |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 31            | R/W                                                         | R  | 0x0     | <b>MasterInterruptEnable</b><br>A written ‘0’ to this field is ignored by HC. A ‘1’ written to this field disables interrupt generation due events specified in the other bits of this register. This field is set after a hardware or software reset. |   |         |   |                                                             |
| 30:7          |                                                             |    |         | <b>Reserved</b>                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 6             | R/W                                                         | R  | 0x0     | <b>RootHubStatusChange Interrupt Disable</b> <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Disable interrupt generation due to Root Hub Status Change;</td></tr> </table>                                                   | 0 | Ignore; | 1 | Disable interrupt generation due to Root Hub Status Change; |
| 0             | Ignore;                                                     |    |         |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 1             | Disable interrupt generation due to Root Hub Status Change; |    |         |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 5             | R/W                                                         | R  | 0x0     | <b>FrameNumberOverflow Interrupt Disable</b> <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Disable interrupt generation due to Frame Number Overflow;</td></tr> </table>                                                    | 0 | Ignore; | 1 | Disable interrupt generation due to Frame Number Overflow;  |
| 0             | Ignore;                                                     |    |         |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 1             | Disable interrupt generation due to Frame Number Overflow;  |    |         |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 4             | R/W                                                         | R  | 0x0     | <b>UnrecoverableError Interrupt Disable</b> <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Disable interrupt generation due to Unrecoverable Error;</td></tr> </table>                                                       | 0 | Ignore; | 1 | Disable interrupt generation due to Unrecoverable Error;    |
| 0             | Ignore;                                                     |    |         |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 1             | Disable interrupt generation due to Unrecoverable Error;    |    |         |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 3             | R/W                                                         | R  | 0x0     | <b>ResumeDetected Interrupt Disable</b> <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     | <b>StartofFrame Interrupt Disable</b> <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 | <b>WritebackDoneHead Interrupt Disable</b>                                                                                                              |
|   |                                                           |   |     | <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Write back Done Head;</td></tr> </table> |
| 0 | Ignore;                                                   |   |     |                                                                                                                                                         |
| 1 | Disable interrupt generation due to Write back Done Head; |   |     |                                                                                                                                                         |
| 0 | R/w                                                       | R | 0x0 | <b>SchedulingOverrun Interrupt Disable</b>                                                                                                              |
|   |                                                           |   |     | <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Scheduling Overrun;</td></tr> </table>   |
| 0 | Ignore;                                                   |   |     |                                                                                                                                                         |
| 1 | Disable interrupt generation due to Scheduling Overrun;   |   |     |                                                                                                                                                         |

#### 6.8.7.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><b>HCCA[31:8]</b><br/> This is the base address of the Host Controller Communication Area. This area is used to hold the control structures and the Interrupt table that are accessed by both the Host Controller and the Host Controller Driver.</p> |
| 7:0           | R/W        | R  | 0x0     | <p><b>HCCA[7:0]</b><br/> The alignment restriction in HcHCCA register is evaluated by examining the number of zeros in the lower order bits. The minimum alignment is 256 bytes, therefore, bits 0 through 7 must always return 0 when read.</p>         |

#### 6.8.7.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     | <p><b>PCED[31:4]</b><br/> This is used by HC to point to the head of one of the Periodic list which will be processed in the current Frame. The content of this register is updated by HC after a periodic ED has been processed. HCD may read the content in determining which ED is currently being processed at the time of reading.</p> |
| 3:0           | R          | R/W | 0x0     | <p><b>PCED[3:0]</b><br/> Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                                                                                            |

#### 6.8.7.9. HCCONTROLHEADED REGISTER

| Offset: 0x420 |  |  |  | Register Name: HcControlHeadED[CCHED]<br>Default Value: 0x0 |
|---------------|--|--|--|-------------------------------------------------------------|
|---------------|--|--|--|-------------------------------------------------------------|

| Bit  | Read/Write |    | Default | Description                                                                                                                                                                                                                                                                    |
|------|------------|----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | HCD        | HC |         |                                                                                                                                                                                                                                                                                |
| 31:4 | R/W        | R  | 0x0     | <b>CHED[31:4]</b><br>The HcControlHeadED register contains the physical address of the first Endpoint Descriptor of the Control list. HC traverse the Control list starting with the HcControlHeadED pointer. The content is loaded from HCCA during the initialization of HC. |
| 3:0  | R/W        | R  | 0x0     | <b>CHED[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                        |

#### 6.8.7.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     | <b>CCED[31:4]</b><br>The pointer is advanced to the next ED after serving the present one. HC will continue processing the list from where it left off in the last Frame. When it reaches the end of the Control list, HC checks the ControlListFilled of in HcCommandStatus. If set, it copies the content of HcControlHeadED to HcControlCurrentED and clears the bit. If not set, it does nothing.<br>HCD is allowed to modify this register only when the ControlListEnable of HcControl is cleared. When set, HCD only reads the instantaneous value of this register. Initially , this is set to zero to indicate the end of the Control list. |
| 3:0           | R/W        | R/W | 0x0     | <b>CCED[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### 6.8.7.11. HC BULK HEADED REGISTER

| Offset: 0x428 |            |    |         | Register Name: HcBulkHeadED[BHED]<br>Default Value: 0x0                                                                                                                                                                                                             |
|---------------|------------|----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                         |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                     |
| 31:4          | R/W        | R  | 0x0     | <b>BHED[31:4]</b><br>The HcBulkHeadED register contains the physical address of the first Endpoint Descriptor of the Bulk list. HC traverses the Bulk list starting with the HcBulkHeadED pointer. The content is loaded from HCCA during the initialization of HC. |
|               |            |    |         | <b>BHED[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits                                                                                                             |

|     |     |   |     |                                                                 |
|-----|-----|---|-----|-----------------------------------------------------------------|
| 3:0 | R/W | R | 0x0 | in the PCED, through bit 0 to bit 3 must be zero in this field. |
|-----|-----|---|-----|-----------------------------------------------------------------|

#### 6.8.7.12. HCBULKCURRENTED REGISTER

| Offset: 0x42c |            |     |         | Register Name: HcBulkCurrentED [BCED]<br>Default Value: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:4          | R/W        | R/W | 0x0     | <b>BulkCurrentED[31:4]</b><br>This is advanced to the next ED after the HC has served the present one. HC continues processing the list from where it left off in the last Frame. When it reaches the end of the Bulk list, HC checks the <b>ControlListFilled</b> of <i>HcControl</i> . If set, it copies the content of <i>HcBulkHeadED</i> to <i>HcBulkCurrentED</i> and clears the bit. If it is not set, it does nothing. HCD is only allowed to modify this register when the <b>BulkListEnable</b> of <i>HcControl</i> is cleared. When set, the HCD only reads the instantaneous value of this register. This is initially set to zero to indicate the end of the Bulk list. |
| 3:0           | R/W        | R/W | 0x0     | <b>BulkCurrentED [3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 6.8.7.13. HCDONEHEAD REGISTER

| Offset: 0x430 |            |     |         | Register Name: HcDoneHead<br>Default Value: 0x0                                                                                                                                                                                                                                                                                                                    |
|---------------|------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                                                                                        |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                                                                                                    |
| 31:4          | R          | R/W | 0x0     | <b>HcDoneHead[31:4]</b><br>When a TD is completed, HC writes the content of <i>HcDoneHead</i> to the NextTD field of the TD. HC then overwrites the content of <i>HcDoneHead</i> with the address of this TD. This is set to zero whenever HC writes the content of this register to HCCA. It also sets the <b>WritebackDoneHead</b> of <i>HcInterruptStatus</i> . |
| 3:0           | R          | R/W | 0x0     | <b>HcDoneHead[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                                                      |

#### 6.8.7.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    | <b>FrameIntervalToggler</b><br>HCD toggles this bit whenever it loads a new value to <b>FrameInterval</b> .                                                                                                                                                                                                                                                                                                                                     |
| 30:16 | R/W | R | 0x0    | <b>FSLargestDataPacket</b><br>This field specifies a value which is loaded into the Largest Data Packet Counter at the beginning of each frame. The counter value represents the largest amount of data in bits which can be sent or received by the HC in a single transaction at any given time without causing scheduling overrun. The field value is calculated by the HCD.                                                                 |
| 15:14 |     |   |        | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13:0  | R/W | R | 0x2edf | <b>FrameInterval</b><br>This specifies the interval between two consecutive SOFs in bit times. The nominal value is set to be 11,999. HCD should store the current value of this field before resetting HC. By setting the <b>HostControllerReset</b> field of <i>HcCommandStatus</i> as this will cause the HC to reset this field to its nominal value. HCD may choose to restore the stored value upon the completion of the Reset sequence. |

#### 6.8.7.15. HCFMREMAINING REGISTER

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

#### 6.8.7.16. HCFMNUMBER REGISTER

| Offset: 0x43c |            |    |         | Register Name: HcFmNumber<br>Default Value: 0x0 |
|---------------|------------|----|---------|-------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                     |
|               | HCD        | HC |         |                                                 |
| 31:16         | /          | /  | /       | <b>Reserved</b>                                 |

|      |   |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |   |     |     | <b>FrameNumber</b><br>This is incremented when <i>HcFmRemaining</i> is re-loaded. It will be rolled over to 0x0 after 0xffff. When entering the USBOPERATIONAL state, this will be incremented automatically. The content will be written to HCCA after HC has incremented the <b>FrameNumber</b> at each frame boundary and sent a SOF but before HC reads the first ED in that Frame. After writing to HCCA, HC will set the <b>StartofFrame</b> in <i>HcInterruptStatus</i> . |
| 15:0 | R | R/W | 0x0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### 6.8.7.17. HCPERIODICSTART REGISTER

| Offset: 0x440 |            |    |         | Register Name: HcPeriodicStatus<br>Default Value: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|------------|----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:14         | /          | /  | /       | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13:0          | R/W        | R  | 0x0     | <b>PeriodicStart</b><br>After a hardware reset, this field is cleared. This is then set by HCD during the HC initialization. The value is calculated roughly as 10% off from <i>HcFmInterval</i> .. A typical value will be 0x3e67. When <i>HcFmRemaining</i> reaches the value specified, processing of the periodic lists will have priority over Control/Bulk processing. HC will therefore start processing the Interrupt list after completing the current Control or Bulk transaction that is in progress. |

#### 6.8.7.18. HCLSTHRESHOLD REGISTER

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

#### 6.8.7.19. HCRHDESCRIPTORA REGISTER

| Offset: 0x448 |            |    |         | Register Name: HcRhDescriptorA<br>Default Value: 0x02001201                                                |
|---------------|------------|----|---------|------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                |
|               | HCD        | HC |         |                                                                                                            |
| 31:24         | R/W        | R  | 0x02    | <b>PowerOnToPowerGoodTime[POTPGT]</b><br>This byte specifies the duration HCD has to wait before accessing |

|       |                                                                                                                                                                                                                                                                                                                                                                                          |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                                                                                                                                                                                                                                                                                                                                                                                          |   |      | a powered-on port of the Root Hub. It is implementation-specific. The unit of time is 2 ms. The duration is calculated as POTPGT * 2ms.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 23:13 |                                                                                                                                                                                                                                                                                                                                                                                          |   |      | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 12    | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R | 0x01 | <p><b>NoOverCurrentProtection</b><br/> This bit describes how the overcurrent status for the Root Hub ports are reported. When this bit is cleared, the <b>OverCurrentProtectionMode</b> field specifies global or per-port reporting.</p> <table border="1"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>No overcurrent protection supported.</td></tr> </table>                                                                                                                                                                                                                                                                                                               | 0 | Over-current status is reported collectively for all downstream ports. | 1 | No overcurrent protection supported.                                                                                                                                                                                                                                                                                                                                                     |
| 0     | Over-current status is reported collectively for all downstream ports.                                                                                                                                                                                                                                                                                                                   |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1     | No overcurrent protection supported.                                                                                                                                                                                                                                                                                                                                                     |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 11    | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R | 0x0  | <p><b>OverCurrentProtectionMode</b><br/> This bit describes how the overcurrent status for the Root Hub ports are reported. At reset, these fields should reflect the same mode as <b>PowerSwitchingMode</b>. This field is valid only if the <b>NoOverCurrentProtection</b> field is cleared.</p> <table border="1"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>Over-current status is reported on per-port basis.</td></tr> </table>                                                                                                                                                                                                                                         | 0 | Over-current status is reported collectively for all downstream ports. | 1 | Over-current status is reported on per-port basis.                                                                                                                                                                                                                                                                                                                                       |
| 0     | Over-current status is reported collectively for all downstream ports.                                                                                                                                                                                                                                                                                                                   |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1     | Over-current status is reported on per-port basis.                                                                                                                                                                                                                                                                                                                                       |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 10    | R                                                                                                                                                                                                                                                                                                                                                                                        | R | 0x0  | <p><b>Device Type</b><br/> This bit specifies that the Root Hub is not a compound device. The Root Hub is not permitted to be a compound device. This field should always read/write 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 9     | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R | 0x01 | <p><b>PowerSwitchingMode</b><br/> This bit is used to specify how the power switching of the Root Hub ports is controlled. It is implementation-specific. This field is only valid if the <b>NoPowerSwitching</b> field is cleared.</p> <table border="1"> <tr> <td>0</td><td>All ports are powered at the same time.</td></tr> <tr> <td>1</td><td>Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands (<b>Set/ClearPortPower</b>). If the port mask is cleared, then the port is controlled only by the global power switch (<b>Set/ClearGlobalPower</b>).</td></tr> </table> | 0 | All ports are powered at the same time.                                | 1 | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands ( <b>Set/ClearPortPower</b> ). If the port mask is cleared, then the port is controlled only by the global power switch ( <b>Set/ClearGlobalPower</b> ). |
| 0     | All ports are powered at the same time.                                                                                                                                                                                                                                                                                                                                                  |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1     | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands ( <b>Set/ClearPortPower</b> ). If the port mask is cleared, then the port is controlled only by the global power switch ( <b>Set/ClearGlobalPower</b> ). |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 8     | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R | 0x0  | <p><b>NoPowerSwitching</b><br/> These bits are used to specify whether power switching is supported or ports are always powered. It is implementation-specific. When this bit is cleared, the <b>PowerSwitchingMode</b> specifies global or per-port switching.</p> <table border="1"> <tr> <td>0</td><td>Ports are power switched.</td></tr> <tr> <td>1</td><td>Ports are always powered on when the HC is powered on.</td></tr> </table>                                                                                                                                                                                                                                                                                                                 | 0 | Ports are power switched.                                              | 1 | Ports are always powered on when the HC is powered on.                                                                                                                                                                                                                                                                                                                                   |
| 0     | Ports are power switched.                                                                                                                                                                                                                                                                                                                                                                |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1     | Ports are always powered on when the HC is powered on.                                                                                                                                                                                                                                                                                                                                   |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:0   | R                                                                                                                                                                                                                                                                                                                                                                                        | R | 0x01 | <p><b>NumberDownstreamPorts</b><br/> These bits specify the number of downstream ports supported by the Root Hub. It is implementation-specific. The minimum number of ports is 1. The maximum number of ports supported.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |

### 6.8.7.20. HCRHDESCRIPTORB REGISTER

| Offset: 0x44c |                                |    |         | Register Name: HcRhDescriptorB Register<br>Default Value:0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |          |      |                               |      |                               |     |  |       |                                |
|---------------|--------------------------------|----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|-------------------------------|------|-------------------------------|-----|--|-------|--------------------------------|
| Bit           | Read/Write                     |    | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
|               | HCD                            | HC |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| 31:16         | R/W                            | R  | 0x0     | <p><b>PortPowerControlMask</b><br/>           Each bit indicates if a port is affected by a global power control command when <b>PowerSwitchingMode</b> is set. When set, the port's power state is only affected by per-port power control (<b>Set/Counterpower</b>). When cleared, the port is controlled by the global power switch (<b>Set/ClearGlobalPower</b>). If the device is configured to global switching mode (<b>PowerSwitchingMode</b> = 0 ), this field is not valid.</p> <table border="1"> <tr><td>Bit0</td><td>Reserved</td></tr> <tr><td>Bit1</td><td>Ganged-power mask on Port #1.</td></tr> <tr><td>Bit2</td><td>Ganged-power mask on Port #2.</td></tr> <tr><td>...</td><td></td></tr> <tr><td>Bit15</td><td>Ganged-power mask on Port #15.</td></tr> </table> | Bit0 | Reserved | Bit1 | Ganged-power mask on Port #1. | Bit2 | Ganged-power mask on Port #2. | ... |  | Bit15 | Ganged-power mask on Port #15. |
| Bit0          | Reserved                       |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1          | Ganged-power mask on Port #1.  |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2          | Ganged-power mask on Port #2.  |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| ...           |                                |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15         | Ganged-power mask on Port #15. |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| 15:0          | R/W                            | R  | 0x0     | <p><b>DeviceRemovable</b><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.</p> <table border="1"> <tr><td>Bit0</td><td>Reserved</td></tr> <tr><td>Bit1</td><td>Device attached to Port #1.</td></tr> <tr><td>Bit2</td><td>Device attached to Port #2.</td></tr> <tr><td>...</td><td></td></tr> <tr><td>Bit15</td><td>Device attached to Port #15.</td></tr> </table>                                                                                                                                                                                                                                                                                                   | Bit0 | Reserved | Bit1 | Device attached to Port #1.   | Bit2 | Device attached to Port #2.   | ... |  | Bit15 | Device attached to Port #15.   |
| Bit0          | Reserved                       |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1          | Device attached to Port #1.    |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2          | Device attached to Port #2.    |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| ...           |                                |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15         | Device attached to Port #15.   |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |

### 6.8.7.21. HCRHSTATUS REGISTER

| Offset: 0x450 |            |    |         | Register Name: HcRhStatus Register<br>Default Value:0x0                                                                                                                                                                                                                                     |
|---------------|------------|----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                                                 |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                                             |
| 31            | W          | R  | 0x0     | <p><b>(write)ClearRemoteWakeupEnable</b><br/>           Write a '1' clears <b>DeviceRemoteWakeupEnable</b>. Write a '0' has no effect.</p>                                                                                                                                                  |
| 30:18         | /          | /  | /       | <b>Reserved</b>                                                                                                                                                                                                                                                                             |
| 17            | R/W        | R  | 0x0     | <p><b>OverCurrentIndicatorChange</b><br/>           This bit is set by hardware when a change has occurred to the <b>OverCurrentIndicator</b> field of this register. The HCD clears this bit by writing a '1'.Writing a '0' has no effect.</p> <p><b>(read)LocalPowerStartusChange</b></p> |

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

#### 6.8.7.22. HCRHPORTSTATUS REGISTER

| Offset: 0x454 |                            |     |         | Register Name: HcRhPortStatus<br>Default Value:0x100                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                            |   |                        |
|---------------|----------------------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------|---|------------------------|
| Bit           | Read/Write                 |     | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                            |   |                        |
|               | HCD                        | HC  |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                            |   |                        |
| 31:21         |                            |     | -       | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                            |   |                        |
| 20            | R/W                        | R/W | 0x0     | <b>PortResetStatusChange</b><br>This bit is set at the end of the 10-ms port reset signal. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>0</td><td>port reset is not complete</td></tr> <tr> <td>1</td><td>port reset is complete</td></tr> </table><br><b>PortOverCurrentIndicatorChange</b><br>This bit is valid only if overcurrent conditions are reported on a | 0 | port reset is not complete | 1 | port reset is complete |
| 0             | port reset is not complete |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                            |   |                        |
| 1             | port reset is complete     |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                            |   |                        |

|       |                                              |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
|-------|----------------------------------------------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------|---|---------------------------------------------|
|       |                                              |     |     | per-port basis. This bit is set when Root Hub changes the <b>PortOverCurrentIndicator</b> bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                              |   |                                             |
| 19    | R/W                                          | R/W | 0x0 | <p><b>PortOverCurrentIndicator</b></p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortOverCurrentIndicator</b></td></tr> <tr> <td>1</td><td><b>PortOverCurrentIndicator</b> has changed</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0 | no change in <b>PortOverCurrentIndicator</b> | 1 | <b>PortOverCurrentIndicator</b> has changed |
| 0     | no change in <b>PortOverCurrentIndicator</b> |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 1     | <b>PortOverCurrentIndicator</b> has changed  |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 18    | R/W                                          | R/W | 0x0 | <p><b>PortSuspendStatusChange</b><br/> This bit is set when the full resume sequence has been completed. This sequence includes the 20-s resume pulse, LS EOP, and 3-ms resynchronization delay. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. This bit is also cleared when <b>ResetStatusChange</b> is set.</p> <table border="1"> <tr> <td>0</td><td>resume is not completed</td></tr> <tr> <td>1</td><td>resume completed</td></tr> </table>                                                                                                                                                                                                                                                                                                        | 0 | resume is not completed                      | 1 | resume completed                            |
| 0     | resume is not completed                      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 1     | resume completed                             |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 17    | R/W                                          | R/W | 0x0 | <p><b>PortEnableStatusChange</b><br/> This bit is set when hardware events cause the <b>PortEnableStatus</b> bit to be cleared. Changes from HCD writes do not set this bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortEnableStatus</b></td></tr> <tr> <td>1</td><td>change in <b>PortEnableStatus</b></td></tr> </table>                                                                                                                                                                                                                                                                                                                                                             | 0 | no change in <b>PortEnableStatus</b>         | 1 | change in <b>PortEnableStatus</b>           |
| 0     | no change in <b>PortEnableStatus</b>         |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 1     | change in <b>PortEnableStatus</b>            |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 16    | R/W                                          | R/W | 0x0 | <p><b>ConnectStatusChange</b><br/> This bit is set whenever a connect or disconnect event occurs. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared when a <b>SetPortReset</b>, <b>SetPortEnable</b>, or <b>SetPortSuspend</b> write occurs, this bit is set to force the driver to re-evaluate the connection status since these writes should not occur if the port is disconnected.</p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortEnableStatus</b></td></tr> <tr> <td>1</td><td>change in <b>PortEnableStatus</b></td></tr> </table> <p>Note: If the <b>DeviceRemovable[NDP]</b> bit is set, this bit is set only after a Root Hub reset to inform the system that the device is attached.</p> | 0 | no change in <b>PortEnableStatus</b>         | 1 | change in <b>PortEnableStatus</b>           |
| 0     | no change in <b>PortEnableStatus</b>         |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 1     | change in <b>PortEnableStatus</b>            |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 15:10 |                                              |     |     | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 9     | R/W                                          | R/W | -   | <p><b>(read)LowSpeedDeviceAttached</b><br/> This bit indicates the speed of the device attached to this port. When set, a Low Speed device is attached to this port. When clear, a Full Speed device is attached to this port. This field is valid only when the <b>CurrentConnectStatus</b> is set.</p> <table border="1"> <tr> <td>0</td><td>full speed device attached</td></tr> <tr> <td>1</td><td>low speed device attached</td></tr> </table> <p><b>(write)ClearPortPower</b><br/> The HCD clears the <b>PortPowerStatus</b> bit by writing a '1' to this bit. Writing a '0' has no effect.</p>                                                                                                                                                                          | 0 | full speed device attached                   | 1 | low speed device attached                   |
| 0     | full speed device attached                   |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
| 1     | low speed device attached                    |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                              |   |                                             |
|       |                                              |     |     | <p><b>(read)PortPowerStatus</b><br/> This bit reflects the port's power status, regardless of the type of power switching implemented. This bit is cleared if an overcurrent condition is detected. HCD sets this bit by writing <b>SetPortPower</b> or <b>SetGlobalPower</b>. HCD clears this bit by writing <b>ClearPortPower</b> or <b>ClearGlobalPower</b>. Which power control switches are enabled</p>                                                                                                                                                                                                                                                                                                                                                                   |   |                                              |   |                                             |

|     |                                 |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
|-----|---------------------------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------|---|---------------------------------|
|     |                                 |     |     | is determined by <b>PowerSwitchingMode</b> and <b>PortPortControlMask[NumberDownstreamPort]</b> . In global switching mode( <b>PowerSwitchingMode</b> =0), only <b>Set/ClearGlobalPower</b> controls this bit. In per-port power switching ( <b>PowerSwitchingMode</b> =1), if the <b>PortPowerControlMask[NDP]</b> bit for the port is set, only <b>Set/ClearPortPower</b> commands are enabled. If the mask is not set, only <b>Set/ClearGlobalPower</b> commands are enabled. When port power is disabled, <b>CurrentConnectStatus</b> , <b>PortEnableStatus</b> , <b>PortSuspendStatus</b> , and <b>PortResetStatus</b> should be reset.                                                                                                                                                                              |   |                                 |   |                                 |
| 8   | R/W                             | R/W | 0x0 | <p>(write)<b>SetPortPower</b><br/>           The HCD writes a '1' to set the <b>PortPowerStatus</b> bit. Writing a '0' has no effect.</p> <p>Note: This bit is always reads '1b' if power switching is not supported.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                 |   |                                 |
| 7:5 |                                 |     |     | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 4   | R/W                             | R/W | 0x0 | <p>(read)<b>PortResetStatus</b><br/>           When this bit is set by a write to <b>SetPortReset</b>, port reset signaling is asserted. When reset is completed, this bit is cleared when <b>PortResetStatusChange</b> is set. This bit cannot be set if <b>CurrentConnectStatus</b> is cleared.</p> <table border="1"> <tr> <td>0</td><td>port reset signal is not active</td></tr> <tr> <td>1</td><td>port reset signal is active</td></tr> </table> <p>(write)<b>SetPortReset</b><br/>           The HCD sets the port reset signaling by writing a '1' to this bit. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this write does not set <b>PortResetStatus</b>, but instead sets <b>ConnectStatusChange</b>. This informs the driver that it attempted to reset a disconnected port.</p> | 0 | port reset signal is not active | 1 | port reset signal is active     |
| 0   | port reset signal is not active |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 1   | port reset signal is active     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 3   | R/W                             | R/W | 0x0 | <p>(read)<b>PortOverCurrentIndicator</b><br/>           This bit is only valid when the Root Hub is configured in such a way that overcurrent conditions are reported on a per-port basis. If per-port overcurrent reporting is not supported, this bit is set to 0. If cleared, all power operations are normal for this port. If set, an overcurrent condition exists on this port. This bit always reflects the overcurrent input signal.</p> <table border="1"> <tr> <td>0</td><td>no overcurrent condition.</td></tr> <tr> <td>1</td><td>overcurrent condition detected.</td></tr> </table> <p>(write)<b>ClearSuspendStatus</b><br/>           The HCD writes a '1' to initiate a resume. Writing a '0' has no effect. A resume is initiated only if <b>PortSuspendStatus</b> is set.</p>                            | 0 | no overcurrent condition.       | 1 | overcurrent condition detected. |
| 0   | no overcurrent condition.       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 1   | overcurrent condition detected. |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
|     |                                 |     |     | <p>(read)<b>PortSuspendStatus</b><br/>           This bit indicates the port is suspended or in the resume sequence. It is set by a <b>SetSuspendState</b> write and cleared when <b>PortSuspendStatusChange</b> is set at the end of the resume interval. This bit cannot be set if <b>CurrentConnectStatus</b> is cleared. This bit is also cleared when <b>PortResetStatusChange</b> is</p>                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                 |   |                                 |

|   |                       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                       |   |                   |
|---|-----------------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------------------|---|-------------------|
|   |                       |     |     | 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" style="margin-left: auto; margin-right: auto;"> <tr> <td>0</td><td>port is not suspended</td></tr> <tr> <td>1</td><td>port is suspended</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 | port is not suspended | 1 | port is suspended |
| 0 | port is not suspended |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                       |   |                   |
| 1 | port is suspended     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                       |   |                   |
| 2 | R/W                   | R/W | 0x0 | <p>(write)<b>SetPortSuspend</b><br/> The HCD sets the <b>PortSuspendStatus</b> bit by writing a '1' to this bit. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this write does not set <b>PortSuspendStatus</b>; instead it sets <b>ConnectStatusChange</b>. This informs the driver that it attempted to suspend a disconnected port.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                       |   |                   |
| 1 | R/W                   | R/W | 0x0 | <p>(read)<b>PortEnableStatus</b><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 <b>PortEnabledStatusChange</b> to be set. HCD sets this bit by writing <b>SetPortEnable</b> and clears it by writing <b>ClearPortEnable</b>. This bit cannot be set when <b>CurrentConnectStatus</b> is cleared. This bit is also set, if not already, at the completion of a port reset when <b>ResetStatusChange</b> is set or port suspend when <b>SuspendStatusChange</b> is set.</p> <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>0</td><td>port is disabled</td></tr> <tr> <td>1</td><td>port is enabled</td></tr> </table> <p>(write)<b>SetPortEnable</b><br/> The HCD sets <b>PortEnableStatus</b> by writing a '1'. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this write does not set <b>PortEnableStatus</b>, but instead sets <b>ConnectStatusChange</b>. This informs the driver that it attempted to enable a disconnected Port.</p> | 0 | port is disabled      | 1 | port is enabled   |
| 0 | port is disabled      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                       |   |                   |
| 1 | port is enabled       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                       |   |                   |
| 0 | R/W                   | R/W | 0x0 | <p>(read)<b>CurrentConnectStatus</b><br/> This bit reflects the current state of the downstream port.</p> <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>0</td><td>No device connected</td></tr> <tr> <td>1</td><td>Device connected</td></tr> </table> <p>(write)<b>ClearPortEnable</b><br/> The HCD writes a '1' to clear the PortEnableStatus bit. Writing '0' has no effect. The CurrentConnectStatus is not affected by any write.</p> <p>Note: This bit is always read '1' when the attached device is nonremovable(DeviceRemovable[NumberDownstreamPort]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0 | No device connected   | 1 | Device connected  |
| 0 | No device connected   |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                       |   |                   |
| 1 | Device connected      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                       |   |                   |

## 6.8.8. USB Host Special Requirement

### 6.8.8.1. USB HOST CLOCK REQUIREMENT

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

## 6.9. Digital Audio Interface

### 6.9.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:

- Support industry-standard AMBA Peripheral Bus (APB) and it is fully compliant with the AMBA Specification, Revision 2.0
- Support APB 32-bit bus width
- I2S or PCM configured by software
- Full-duplex synchronous serial interface
- Master / Slave mode operation configured by software
- Audio data resolution 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 support 8-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-bit FIFO for data transmit, one 64x24-bit FIFO for data receive
- Programmable FIFO thresholds
- Interrupt and DMA support
- Two 32-bit counters for AV sync application
- Loopback mode for test

## 6.9.2. Digital Audio Interface Block Diagram

The Digital Audio Interface block diagram is shown below:



## 6.9.3. Digital Audio Interface Timing Diagram



Standard I2S Timing Diagram



Left-justified I2S Timing Diagram



Right-justified I2S Timing Diagram



PCM Long Frame SYNC Timing Diagram (8-bits Companded Sample Example)



PCM Short Frame SYNC Timing Diagram (16-bits sample example)

## 6.9.4. Digital Audio Interface Register List

| Module Name | Base Address |
|-------------|--------------|
| DA0         | 0x01C22400   |
| DA1         | 0x01C22000   |

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

## 6.9.5. Digital Audio Interface Register Description

### 6.9.5.1. DIGITAL AUDIO CONTROL REGISTER

| Offset: 0x00 |            |         | Register Name: DA_CTL      |
|--------------|------------|---------|----------------------------|
|              |            |         | Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                |
| 31:12        | /          | /       | /                          |
| 11           | R/W        | 0       | SDO3_EN                    |

| Offset: 0x00 |            |         | Register Name: DA_CTL<br>Default Value: 0x0000_0000                                                  |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                          |
|              |            |         | 0: Disable<br>1: Enable                                                                              |
| 10           | R/W        | 0       | SDO2_EN<br>0: Disable<br>1: Enable                                                                   |
| 9            | R/W        | 0       | SDO1_EN<br>0: Disable<br>1: Enable                                                                   |
| 8            | R/W        | 0       | SDO0_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       | /                                                                                                    |
| 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                                                                                                  |

| <b>Offset: 0x00</b> |                   |                | <b>Register Name: DA_CTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                   |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                  |
|                     |                   |                | <p>Globe Enable<br/> A disable on this bit overrides any other block or channel enables and flushes all FIFOs.</p> <p>0: Disable<br/> 1: Enable</p> |

#### 6.9.5.2. DIGITAL AUDIO FORMAT REGISTER 0

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: DA_FAT0</b><br><b>Default Value: 0x0000_000C</b>                                                                                                                                                                            |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                            |
| 31:8                | /                 | /              | /                                                                                                                                                                                                                                             |
| 7                   | R/W               | 0              | <p>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</p> |
| 6                   | R/W               | 0              | <p>BCP<br/> BCLK Parity<br/> 0: Normal<br/> 1: Inverted</p>                                                                                                                                                                                   |
| 5:4                 | R/W               | 0              | <p>SR<br/> Sample Resolution<br/> 00: 16-bit<br/> 01: 20-bit<br/> 10: 24-bit<br/> 11: Reserved</p>                                                                                                                                            |
| 3:2                 | R/W               | 0x3            | <p>WSS<br/> Word Select Size</p>                                                                                                                                                                                                              |

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: DA_FAT0</b><br><b>Default Value: 0x0000_000C</b>                                                                     |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                     |
|                     |                   |                | 00: 16 BCLK<br>01: 20 BCLK<br>10: 24 BCLK<br>11: 32 BCLK                                                                               |
| 1:0                 | R/W               | 0              | <b>FMT</b><br>Serial Data Format<br>00: Standard I2S Format<br>01: Left Justified Format<br>10: Right Justified Format<br>11: Reserved |

#### 6.9.5.3. DIGITAL AUDIO FORMAT REGISTER 1

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: DA_FAT1</b><br><b>Default Value: 0x0000_4020</b>                                                                                                                               |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                               |
| 31:15               | /                 | /              | /                                                                                                                                                                                                |
| 14:12               | R/W               | 0x4            | <b>PCM_SYNC_PERIOD</b><br>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              | <b>PCM_SYNC_OUT</b><br>PCM Sync Out<br>0: Enable PCM_SYNC output in Master mode<br>1: Suppress PCM_SYNC whilst keeping PCM_CLK running.<br>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                                                                                                                                                                                              |

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: DA_FAT1</b><br><b>Default Value: 0x0000_4020</b>                                                                                                                                                                                                                                                                             |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                             |
|                     |                   |                | MSB / LSB First Select<br>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 writing the bit is 0, the unused bits are audio gain for 13-bit linear sample and zeros padding for 8-bit companding sample.<br>When writing the bit is 1, the unused bits are both 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                                                                                                                                                                                                                             |

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: DA_FAT1</b><br><b>Default Value: 0x0000_4020</b>                                                 |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                 |
| 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 |

#### 6.9.5.4. DIGITAL AUDIO TX FIFO REGISTER

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: DA_TXFIFO</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                      |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                        |
| 31:0                | W                 | 0              | TX_DATA<br>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. |

#### 6.9.5.5. DIGITAL AUDIO RX FIFO REGISTER

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: DA_RXFIFO</b><br><b>Default Value: 0x0000_0000</b>                                                                               |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                 |
| 31:0                | R                 | 0              | 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. |

#### 6.9.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 clear to '0'.                                                                                                                                                                                                                                |
| 24           | R/W        | 0       | FRX<br>Write '1' to flush RX FIFO, self clear 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<br>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       | RXOM<br>RX FIFO Output Mode (Mode 0, 1, 2, 3)<br>00: Expanding '0' at LSB of DA_RXFIFO register.                                                                                                                                                                                     |

| <b>Offset: 0x14</b> |                   |                | <b>Register Name: DA_FCTL</b><br><b>Default Value: 0x0004_00F0</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                     |                   |                | <p>01: Expanding received sample sign bit at MSB of DA_RXFIFO register.</p> <p>10: Truncating received samples at high half-word of DA_RXFIFO register and low half-word of DA_RXFIFO register is filled by '0'.</p> <p>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:</p> <p>Mode 0: RXFIFO[31:0] = {FIFO_O[19:0], 12'h0}</p> <p>Mode 1: RXFIFO[31:0] = {12{FIFO_O[19]}, FIFO_O[19:0]}</p> <p>Mode 2: RXFIFO[31:0] = {FIFO_O[19:4], 16'h0}</p> <p>Mode 3: RXFIFO[31:0] = {16{FIFO_O[19]}, FIFO_O[19:4]}</p> |

#### 6.9.5.7. DIGITAL AUDIO FIFO STATUS REGISTER

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

| <b>Offset: 0x18</b> |                   |                | <b>Register Name: DA_FSTA</b><br><b>Default Value: 0x1080_0000</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 6:0                 | R                 | 0              | RXA_CNT<br>RX FIFO Available Sample Word Counter                   |

#### 6.9.5.8. DIGITAL AUDIO DMA & INTERRUPT CONTROL REGISTER

| <b>Offset: 0x1C</b> |                   |                | <b>Register Name: DA_INT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                      |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                     |
| 31:8                | /                 | /              | /                                                                                                                                                                      |
| 7                   | R/W               | 0              | <b>TX_DRQ</b><br>TX FIFO Empty DRQ Enable<br>0: Disable<br>1: Enable                                                                                                   |
| 6                   | R/W               | 0              | <b>TXUI_EN</b><br>TX FIFO Under run Interrupt Enable<br>0: Disable<br>1: Enable                                                                                        |
| 5                   | R/W               | 0              | <b>TXOI_EN</b><br>TX FIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable<br>When set to '1', an interrupt happens when writing new audio data if TX FIFO is full. |
| 4                   | R/W               | 0              | <b>TXEI_EN</b><br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                                                            |
| 3                   | R/W               | 0              | <b>RX_DRQ</b><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. |

| <b>Offset: 0x1C</b> |                   |                | <b>Register Name: DA_INT</b><br><b>Default Value: 0x0000_0000</b>             |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                            |
| 2                   | R/W               | 0              | RXUI_EN<br>RX FIFO Under run 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 |

#### 6.9.5.9. DIGITAL AUDIO INTERRUPT STATUS REGISTER

| <b>Offset: 0x20</b> |                   |                | <b>Register Name: DAISTA</b><br><b>Default Value: 0x0000_0010</b>                                                                                                       |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                      |
| 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 automatic clear if interrupt |

| <b>Offset: 0x20</b> |                   |                | <b>Register Name: DAISTA</b><br><b>Default Value: 0x0000_0010</b>                                                                                                                                                     |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                    |
|                     |                   |                | condition fails.                                                                                                                                                                                                      |
| 3:2                 | /                 | /              | /                                                                                                                                                                                                                     |
| 2                   | R/W               | 0              | <p><b>RXU_INT</b><br/> RX FIFO Under run Pending Interrupt<br/> 0: No Pending Interrupt<br/> 1:FIFO Under run Pending Interrupt<br/> Write 1 to clear this interrupt</p>                                              |
| 1                   | R/W               | 0              | <p><b>RXO_INT</b><br/> RX FIFO Overrun Pending Interrupt<br/> 0: No Pending IRQ<br/> 1: FIFO Overrun Pending IRQ<br/> Write '1' to clear this interrupt</p>                                                           |
| 0                   | R/W               | 0              | <p><b>RXA_INT</b><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.</p> |

#### 6.9.5.10. DIGITAL AUDIO CLOCK DIVIDE REGISTER

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

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: DA_CLKD</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                          |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                          |
|                     |                   |                | 000: Divide by 2 (BCLK = MCLK/2)<br>001: Divide by 4<br>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              | <b>MCLKDIV</b><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 |

#### 6.9.5.11. DIGITAL AUDIO TX COUNTER REGISTER

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

| <b>Offset: 0x28</b> |                   |                | <b>Register Name: DA_TXCNT</b><br><b>Default Value: 0x0000_0000</b>                                 |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                  |
|                     |                   |                | been updated by the initial value, the counter register should count on base of this initial value. |

#### 6.9.5.12. DIGITAL AUDIO RX COUNTER REGISTER

| <b>Offset: 0x2C</b> |                   |                | <b>Register Name: DA_RXCNT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                          |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                           |
| 31:0                | R/W               | 0              | <p><b>RX_CNT</b><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> |

#### 6.9.5.13. DIGITAL AUDIO TX CHANNEL SELECT REGISTER

| <b>Offset: 0x30</b> |                   |                | <b>Register Name: DA_TXCHSEL</b><br><b>Default Value: 0x0000_0001</b>                                                                           |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                              |
| 31:3                | /                 | /              | /                                                                                                                                               |
| 2:0                 | R/W               | 1              | <p><b>TX_CHSEL</b><br/>TX Channel Select</p> <p>0: 1-ch<br/>1: 2-ch<br/>2: 3-ch<br/>3: 4-ch<br/>4: 5-ch<br/>5: 6-ch<br/>6: 7-ch<br/>7: 8-ch</p> |

#### 6.9.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           | /          | /       | /                                                                                                                                                                                                                                                                                         |
| 30:28        | R/W        | 7       | TX_CH7_MAP<br>TX Channel7 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 27           | /          | /       | /                                                                                                                                                                                                                                                                                         |
| 26:24        | R/W        | 6       | TX_CH6_MAP<br>TX Channel6 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 23           | /          | /       | /                                                                                                                                                                                                                                                                                         |
| 22:20        | R/W        | 5       | TX_CH5_MAP<br>TX Channel5 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample                                                                                              |

| Offset: 0x34 |                   |                | <b>Register Name: DA_TXCHMAP</b><br><b>Default Value: 0x7654_3210</b>                                                                                                                                                                                                                     |
|--------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>   | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|              |                   |                | 101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample                                                                                                                                                                                                 |
| 19           | /                 | /              | /                                                                                                                                                                                                                                                                                         |
| 18:16        | R/W               | 4              | TX_CH4_MAP<br>TX Channel4 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 15           | /                 | /              | /                                                                                                                                                                                                                                                                                         |
| 14:12        | R/W               | 3              | TX_CH3_MAP<br>TX Channel3 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 11           | /                 | /              | /                                                                                                                                                                                                                                                                                         |
| 10:8         | R/W               | 2              | TX_CH2_MAP<br>TX Channel2 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample                                                               |

| <b>Offset: 0x34</b> |                   |                | <b>Register Name: DA_TXCHMAP</b><br><b>Default Value: 0x7654_3210</b>                                                                                                                                                                                                                     |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|                     |                   |                | 110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample                                                                                                                                                                                                                                |
| 7                   | /                 | /              | /                                                                                                                                                                                                                                                                                         |
| 6:4                 | R/W               | 1              | TX_CH1_MAP<br>TX Channel1 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |
| 3                   | /                 | /              | /                                                                                                                                                                                                                                                                                         |
| 2:0                 | R/W               | 0              | TX_CH0_MAP<br>TX Channel0 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>100: 5 <sup>th</sup> sample<br>101: 6 <sup>th</sup> sample<br>110: 7 <sup>th</sup> sample<br>111: 8 <sup>th</sup> sample |

#### 6.9.5.15. DIGITAL AUDIO RX CHANNEL SELECT REGISTER

| <b>Offset: 0x38</b> |                   |                | <b>Register Name: DA_RXCHSEL</b><br><b>Default Value: 0x0000_0001</b> |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                    |
| 31:3                | /                 | /              | /                                                                     |
| 2:0                 | R/W               | 1              | RX_CHSEL                                                              |

| <b>Offset: 0x38</b> |                   |                | <b>Register Name: DA_RXCHSEL</b><br><b>Default Value: 0x0000_0001</b>             |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                |
|                     |                   |                | RX Channel Select<br>0: 1-ch<br>1: 2-ch<br>2: 3-ch<br>3: 4-ch<br>Others: Reserved |

#### 6.9.5.16. DIGITAL AUDIO RX CHANNEL MAPPING REGISTER

| <b>Offset: 0x3C</b> |                   |                | <b>Register Name: DA_RXCHMAP</b><br><b>Default Value: 0x0000_3210</b>                                                                                                             |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                |
| 31:15               | /                 | /              | /                                                                                                                                                                                 |
| 14:12               | R/W               | 3              | RX_CH3_MAP<br>RX Channel3 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>Others: Reserved |
| 11                  | /                 | /              | /                                                                                                                                                                                 |
| 10:8                | R/W               | 2              | RX_CH2_MAP<br>RX Channel2 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>Others: Reserved |
| 7                   | /                 | /              | /                                                                                                                                                                                 |
| 6:4                 | R/W               | 1              | RX_CH1_MAP<br>RX Channel1 Mapping<br>000: 1 <sup>st</sup> sample                                                                                                                  |

| <b>Offset: 0x3C</b> |                   |                | <b>Register Name: DA_RXCHMAP</b><br><b>Default Value: 0x0000_3210</b>                                                                                                             |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                |
|                     |                   |                | 001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>Others: Reserved                                                                     |
| 3                   | /                 | /              | /                                                                                                                                                                                 |
| 2:0                 | R/W               | 0              | RX_CH0_MAP<br>RX Channel0 Mapping<br>000: 1 <sup>st</sup> sample<br>001: 2 <sup>nd</sup> sample<br>010: 3 <sup>rd</sup> sample<br>011: 4 <sup>th</sup> sample<br>Others: Reserved |

## 6.9.6. Digital Audio Interface Special Requirement

### 6.9.6.1. DIGITAL AUDIO INTERFACE PIN LIST

| <b>Port Name</b> | <b>Width</b> | <b>Direction(M)</b> | <b>Description</b>                    |
|------------------|--------------|---------------------|---------------------------------------|
| 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             |

### 6.9.6.2. DIGITAL AUDIO INTERFACE MCLK AND BCLK

The Digital Audio Interface can support sampling rates from 128fs to 768fs, where fs is the audio sampling frequency typically 32kHz, 44.1kHz, 48kHz or 96kHz. For different sampling frequencies, the tables list the coefficient value of MCLKDIV and BCLKDIV.

| <b>Sampling Rate (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            |

MCLKDIV value for 24.576MHz Audio Serial Frequency

| <b>Sampling Rate (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            |

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           |

BCLKDIV value for Different Word Select Size

## DIGITAL AUDIO INTERFACE CLOCK SOURCE AND FREQUENCY

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

| <b>Name</b> | <b>Description</b>                            |
|-------------|-----------------------------------------------|
| Audio_PLL   | 24.576Mhz or 22.528Mhz generated by Audio PLL |

| Name    | Description                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------|
| APB_CLK | APB bus system clock. In I2S mode, it is requested $\geq 0.25$ BCLK. In PCM mode, it is requested $\geq 0.5$ BCLK. |

## 6.10. AC97 Interface

### 6.10.1. Overview

The AC97 interface supports AC97 revision 2.3 features. AC97 controller communicates with AC97 Codec using an audio controller link (AC-link). Controller sends the stereo PCM data to Codec. The external digital-to-analog converter (DAC) in the Codec converts the audio sample to an analog audio waveform. Controller receives the stereo PCM data and the mono Microphone data from Codec then stores in memories.

It features:

- Support industry-standard AMBA Peripheral Bus (APB) and it is fully compliant with the AMBA Specification, Revision 2.0
- Support APB 32-bits bus width
- Comply with AC97 2.3 component specification
- Full-duplex synchronous serial interface
- Support 2 channels, TX (stereo),RX (PCM stereo, MIC mono optional)
- Variable sampling rate AC97 codec interface support, up to 48KHz
- Support 2-channel and 6-channel audio data output
- DRA mode support
- Only one primary codec support
- Channels support mono or stereo samples of 16(standard), 18(optional) and 20(optional) bit wide
- One 96x20-bit FIFO and one 32x20-bit FIFO for data transfer
- Programmable FIFO thresholds
- Interrupt and DMA support

### 6.10.2. AC97 Block diagram



AC97 Interface Block Diagram



Operation Flow Diagram

### 6.10.3. AC97 Interface Clock Tree

The beginning of all audio sample packets, or Audio Frames, transferred over AC-link is synchronized to the rising edge of the SYNC signal. SYNC is driven by the Controller. The Controller generates SYNC by dividing BIT\_CLK by 256 and applying some condition to tailor its duty cycle. This yields a 48 KHz SYNC signal whose period defines an audio frame. Data is transitioned on AC-link on every rising edge of BIT\_CLK, and subsequently sampled by the receiving device on the receiving side of AC-link on each immediately following falling edge of BIT\_CLK.

### 6.10.4. AC Link Frame Format



Bi-directional AC-link Frame with slot assignments

The AC-link output slots (transmitted from the Controller) are defined as follows:

| Slot    | Name                          | Description                                                                                                              |
|---------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0       | SDATA_OUT TAG                 | MSBs indicate which slots contain valid data; LSBs convey Codec ID                                                       |
| 1       | Control CMD ADDR write port   | Read/write command bit plus 7-bit Codec register address                                                                 |
| 2       | Control DATA write port       | 16-bit command register write data                                                                                       |
| 3,4     | PCM L&R DAC playback          | 16, 18, or 20-bit PCM data for Left and Right channels                                                                   |
| 5       | Modem Line 1 DAC              | 16-bit modem data for modem Line 1 output                                                                                |
| 6,7,8,9 | PCM Center, Surround L&R, LFE | 16, 18, or 20-bit PCM data for Center, Surround L&R, LFE channels                                                        |
| 10      | Modem Line 2 DAC              | 16-bit modem data for modem Line 2 output                                                                                |
| 11      | Modem handset DAC             | 16-bit modem data for modem Handset output                                                                               |
| 12      | Modem IO control              | GPIO write port for modem Control                                                                                        |
| 10-11   | SPDIF Out                     | Optional AC-link bandwidth for SPDIF output                                                                              |
| 6-12    | Double rate audio             | Optional AC-link bandwidth for 88.2 or 96 kHz on L, C, R channels.<br>Actual slots used are controlled by the DRSS bits. |

The AC-link input slots (transmitted from the Codec) are defined as follows:

| Slot  | Name                     | Description                                                        |
|-------|--------------------------|--------------------------------------------------------------------|
| 0     | SDATA_IN TAG             | MSBs indicate which slots contain valid data                       |
| 1     | STATUS ADDR read port    | MSBs echo register address; LSBs indicate which slots request data |
| 2     | STATUS DATA read port    | 16-bit command register read data                                  |
| 3,4   | PCM L&R ADC record       | 16, 18 or 20-bit PCM data from Left and Right inputs               |
| 5     | Modem Line 1 ADC         | 16-bit modem data from modem Line1 input                           |
| 6     | Dedicated Microphone ADC | 16, 18 or 20-bit PCM data from optional 3rd ADC input              |
| 7,8,9 | Vendor reserved          | Vendor specific (enhanced input for docking, array mic, etc)       |
| 10    | Modem Line 2 ADC         | 16-bit modem data from modem Line 2 input                          |
| 11    | Modem handset input ADC  | 16-bit modem data for modem Handset input                          |
| 12    | Modem IO status          | GPIO read port for modem Status                                    |

## 6.10.5. AC97 Interface Timing Diagram

### 6.10.5.1. COLD RESET TIMING DIAGRAM



Cold Reset timing parameters

| Parameter                                           | Symbol         | Min   | Typ | Max | Units   |
|-----------------------------------------------------|----------------|-------|-----|-----|---------|
| RESET# active low pulse width                       | $T_{rst\_low}$ | 1.0   | -   | -   | $\mu s$ |
| RESET# inactive to SDATA_IN or BIT_CLK active delay | $T_{tr2actv}$  | -     | -   | 25  | ns      |
| RESET# inactive to BIT_CLK startup delay            | $T_{rst2clk}$  | 162.8 | -   | -   | ns      |

### 6.10.5.2. WARM RESET TIMING DIAGRAM



| Parameter                              | Symbol           | Min   | Typ | Max | Units   |
|----------------------------------------|------------------|-------|-----|-----|---------|
| SYNC active high pulse width           | $T_{sync\_high}$ | 1.0   | -   | -   | $\mu s$ |
| SYNC inactive to BIT_CLK startup delay | $T_{sync2clk}$   | 162.8 | -   | -   | ns      |

Warm Reset timing parameters

### 6.10.5.3. POWER DOWN TIMING DIAGRAM



AC-link low power mode timing parameters

| Parameter                              | Symbol          | Min | Typ | Max | Units   |
|----------------------------------------|-----------------|-----|-----|-----|---------|
| End of Slot 2 to BIT_CLK, SDATA_IN low | $T_{s2\_pdown}$ | -   | -   | 1.0 | $\mu s$ |

#### 6.10.5.4. AC-LINK CLOCK



**BIT\_CLK and SYNC Timing diagram**

#### BIT\_CLK and SYNC Timing Parameters

| Parameter                         | Symbol                   | Min | Typ    | Max | Units |
|-----------------------------------|--------------------------|-----|--------|-----|-------|
| BIT_CLK frequency                 |                          | -   | 12.288 | -   | MHz   |
| BIT_CLK period                    | T <sub>clk_period</sub>  | -   | 81.4   | -   | ns    |
| BIT_CLK output jitter             |                          | -   | -      | 750 | ps    |
| BIT_CLK high pulse width (note 2) | T <sub>clk_high</sub>    | 36  | 40.7   | 45  | ns    |
| BIT_CLK low pulse width (note 2)  | T <sub>clk_low</sub>     | 36  | 40.7   | 45  | ns    |
| SYNC frequency                    |                          | -   | 48.0   | -   | kHz   |
| SYNC period                       | T <sub>sync_period</sub> | -   | 20.8   | -   | μs    |
| SYNC high pulse width             | T <sub>sync_high</sub>   | -   | 1.3    | -   | μs    |
| SYNC low pulse width              | T <sub>sync_low</sub>    | -   | 19.5   | -   | μs    |

Note 1: 47.5-75 pF external load as per Table 54  
Note 2: Worst case duty cycle restricted to 45/55

### 6.10.5.5. DATA TRANSMISSION TIMING DIAGRAM



Data transmission timing diagram



Data Output and Input Timing Diagram

#### AC-link Output Valid Delay Timing Parameters

| Parameter                                      | Symbol          | Min | Typ | Max | Units |
|------------------------------------------------|-----------------|-----|-----|-----|-------|
| Output Valid Delay from rising edge of BIT_CLK | t <sub>co</sub> | -   | -   | 15  | ns    |

Note: 47.5-75pF external load as per Table 54

#### AC-link Input Setup and Hold Timing Parameters

| Parameter                               | Symbol             | Min | Typ | Max | Units |
|-----------------------------------------|--------------------|-----|-----|-----|-------|
| Input Setup to falling edge of BIT_CLK  | t <sub>setup</sub> | 10  | -   | -   | ns    |
| Input Hold from falling edge of BIT_CLK | t <sub>hold</sub>  | 10  | -   | -   | ns    |

#### AC-link Combined Rise or Fall plus Flight Timing Parameters

| Parameter                                                                                            | Symbol | Min | Typ | Max | Units |
|------------------------------------------------------------------------------------------------------|--------|-----|-----|-----|-------|
| BIT_CLK combined rise or fall plus flight time<br>(Primary Codec to Controller or Secondary)         |        | -   | -   | 7   | ns    |
| SDATA combined rise or fall plus flight time<br>(Output to Input)                                    |        | -   | -   | 7   | ns    |
| Note: Combined rise or fall plus flight times are provided for worst case scenario modeling purposes |        |     |     |     |       |



Signal rise and fall timing diagram

#### Signal Rise and Fall Time Parameters

| Parameter                    | Symbol            | Min | Typ | Max | Units |
|------------------------------|-------------------|-----|-----|-----|-------|
| BIT_CLK rise time (Note 1)   | $T_{rise_{clk}}$  | -   | -   | 6   | ns    |
| BIT_CLK fall time (Note 1)   | $T_{fall_{clk}}$  | -   | -   | 6   | ns    |
| SYNC rise time (Note 2)      | $T_{rise_{sync}}$ | -   | -   | 6   | ns    |
| SYNC fall time (Note 2)      | $T_{fall_{sync}}$ | -   | -   | 6   | ns    |
| SDATA_IN rise time (Note 3)  | $T_{rise_{din}}$  | -   | -   | 6   | ns    |
| SDATA_IN fall time (Note 3)  | $T_{fall_{din}}$  | -   | -   | 6   | ns    |
| SDATA_OUT rise time (Note 2) | $T_{rise_{dout}}$ | -   | -   | 6   | ns    |
| SDATA_OUT fall time (Note 2) | $T_{fall_{dout}}$ | -   | -   | 6   | ns    |

Note 1: BIT\_CLK rise/fall times with an external load of 75 pF

Note 2: SYNC and SDATA\_OUT rise/fall times with a external load of 75 pF

Note 3: SDATA\_IN rise/fall times with an external load of 60 pF

Note 4: Rise is from 10% to 90% of Vdd ( $V_{ol}$  to  $V_{oh}$ )

Note 5: Fall is from 90% to 10% of Vdd ( $V_{oh}$  to  $V_{ol}$ )

## 6.10.6. AC97 Interface Register List

| Module Name | Base Address |
|-------------|--------------|
| AC97        | 0x01C21400   |

| Register Name | Offset | Description                     |
|---------------|--------|---------------------------------|
| AC_CTL        | 0x00   | AC97 Control Register           |
| AC_FMT        | 0x04   | AC97 Format Register            |
| AC_CMD        | 0x08   | AC97 Command Register           |
| AC_CS         | 0x0C   | AC97 Codec Status Register      |
| AC_TX_FIFO    | 0x10   | AC97 TX FIFO Register           |
| AC_RX_FIFO    | 0x14   | AC97 RX FIFO Register           |
| AC_FCTL       | 0x18   | AC97 FIFO Control Register      |
| AC_FSTA       | 0x1C   | AC97 FIFO Status Register       |
| AC_INT        | 0x20   | AC97 Interrupt Control Register |
| ACISTA        | 0x24   | AC97 Interrupt Status Register  |
| AC_TX_CNT     | 0x28   | AC97 TX Counter register        |
| AC_RX_CNT     | 0x2C   | AC97 RX Counter register        |

## 6.10.7. AC97 Interface Register Description

### 6.10.7.1. AC97 CONTROL REGISTER

| Offset: 0x00 |             |         | Register Name: AC_CTL<br>Default Value: 0x0000_0000        |
|--------------|-------------|---------|------------------------------------------------------------|
| Bit          | Read/Wr ite | Default | Description                                                |
| 31:19        | /           | /       | /                                                          |
| 18           | R           | 0       | CS_RF<br>CODEC Status Register FLAG<br>0: Empty<br>1: Full |
| 17           | R           | 0       | CMD_RF<br>CMD Register FLAG<br>0: Empty<br>1: Full         |

| Offset: 0x00 |                        |                | <b>Register Name: AC_CTL</b><br><b>Default Value: 0x0000_0000</b>                                                                                                  |
|--------------|------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>   | <b>Read/Wr<br/>ite</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                 |
| 16           | R                      | 0              | RX_STATUS<br>RX Transfer Status<br>0: PCM IN<br>1: MIC IN                                                                                                          |
| 15:10        | /                      | /              | /                                                                                                                                                                  |
| 9            | R/W                    | 0              | RX_MODE<br>RX MODE<br>0: PCM IN<br>1: MIC IN<br><i>Note: this bit indicate which mode will be selected when PCM IN and MIC IN slots are available simultaneity</i> |
| 8            | R/W                    | 0              | ASS<br>Audio sample select with TX FIFO under run<br>0: sending 0 (invalid frame)<br>1: sending the last audio (valid frame)                                       |
| 7            | R/W                    | 0              | TXEN<br>0: Disable<br>1: Enable                                                                                                                                    |
| 6            | R/W                    | 0              | RXEN<br>0: Disable<br>1: Enable                                                                                                                                    |
| 5            | R/W                    | 0              | AC-link EN<br>0: Disable<br>1: Enable(SYNC signal transfer to Codec)                                                                                               |
| 4            | R/W                    | 0              | GEN<br>Globe Enable<br>A disable on this bit overrides any other block or channel enables and flushes all FIFOs.<br>0: Disable<br>1: Enable                        |
| 3:2          | /                      | /              | /                                                                                                                                                                  |
| 1            | R/W                    | 0              | WARM_RST<br>Warm reset                                                                                                                                             |

| <b>Offset: 0x00</b> |                        |                | <b>Register Name: AC_CTL</b><br><b>Default Value: 0x0000_0000</b>               |
|---------------------|------------------------|----------------|---------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Wr<br/>ite</b> | <b>Default</b> | <b>Description</b>                                                              |
|                     |                        |                | 0: Normal<br>1: Wake up codec from power down<br><i>Note: Self clear to "0"</i> |
| 0                   | /                      | /              | /                                                                               |

#### 6.10.7.2. AC97 FORMAT REGISTER

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: AC_FAT</b><br><b>Default Value: 0x0000_0000</b>                                                                                       |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                      |
| 31:9                | /                 | /              | /                                                                                                                                                       |
| 8:7                 | R/W               | 0              | TX_AUDIO_MODE<br>TX audio mode<br>00: 2-channel(PCM l/r main)<br>01: 6-channel(PCM l/r main, l/r surround, center, AFE)<br>10: Reserved<br>11: Reserved |
| 6                   | R/W               | 0              | DRA_SLOT_SEL<br>DRA additional slots select (available in 2-channel mode)<br>0: select slot 10, slot 11<br>1: select slot 7, slot 8                     |
| 5                   | R/W               | 0              | DRA_MODE<br>DRA mode<br>0 : Non-DRA<br>1 : DRA                                                                                                          |
| 4                   | R/W               | 0              | VRA_MODE<br>VRA Mode<br>0 : Non-VRA<br>1 : VRA                                                                                                          |
| 3:2                 | R/W               | 0              | TX_RES<br>TX Audio data resolution<br>00: 16-bit<br>01: 18-bit                                                                                          |

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: AC_FAT</b><br><b>Default Value: 0x0000_0000</b>                            |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                           |
|                     |                   |                | 10: 20-bit<br>11: Reserved                                                                   |
| 1:0                 | R/W               | 0              | RX_RES<br>RX Audio data resolution<br>00: 16-bit<br>01: 18-bit<br>10: 20-bit<br>11: Reserved |

#### 6.10.7.3. AC97 CODEC COMMAND REGISTER

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: AC_CMD</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|-------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                |
| 31:24               | /                 | /              | /                                                                 |
| 23                  | R/W               | 0              | OP<br>Read enable<br>0: Command write<br>1: Status read           |
| 22:16               | R/W               | 0x00           | CC_ADDR<br>Codec command address                                  |
| 15:0                | R/W               | 0x0000         | CC<br>Codec command data                                          |

#### 6.10.7.4. AC97 CODEC STATUS REGISTER

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: AC_CS</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                               |
| 31:23               | /                 | /              | /                                                                |

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: AC_CS</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                               |
| 22:16               | R                 | 0x00           | CS_ADDR<br>Codec status address                                  |
| 15:0                | R                 | 0x0000         | CS<br>Codec status data                                          |

#### 6.10.7.5. AC97 TX FIFO REGISTER

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: AC_TXFIFO</b><br><b>Default Value: 0x0000_0000</b>                                                                                                         |
|---------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                           |
| 31:0                | W                 | 0              | 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. |

#### 6.10.7.6. AC97 RX FIFO REGISTER

| <b>Offset: 0x14</b> |                   |                | <b>Register Name: AC_RXFIFO</b><br><b>Default Value: 0x0000_0000</b>                                                                                        |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                          |
| 31:0                | R                 | 0              | RX_DATA<br>Host can get one sample by reading this register. If in the PCM IN mode, the left channel sample data is first and then the right channel sample |

#### 6.10.7.7. AC97 FIFO CONTROL REGISTER

| <b>Offset: 0x18</b> |                   |                | <b>Register Name: AC_FCTL</b><br><b>Default Value: 0x0000_3078</b> |
|---------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:18               | /                 | /              | /                                                                  |
| 17                  | R/W               | 0              | FTX                                                                |

| Offset: 0x18 |            |         | Register Name: AC_FCTL<br>Default Value: 0x0000_3078                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              |            |         | Write “1” to flush TX FIFO, self clear to “0”                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 16           | R/W        | 0       | FRX<br>Write “1” to flush RX FIFO, self clear to “0”                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:8         | R/W        | 0x30    | TXTL<br>TX FIFO empty Trigger Level<br>Interrupt and DMA request trigger level for TX FIFO normal condition<br>Trigger Level = TXTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:3          | R/W        | 0x0F    | RXTL<br>RX FIFO Trigger Level<br>Interrupt and DMA request trigger level for RX FIFO normal condition<br>Trigger Level = RXTL + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2            | R/W        | 0       | TXIM<br>TX FIFO Input Mode(Mode0, 1)<br>0: Valid data at the MSB of AC_TXFIFO register<br>1: Valid data at the LSB of AC_TXFIFO register<br>Example for 18-bits transmitted audio sample:<br>Mode 0: FIFO_I[19:0] = {TXFIFO[31:14], 2'h0}<br>Mode 1: FIFO_I[19:0] = {TXFIFO[17:0], 2'h0}                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1:0          | R/W        | 0       | RXOM<br>RX FIFO Output Mode(0,1,2,3)<br>00: Expanding “0” at LSB of AC_RXFIFO register<br>01: Expanding received sample sign bit at MSB of AC_RXFIFO register<br>10: Truncating received samples at high half-word of AC_RXFIFO register and low half-word of AC_FIFO register is filled by “0”<br>11: Truncating received samples at low half-word of AC_RXFIFO register and high half-word of AC_FIFO register is expanded by its sign bit<br>Example for 18-bits received audio sample:<br>Mode0: RXFIFO[31:0] = {FIFO_O[19:2], 14'h0}<br>Mode 1: RXFIFO[31:0] = {14'FIFO_O[19], FIFO_O[19:2]}<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]} |

#### 6.10.7.8. AC97 FIFO STATUS REGISTER

| Offset: 0x1C |            |         | Register Name: AC_FSTA<br>Default Value: 0x0000_C000                                                                         |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                  |
| 31:16        | /          | /       | /                                                                                                                            |
| 15           | R          | 1       | 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 ( >=1 word ) |
| 14:7         | R          | 0x80    | TXE_CNT<br>TX FIFO Empty Space Word counter                                                                                  |
| 6            | R          | 0       | RXA<br>RX FIFO Available<br>0: No available data in RX FIFO<br>1: More than one sample in RX FIFO ( >=1 word )               |
| 5:0          | R          | 0       | RXA_CNT<br>RX FIFO Available Sample Word counter                                                                             |

#### 6.10.7.9. AC97 INTERRUPT CONTROL REGISTER

| Offset: 0x20 |            |         | Register Name: AC_INT<br>Default Value: 0x0000_0000                     |
|--------------|------------|---------|-------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                             |
| 31:10        | /          | /       | /                                                                       |
| 9            | R/W        | 0       | CODEC_GPIO_EN<br>Codec GPIO interrupt enable<br>0: Disable<br>1: Enable |
| 8            | R/W        | 0       | CREN<br>Codec Ready interrupt enable<br>0: Disable                      |

| Offset: 0x20 |            |         | Register Name: AC_INT<br>Default Value: 0x0000_0000                                                                                                        |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                |
|              |            |         | 1: Enable                                                                                                                                                  |
| 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                                                                                     |
| 4            | R/W        | 0       | TXEI_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                                                       |
| 3            | /          | /       | /                                                                                                                                                          |
| 2            | R/W        | 0       | RX_DRQ<br>RX FIFO Data Available DRQ Enable<br>When set to "1", RX FIFO DMA Request is asserted if Data is available in RX FIFO<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                                                                              |

#### 6.10.7.10. AC97 INTERRUPT STATUS REGISTER

| Offset: 0x24 |            |         | Register Name: AC_ISTA<br>Default Value: 0x0000_0010                                                                                                                                         |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                  |
| 31:10        | /          | /       | /                                                                                                                                                                                            |
| 9            | R/W        | 0       | CODEC_GPIO_INT<br>Codec GPIO interrupt<br>0: No pending IRQ<br>1: Codec GPIO interrupt                                                                                                       |
| 8            | R/W        | 0       | CR_INT<br>Codec Ready pending Interrupt<br>0: No pending IRQ<br>1: Codec Ready Pending Interrupt<br>Write “1” to clear this interrupt                                                        |
| 7            | /          | /       | /                                                                                                                                                                                            |
| 6            | R/W        | 0       | TXU_INT<br>TX FIFO Under run Pending Interrupt<br>0: No pending IRQ<br>1: FIFO Under run Pending Interrupt<br>Write “1” to clear this interrupt                                              |
| 5            | R/W        | 0       | TXO_INT<br>TX FIFO Overrun Pending Interrupt<br>0: No Pending IRQ<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 clear if interrupt condition fails. |
| 3:2          | /          | /       | /                                                                                                                                                                                            |
| 1            | R/W        | 0       | RXO_INT<br>RX FIFO Overrun Pending Interrupt<br>0: FIFO Overrun Pending<br>Write “1” to clear this interrupt                                                                                 |

| <b>Offset: 0x24</b> |                   |                | <b>Register Name: ACISTA</b><br><b>Default Value: 0x0000_0010</b>                                                                                                                             |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                            |
| 0                   | R/W               | 0              | RXA_INT<br>RX FIFO Available Pending Interrupt<br>0: No Pending IRQ<br>1: Data Available Pending IRQ<br>Write "1" to clear this interrupt or automatically clear if interrupt condition fails |

#### 6.10.7.11. AC97 TX COUNTER REGISTER

| <b>Offset: 0x28</b> |                   |                | <b>Register Name: AC_TX_CNT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                     |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                       |
| 31:0                | R/W               | 0              | TX_CNT<br>TX Sample counter<br>The audio sample number of writing into TX FIFO. When one sample is written by DMA or by host IO, the TX sample counter register increases by one. The TX 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 value. |

#### 6.10.7.12. AC97 RX COUNTER REGISTER

| <b>Offset: 0x2C</b> |                   |                | <b>Register Name: AC_RX_CNT</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                         |
|---------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                           |
| 31:0                | R/W               | 0              | RX_CNT<br>RX Sample counter<br>The audio sample number of writing into RX FIFO. When one sample is written by Codec, the RX sample counter register increases by one. The RX 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 value. |

## 6.10.8. AC97 Interface Special Requirement

### 6.10.8.1. PIN LIST

| Port Name   | Width | Direction | Description                                  |
|-------------|-------|-----------|----------------------------------------------|
| AC_BIT_CLK  | 1     | IN        | Digital Audio Serial Clock provided by Codec |
| AC_SYNC     | 1     | OUT       | Digital Audio Sample rate/sync               |
| AC_MCLK     | 1     | OUT       | AC97 Codec Input Mclk                        |
| AC_SDATA_IN | 1     | IN        | Digital Audio serial Data Input              |
| AC_SDTA_OUT | 1     | OUT       | Digital Audio serial Data Output             |

Note:BIT\_CLK is provided by AC97 Codec.

### 6.10.8.2. AC97 CLOCK REQUIREMENT

| Clock Name | Description                 | Requirement                        |
|------------|-----------------------------|------------------------------------|
| apb_clk    | APB bus clock               |                                    |
| s_clk      | AC97 serial access x1 clock | 24.576 MHz or 22.5792 MHz from CCU |

## 6.11. EMAC

### 6.11.1. Overview

The Ethernet MAC Controller enables the host to transmit and receive data over Ethernet in compliance with the IEEE 802.3-2002 standard. It supports 10M/100M external PHY with MII interface in both full and half duplex mode. A 16KB SRAM is provided to keep continuous data transmission. Besides, the flow control and DA/SA filter are also supported in EMAC module.

The EMAC features:

- Support industry-standard AMBA Host Bus (AHB) and fully comply with the AMBA Specification, Revision 2.0, support 32-bit Little Endian bus
- 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 filter
- Support loop back operation
- Provide MII Interface for external Ethernet PHY
- 3KB FIFO for TX
- 13KB FIFO for RX

### 6.11.2. EMAC Block Diagram



### 6.11.3. EMAC Operation Diagram

#### 6.11.3.1. TX OPERATION



### 6.11.3.2. RX OPERATION



Each received packet has 8-byte header followed with data of the reception packet which CRC field isn't included. The format of the 8-byte header is 4Dh, 41h, 43h, 01h, PKT\_SIZE low and PKT\_SIZE high

status low, status high,. The received packet must be WORD(32-bits) align. If there is not enough data for WORD(32-bits) align. The zero bytes are padded at the end of packet. The PKT\_SIZE would count the size of useful data, not including padding bytes and 8-bytes packet header.

The 8-bytes packet header is listed below:

| <b>Index</b> | <b>Value</b> | <b>Description</b>                                                |
|--------------|--------------|-------------------------------------------------------------------|
| BYTE0        | PKT_VLD      | Packet Valid Flag<br>0x01: packet valid<br>0x00: packet not valid |
| BYTE1        | 0x43         | ASCII code 'C'                                                    |
| BYTE2        | 0x41         | ASCII code 'A'                                                    |
| BYTE3        | 0x4d         | ASCII code 'M'                                                    |
| BYTE4        | PKT_STATUS   | High byte of received packet's status                             |
| BYTE5        | PKT_STATUS   | Low byte of received packet's status                              |
| BYTE6        | PKT_SIZE     | High byte of packet size                                          |
| BYTE7        | PKT_SIZE     | Low byte of packet size                                           |

The 2-bytes status is listed below:

| <b>Bit</b> | <b>Description</b>            |
|------------|-------------------------------|
| 15         | Reserved                      |
| 14         | Receive VLAN TYPE detected    |
| 13         | Receive Unsupported Op-code   |
| 12         | Receive Pause Control Frame   |
| 11         | Receive Control Frame         |
| 10         | Dribble Nibble                |
| 9          | Broadcast Packet              |
| 8          | Multicast Packet              |
| 7          | Receive OK                    |
| 6          | Length Out of Range           |
| 5          | Length Check Error            |
| 4          | CRC Error                     |
| 3          | Receive Code Violation        |
| 2          | Carrier Event Previously Seen |
| 1          | RXDV Event Previously Seen    |
| 0          | Packet Previously Ignored     |

## 6.12. GMAC

### 6.12.1. Overview

The GMAC controller enables a host to transmit and receive data over Ethernet in compliance with the IEEE 802.3-2002 standard. It supports 10M/100M/1000M external PHY with RGMII interface in both full and half duplex mode.

The GMAC-DMA is designed for packet-oriented data transfer based on a linked list of descriptors. 4KB TXFIFO and 16KB RXFIFO are provided to keep continuous transmission and reception. Flow Control, CRC Pad & Stripping, and address filtering are supported in this module as well.

It features:

- Support 10/100/1000-Mbps data transfer rates
- Support RGMII PHY interface
- Support both full-duplex and half-duplex operation
- Automatic CRC and pad generation controllable on a per-frame basis
- Options for Automatic Pad/CRC Stripping on receive frames
- Programmable frame length to support Standard or Jumbo Ethernet frames with sizes up to 16 KB
- Programmable Inter Frame Gap (40-96 bit times in steps of 8)
- Supports a variety of flexible address filtering modes
- Separate 32-bit status returned for transmission and reception packets
- Optimization for packet-oriented DMA transfers with frame delimiters
- Dual-buffer (ring) or linked-list (chained) descriptor chaining
- Descriptor architecture, allowing large blocks of data transfer with minimum CPU intervention; each descriptor can transfer up to 4 KB data
- Comprehensive status report for normal operation and transfers with errors
- 4KB TXFIFO for transmission packets and 16KB RXFIFO for reception packets
- Programmable interrupt options for different operational conditions

### 6.12.2. GMAC Block Diagram



## 6.13. Transport Stream

### 6.13.1. Overview

The transport stream controller is responsible for de-multiplexing and pre-processing the inputting multimedia data defined in ISO/IEC 13818-1.

The transport stream controller receives multimedia data stream from SSI (Synchronous Serial Port)/SPI (Synchronous Parallel Port) inputs and de-multiplexing the data into Packets by PID (Packet Identify). Before the Packet is stored to memory by DMA, it can be pre-processed by the Transport Stream Descrambler.

The transport stream controller can be used for almost all multimedia application cases, for example: DVB Set top Box, IPTV, Streaming-media Box, multi-media players and so on.

It features:

- Support industry-standard AMBA Host Bus (AHB) and it is fully compliant with the AMBA Specification, Revision 2.0. Supports 32-bit Little Endian bus.
- Support AHB 32-bit bus width
- One external SPI or SSI
- 32 channels PID filter
- Support multiple transport stream packet (188, 192, 204) formats
- 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
- Support interrupt
- Support DVB-CSA V1.1 descrambler

### 6.13.2. Transport Stream Block Diagram



### 6.13.3. Transport Stream Controller Register List

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

| <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_PCTLR            | 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_PCRCR  | TSF + 0x20 | TSF PCR Control Register                  |
| TSF_PCRDR  | 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  |
| TSD_CTLR   | TSD + 0x00 | TSD Control Register                      |
| TSD_STAR   | TSD + 0x04 | TSD Status Register                       |
| TSD_CWIR   | TSD + 0x1c | TSD Control Word Index Register           |
| TSD_CWR    | TSD + 0x20 | TSD Control Word Register                 |

## 6.13.4. Transport Stream Register Description

### 6.13.4.1. TSC CONTROL REGISTER

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

### 6.13.4.2. TSC STATUS REGISTER

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

### 6.13.4.3. TSC PORT CONTROL REGISTER

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: TSC_PCTRLR</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                    |
| 31:17               | /                 | /              | /                                                                     |
| 16                  | R/W               | 0              | TSOutPort0Ctrl<br>TS Output Port0 Control<br>0 – SPI<br>1 – SSI       |
| 15:2                | /                 | /              | /                                                                     |
| 1                   | R/W               | 0              | TSInPort1Ctrl<br>TS Input Port1 Control<br>0 – SPI<br>1 – SSI         |
| 0                   | R/W               | 0              | TSInPort0Ctrl<br>TS Input Port0 Control                               |

| <b>Offset: 0x10</b> |                   |                | <b>Register Name: TSC_PCTLR</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
|                     |                   |                | 0 – SPI<br>1 – SSI                                                   |

#### 6.13.4.4. TSC PORT PARAMETER REGISTER

| <b>Offset: 0x14</b> |                                                                                    |                | <b>Register Name: TSC_PPARR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |            |     |          |   |                                                                                    |   |                                                                            |   |                                                                      |   |                                                                       |   |                                                                      |
|---------------------|------------------------------------------------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------|-----|----------|---|------------------------------------------------------------------------------------|---|----------------------------------------------------------------------------|---|----------------------------------------------------------------------|---|-----------------------------------------------------------------------|---|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b>                                                                  | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |            |     |          |   |                                                                                    |   |                                                                            |   |                                                                      |   |                                                                       |   |                                                                      |
| 31:24               | R/W                                                                                | 0x00           | <p>TSOutPort0Par<br/>TS Output Port0 Parameters</p> <table border="1"> <thead> <tr> <th>Bit</th><th>Definition</th></tr> </thead> <tbody> <tr> <td>7:5</td><td>/</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> <tr> <td>3</td><td>CLOCK signal polarity<br/>0 : Rise edge capturing<br/>1: Fall edge capturing</td></tr> <tr> <td>2</td><td>ERROR signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> <tr> <td>1</td><td>DVALID signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> <tr> <td>0</td><td>PSYNC signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> </tbody> </table> | Bit | Definition | 7:5 | /        | 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 |
| Bit                 | Definition                                                                         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |            |     |          |   |                                                                                    |   |                                                                            |   |                                                                      |   |                                                                       |   |                                                                      |
| 7:5                 | /                                                                                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |            |     |          |   |                                                                                    |   |                                                                            |   |                                                                      |   |                                                                       |   |                                                                      |
| 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               |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |            |     |          |   |                                                                                    |   |                                                                            |   |                                                                      |   |                                                                       |   |                                                                      |
| 23:16               | /                                                                                  | /              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |            |     |          |   |                                                                                    |   |                                                                            |   |                                                                      |   |                                                                       |   |                                                                      |
| 15:8                | R/W                                                                                | 0x00           | <p>TSInPort1Par<br/>TS Input Port1 Parameters</p> <table border="1"> <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> <tr> <td>3</td><td>CLOCK signal polarity<br/>0 : Rise edge capturing<br/>1: Fall edge capturing</td></tr> <tr> <td>2</td><td>ERROR signal polarity<br/>0: High level active<br/>1: Low level active</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 | 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 |   |                                                                       |   |                                                                      |
| 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               |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |            |     |          |   |                                                                                    |   |                                                                            |   |                                                                      |   |                                                                       |   |                                                                      |

| <b>Offset: 0x14</b> |                                                                                    |                | <b>Register Name: TSC_PPARR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |                                                                       |            |                                                                      |     |                                                                                    |   |                                                                                    |   |                                                                            |   |                                                                       |   |                                                                       |   |                                                                      |
|---------------------|------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------------------------------------------------------------------|------------|----------------------------------------------------------------------|-----|------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------|---|----------------------------------------------------------------------------|---|-----------------------------------------------------------------------|---|-----------------------------------------------------------------------|---|----------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b>                                                                  | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            |                                                                       |            |                                                                      |     |                                                                                    |   |                                                                                    |   |                                                                            |   |                                                                       |   |                                                                       |   |                                                                      |
|                     |                                                                                    |                | <table border="1"> <tr> <td>1</td><td>DVALID signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> <tr> <td>0</td><td>PSYNC signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 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 |     |                                                                                    |   |                                                                                    |   |                                                                            |   |                                                                       |   |                                                                       |   |                                                                      |
| 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               |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |                                                                       |            |                                                                      |     |                                                                                    |   |                                                                                    |   |                                                                            |   |                                                                       |   |                                                                       |   |                                                                      |
|                     |                                                                                    |                | TSInPort0Par<br>TS Input Port0 Parameters <table border="1"> <thead> <tr> <th><b>Bit</b></th><th><b>Definition</b></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> <tr> <td>3</td><td>CLOCK signal polarity<br/>0 : Rise edge capturing<br/>1: Fall edge capturing</td></tr> <tr> <td>2</td><td>ERROR signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> <tr> <td>1</td><td>DVALID signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> <tr> <td>0</td><td>PSYNC signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> </tbody> </table> | <b>Bit</b> | <b>Definition</b>                                                     | 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  |   |                                                                      |
| <b>Bit</b>          | <b>Definition</b>                                                                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |                                                                       |            |                                                                      |     |                                                                                    |   |                                                                                    |   |                                                                            |   |                                                                       |   |                                                                       |   |                                                                      |
| 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               |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |                                                                       |            |                                                                      |     |                                                                                    |   |                                                                                    |   |                                                                            |   |                                                                       |   |                                                                       |   |                                                                      |
| 7:0                 | R/W                                                                                | 0x00           | TSInPort0Par<br>TS Input Port0 Parameters <table border="1"> <thead> <tr> <th><b>Bit</b></th><th><b>Definition</b></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> <tr> <td>3</td><td>CLOCK signal polarity<br/>0 : Rise edge capturing<br/>1: Fall edge capturing</td></tr> <tr> <td>2</td><td>ERROR signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> <tr> <td>1</td><td>DVALID signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> <tr> <td>0</td><td>PSYNC signal polarity<br/>0: High level active<br/>1: Low level active</td></tr> </tbody> </table> |            |                                                                       | <b>Bit</b> | <b>Definition</b>                                                    | 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 |
| <b>Bit</b>          | <b>Definition</b>                                                                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |                                                                       |            |                                                                      |     |                                                                                    |   |                                                                                    |   |                                                                            |   |                                                                       |   |                                                                       |   |                                                                      |
| 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               |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |                                                                       |            |                                                                      |     |                                                                                    |   |                                                                                    |   |                                                                            |   |                                                                       |   |                                                                       |   |                                                                      |

#### 6.13.4.5. TSC TSF INPUT MULTIPLEX CONTROL REGISTER

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

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

#### 6.13.4.6. TSC PORT OUTPUT MULTIPLEX CONTROL REGISTER

| <b>Offset: 0x28</b> |                   |                | <b>Register Name: TSC_TSFMUXR</b><br><b>Default Value: 0x0000_0000</b>                                                                                          |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                              |
| 31:4                | /                 | /              | /                                                                                                                                                               |
| 3:0                 | R/W               | 0x0            | TSPortOutputMuxCtrl<br>TS Port Output Multiplex Control<br>0x0 – Data from TSG<br>0x1 –Data from TS IN Port0<br>0x2 –Data from TS IN Port1<br>Others – Reserved |

#### 6.13.4.7. TSG CONTROL AND STATUS REGISTER

| <b>Offset: TSG+0x00</b> |                   |                | <b>Register Name: TSG_CSR</b><br><b>Default Value: 0x0000_0000</b>                                           |
|-------------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                           |
| 31:26                   | /                 | /              | /                                                                                                            |
| 25:24                   | R                 | 0              | TSGSts<br>Status for TS Generator<br>0: IDLE state<br>1: Running state<br>2: PAUSE state<br>Others: Reserved |

| Offset: TSG+0x00 |            |         | Register Name: TSG_CSR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                        |
|------------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                 |
| 23:10            | /          | /       | /                                                                                                                                                                                                                                                                                                                           |
| 9                | R/W        | 0       | <p>TSGLBufMode<br/>Loop Buffer Mode<br/>When set to '1', the TSG external buffer is in loop mode.</p>                                                                                                                                                                                                                       |
| 8                | R/W        | 0       | <p>TSGSyncByteChkEn<br/>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 receiver, TS Generator would come into PAUSE state. If the correspond interrupt is enable, the interrupt would happen.</p> |
| 7:3              | /          | /       | /                                                                                                                                                                                                                                                                                                                           |
| 2                | R/W        | 0       | <p>TSGPauseBit<br/>Pause Bit for TS Generator<br/>Write '1' to pause TS Generator. TS Generator would stop fetch new data from DRAM. After finishing this operation, this bit will clear to zero by hardware. In PAUSE state, write '1' to resume this state.</p>                                                           |
| 1                | R/W        | 0       | <p>TSGStopBit<br/>Stop Bit for TS Generator<br/>Write '1' to stop TS Generator. TS Generator would 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 clear to zero by hardware.</p>                                                    |
| 0                | R/W        | 0       | <p>TSGStartBit<br/>Start Bit for TS Generator<br/>Write '1' to start TS Generator. TS Generator would fetch data from DRAM and generate SPI stream to TS filter. This bit will clear to zero by hardware after TS Generator is running.</p>                                                                                 |

#### 6.13.4.8. TSG PACKET PARAMETER REGISTER

| Offset: TSG+0x04 | Register Name: TSG_PPR<br>Default Value: 0x0000_0000 |
|------------------|------------------------------------------------------|
|------------------|------------------------------------------------------|

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

#### 6.13.4.9. TSG INTERRUPT ENABLE AND STATUS REGISTER

| <b>Offset: TSG+0x08</b> |                   |                | <b>Register Name: TSG_IESTR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                           |
|-------------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                             |
| 31:20                   | /                 | /              | /                                                                                                                                                                                              |
| 19                      | R/W               | 0              | TSGEndIE<br>TS Generator (TSG) End Interrupt Enable<br>0: Disable<br>1: Enable<br>If set this bit, the interrupt would assert to CPU when all data in external DRAM are sent to TS PID filter. |
| 18                      | R/W               | 0              | TSGFFIE<br>TS Generator (TSG) Full Finish Interrupt Enable<br>0: Disable                                                                                                                       |

| Offset: TSG+0x08 |            |         | Register Name: TSG_IESTR<br>Default Value: 0x0000_0000                                             |
|------------------|------------|---------|----------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                        |
|                  |            |         | 1: Enable                                                                                          |
| 17               | R/W        | 0       | TSGHFIE<br>TS Generator (TSG) Half Finish Interrupt Enable<br>0: Disable<br>1: Enable              |
| 16               | R/W        | 0       | TSGErrSyncByteIE<br>TS Generator (TSG) Error Sync Byte Interrupt Enable<br>0: Disable<br>1: Enable |
| 15:4             | /          | /       | /                                                                                                  |
| 3                | R/W        | 0       | TSGEndSts<br>TS Generator (TSG) End Status<br>Write '1' to clear.                                  |
| 2                | R/W        | 0       | TSGFFSts<br>TS Generator (TSG) Full Finish Status<br>Write '1' to clear.                           |
| 1                | R/W        | 0       | TSGHFSts<br>TS Generator (TSG) Half Finish Status<br>Write '1' to clear.                           |
| 0                | R/W        | 0       | TSGErrSyncByteSts<br>TS Generator (TSG) Error Sync Byte Status<br>Write '1' to clear.              |

#### 6.13.4.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     | TSGCDF_N<br>TSG Clock Divide Factor (N)<br>The Numerator part of TSG Clock Divisor Factor. |
| 15:0             | R/W        | 0x0     | TSGCDF_D                                                                                   |

| <b>Offset: TSG+0x0c</b> |                   |                | <b>Register Name: TSG_CCR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                        |
|-------------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                        |
|                         |                   |                | 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)) / (16 * (D+1))$ .<br>F <sub>i</sub> is the input special clock of TSC, and D must not less than N. |

#### 6.13.4.11. TSG BUFFER BASE ADDRESS REGISTER

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

#### 6.13.4.12. TSG BUFFER SIZE REGISTER

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

#### 6.13.4.13. TSG BUFFER POINTER REGISTER

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

#### 6.13.4.14. TSF CONTROL AND STATUS REGISTER

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

#### 6.13.4.15. TSF PACKET PARAMETER REGISTER

| <b>Offset: TSF+0x04</b> |                   |                | <b>Register Name: TSF_PPR</b><br><b>Default Value: 0x0000_0000</b>                                         |
|-------------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                         |
| 31:28                   | R/W               | 0              | LostSyncThd<br>Lost Sync Packet Threshold<br>It is used for packet sync lost by checking the value of sync |

| <b>Offset: TSF+0x04</b> |                   |                | <b>Register Name: TSF_PPR</b><br><b>Default Value: 0x0000_0000</b>                                                                                   |
|-------------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                   |
|                         |                   |                | byte.                                                                                                                                                |
| 27:24                   | R/W               | 0              | SyncThd<br>Sync Packet Threshold<br>It is used for packet sync by checking the value of sync byte.                                                   |
| 23:16                   | R/W               | 0x47           | SyncByteVal<br>Sync Byte Value<br>This is the value of sync byte used in the TS Packet.                                                              |
| 15:10                   | /                 | /              | /                                                                                                                                                    |
| 9:8                     | R/W               | 0              | SyncMthd<br>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              | SyncBytePos<br>Sync Byte Position<br>0: the 1st byte position<br>1: the 5th byte position<br>Notes: This bit is only used for 192 bytes packet size. |
| 6:2                     | /                 | /              | /                                                                                                                                                    |
| 1:0                     | R/W               | 0              | PktSize<br>Packet Size<br>Byte Size for one TS packet<br>0: 188 bytes<br>1: 192 bytes<br>2: 204 bytes<br>3: Reserved                                 |

#### 6.13.4.16. TSF INTERRUPT ENABLE AND STATUS REGISTER

|                         |                                                                      |
|-------------------------|----------------------------------------------------------------------|
| <b>Offset: TSF+0x08</b> | <b>Register Name: TSF_IESTR</b><br><b>Default Value: 0x0000_0000</b> |
|-------------------------|----------------------------------------------------------------------|

| <b>Bit</b> | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | /                 | /              | /                                                                                                                                                                                                   |
| 19         | R/W               | 0              | <p><b>TSFFOIE</b><br/>           TS PID Filter (TSF) Internal FIFO Overrun Interrupt Enable<br/>           0: Disable<br/>           1: Enable</p>                                                  |
| 18         | R/W               | 0              | <p><b>TSFPPDIE</b><br/>           TS PCR Packet Detect Interrupt Enable<br/>           0: Disable<br/>           1: Enable</p>                                                                      |
| 17         | R/W               | 0              | <p><b>TSFCOIE</b><br/>           TS PID Filter (TSF) Channel Overlap Interrupt Global Enable<br/>           0: Disable<br/>           1: Enable</p>                                                 |
| 16         | R/W               | 0              | <p><b>TSFCDIE</b><br/>           TS PID Filter (TSF) Channel DMA Interrupt Global Enable<br/>           0: Disable<br/>           1: Enable</p>                                                     |
| 15:4       | /                 | /              | /                                                                                                                                                                                                   |
| 3          | R/W               | 0              | <p><b>TSFFOIS</b><br/>           TS PID Filter (TSF) Internal FIFO Overrun Status<br/>           Write '1' to clear.</p>                                                                            |
| 2          | R/W               | 0              | <p><b>TSFPPDIS</b><br/>           TS PCR Packet Found Status<br/>           When it is '1', one TS PCR Packet is found. Write '1' to clear.</p>                                                     |
| 1          | R                 | 0              | <p><b>TSFCOIS</b><br/>           TS PID Filter (TSF) Channel Overlap Status<br/>           It is global status for 16 channel. It would clear to zero after all channels status bits are clear.</p> |
| 0          | R                 | 0              | <p><b>TSFCDIS</b><br/>           TS PID Filter (TSF) Channel DMA status<br/>           It is global status for 16 channel. It would clear to zero after all channels status bits are clear.</p>     |

#### 6.13.4.17. TSF DMA INTERRUPT ENABLE REGISTER

| <b>Offset: TSF+0x10</b> |                   |                | <b>Register Name: TSF_DIER</b><br><b>Default Value: 0x0000_0000</b>          |
|-------------------------|-------------------|----------------|------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                           |
| 31:0                    | R/W               | 0x0            | DMAIE<br>DMA Interrupt Enable<br>DMA interrupt enable bits for channel 0~31. |

#### 6.13.4.18. TSF OVERLAP INTERRUPT ENABLE REGISTER

| <b>Offset: TSF+0x14</b> |                   |                | <b>Register Name: TSF_OIER</b><br><b>Default Value: 0x0000_0000</b>                  |
|-------------------------|-------------------|----------------|--------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                   |
| 31:0                    | R/W               | 0x0            | OLPIE<br>Overlap Interrupt Enable<br>Overlap interrupt enable bits for channel 0~31. |

#### 6.13.4.19. TSF DMA INTERRUPT STATUS REGISTER

| <b>Offset: TSF+0x18</b> |                   |                | <b>Register Name: TSF_DISR</b><br><b>Default Value: 0x3FFF_0000</b>                                                                                                                                                                                        |
|-------------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                         |
| 31:0                    | R/W               | 0x0            | DMAIS<br>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 both these bits and the corresponding DMA Interrupt Enable bits set, the TSF interrupt will generate. |

#### 6.13.4.20. TSF OVERLAP INTERRUPT STATUS REGISTER

| <b>Offset: TSF+0x1c</b> |                   |                | <b>Register Name: TSF_OISR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                                                    |
|-------------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
| 31:0                    | R/W               | 0x0            | OLPIS<br>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 both these bits and the corresponding Overlap Interrupt Enable bits set, the TSF interrupt will generate. |

#### 6.13.4.21. TSF PCR CONTROL REGISTER

| <b>Offset: TSF+0x20</b> |                   |                | <b>Register Name: TSF_PCRCR</b><br><b>Default Value: 0x0000_0000</b> |
|-------------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:17                   | /                 | /              | /                                                                    |
| 16                      | R/W               | 0              | PCRDE<br>PCR Detecting Enable<br>0: Disable<br>1: Enable             |
| 15:13                   | /                 | /              | /                                                                    |
| 12:8                    | R/W               | 0              | PCRCIND<br>Channel Index m for Detecting PCR packet (m from 0 to 31) |
| 7:1                     | /                 | /              | /                                                                    |
| 0                       | R                 | 0              | PCRLSB<br>PCR Contest LSB 1 bit<br>PCR[0]                            |

#### 6.13.4.22. TSF PCR DATA REGISTER

|                         |                                                                      |
|-------------------------|----------------------------------------------------------------------|
| <b>Offset: TSF+0x24</b> | <b>Register Name: TSF_PCRDR</b><br><b>Default Value: 0x0000_0000</b> |
|-------------------------|----------------------------------------------------------------------|

| <b>Bit</b> | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                           |
|------------|-------------------|----------------|----------------------------------------------|
| 31:0       | R                 | 0              | PCRMSB<br>PCR Data High 32 bits<br>PCR[33:1] |

#### 6.13.4.23. TSF CHANNEL ENABLE REGISTER

| <b>Offset: TSF+0x30</b> |                   |                | <b>Register Name: TSF_CENR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                 |
|-------------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                  |
| 31:0                    | R/W               | 0x0            | FilterEn<br>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. |

#### 6.13.4.24. TSF CHANNEL PES ENABLE REGISTER

| <b>Offset: TSF+0x34</b> |                   |                | <b>Register Name: TSF_CPER</b><br><b>Default Value: 0x0000_0000</b>                                                                                |
|-------------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                 |
| 31:0                    | R/W               | 0x0            | PSEn<br>PES Packet Enable for Channel 0~31<br>0: Disable<br>1: Enable<br>These bits should not be changed during the corresponding channel enable. |

#### 6.13.4.25. TSF CHANNEL DESCRAMBLE ENABLE REGISTER

| <b>Offset: TSF+0x38</b> |                   |                | <b>Register Name: TSF_CDER</b><br><b>Default Value: 0x0000_0000</b>                                                                                                         |
|-------------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                          |
| 31:0                    | R/W               | 0x0            | <p>DescEn</p> <p>Descramble Enable for Channel 0~31</p> <p>0: Disable</p> <p>1: Enable</p> <p>These bits should not be changed during the corresponding channel enable.</p> |

#### 6.13.4.26. TSF CHANNEL INDEX REGISTER

| <b>Offset: TSF+0x3c</b> |                   |                | <b>Register Name: TSF_CINDR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                              |
|-------------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                |
| 31:5                    | /                 | /              | /                                                                                                                                                                                                                 |
| 4:0                     | R/W               | 0x0            | <p>CHIND</p> <p>Channel Index</p> <p>This value is the channel index for channel private registers access.</p> <p>Range is from 0x00 to 0x1f.</p> <p>Address range of channel private registers is 0x40~0x7f.</p> |

#### 6.13.4.27. TSF CHANNEL CONTROL REGISTER

| <b>Offset: TSF+0x40</b> |                   |                | <b>Register Name: TSF_CCTRLR</b><br><b>Default Value: 0x0000_0000</b> |
|-------------------------|-------------------|----------------|-----------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                    |
| 31:0                    | /                 | /              | /                                                                     |

#### 6.13.4.28. TSF CHANNEL STATUS REGISTER

| <b>Offset: TSF+0x44</b> |                   |                | <b>Register Name: TSF_CSTAR</b><br><b>Default Value: 0x0000_0000</b> |
|-------------------------|-------------------|----------------|----------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                   |
| 31:0                    | /                 | /              | /                                                                    |

#### 6.13.4.29. TSF CHANNEL CW INDEX REGISTER

| <b>Offset: TSF+0x48</b> |                   |                | <b>Register Name: TSF_CCWIR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                     |
|-------------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                       |
| 31:3                    | /                 | /              | /                                                                                                                                                                                                                        |
| 2:0                     | R/W               | 0x0            | <p>CWIND<br/>Related Control Word Index<br/>Index to the control word used by this channel when Descramble Enable of this channel enable.<br/>This value is useless when the corresponding Descramble Enable is '0'.</p> |

#### 6.13.4.30. TSF CHANNEL PID REGISTER

| <b>Offset: TSF+0x4c</b> |                   |                | <b>Register Name: TSF_CPIDR</b><br><b>Default Value: 0x1ff_0000</b> |
|-------------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:16                   | R/W               | 0x1ff          | PIDMSK<br>Filter PID Mask for Channel                               |
| 15:0                    | R/W               | 0x0            | PIDVAL<br>Filter PID value for Channel                              |

#### 6.13.4.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       | TSFBufBAddr<br>Data Buffer Base Address for Channel<br>It is 4-word (16Bytes) align address. The LSB four bits should be zero. |

#### 6.13.4.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       | CHDMAIntThd<br>DMA Interrupt Threshold for Channel<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, when exceed the specified threshold value, one new interrupt is generated again.<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       | CHBufPktSz<br>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 (16 Bytes) aligned. The LSB four bits should be zero.                                                                                                                                                                                                                                                                                      |

#### 6.13.4.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       | <p>BufWrPtr<br/>Data Buffer Write Pointer (in Bytes)</p> <p>This value is changed by hardware, when data is filled into buffer, this pointer is increased.</p> <p>And this pointer can be set by software, but it should not be changed by software during the corresponding channel is enable.</p> |

#### 6.13.4.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            | /          | /       | /                                                                                                                                           |
| 20:0             | R/W        | 0       | <p>BufRdPtr<br/>Data Buffer Read Pointer (in Bytes)</p> <p>This pointer should be changed by software after the data of buffer is read.</p> |

#### 6.13.4.35. TSD CONTROL REGISTER

| Offset: TSD+0x00 |            |         | Register Name: TSD_CTLR<br>Default Value: 0x0000_0000                                |
|------------------|------------|---------|--------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                          |
| 31:2             | /          | /       |                                                                                      |
| 1:0              | R/W        | 0x0     | <p>DescArith<br/>Descramble Arithmetic<br/>00: DVB CSA V1.1<br/>Others: Reserved</p> |

#### 6.13.4.36. TSD STATUS REGISTER

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

#### 6.13.4.37. TSD CONTROL WORD INDEX REGISTER

| <b>Offset: TSD+0x1c</b> |                   |                | <b>Register Name: TSD_CWIR</b><br><b>Default Value: 0x0000_0000</b>                                                                                                                                                                  |
|-------------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                   |
| 31:3                    | /                 | /              | /                                                                                                                                                                                                                                    |
| 6:4                     | R/W               | 0x0            | CWI<br>Control Word Index<br>This value is the Control index for Control word access.<br>Range is from 0x00 to 0x7.                                                                                                                  |
| 3:2                     | /                 | /              | /                                                                                                                                                                                                                                    |
| 1:0                     | R/W               | 0x0            | CWII<br>Control Word Internal Index<br>0 – Odd Control Word Low 32-bit, OCW[31:0];<br>1 – Odd Control Word High 32-bit, OCW[63:32];<br>2 – Even Control Word Low 32-bit, ECW[31:0];<br>3 – Even Control Word High 32-bit, ECW[63:0]; |

#### 6.13.4.38. TSD CONTROL WORD REGISTER

| <b>Offset: TSD+0x20</b> |                   |                | <b>Register Name: TSD_CWR</b><br><b>Default Value: 0x0000_0000</b> |
|-------------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
| 31:0                    | R/W               | 0x0            | CWD<br>Content of Control Word corresponding to the TSD_CWIR       |

| <b>Offset: TSD+0x20</b> |                   |                | <b>Register Name: TSD_CWR</b><br><b>Default Value: 0x0000_0000</b> |
|-------------------------|-------------------|----------------|--------------------------------------------------------------------|
| <b>Bit</b>              | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                 |
|                         |                   |                | value                                                              |

### 6.13.5. Transport Stream Clock Requirement

| <b>Clock Name</b> | <b>Description</b>             | <b>Requirement</b>           |
|-------------------|--------------------------------|------------------------------|
| HCLK              | AHB bus clock                  |                              |
| TS_CLK            | Clock of TS Stream in SPI mode |                              |
| TSC_CLK           | TS serial clock from CCU       | $TSC\_CLK \geq 16 * TS\_CLK$ |

## 6.14. Smart Card Reader

### 6.14.1. Overview

The Smart Card Reader (SCR) is a communication controller that transmits data between the system and smart card. The controller can perform a complete smart card session, including card activation, card deactivation, cold/warm reset, Answer to Reset (ATR) response reception, and data transfer, etc.

It features:

- Support APB slave interface for easy integration with AMBA-based host systems
- Support the ISO/IEC 7816-3:1997(E) and EMV2000 (4.0) Specifications
- Perform functions needed for complete smart card sessions
- Support adjustable clock rate and bit rate
- Configurable automatic byte repetition
- Support commonly used communication protocols:
  - T=0: for asynchronous half-duplex character transmission
  - T=1: for asynchronous half-duplex block transmission
- Support FIFOs for receive and transmit buffers (up to 128 characters) with threshold
  - Support configurable timing functions: Smart card activation time, Smart card reset time, Guard time, Timeout timers
- Support synchronous and other non-ISO 7816 and non-EMV cards

### 6.14.2. Smart Card Reader Block Diagram



### 6.14.3. Smart Card Reader Timing Diagram

Please refer ISO/IEC 7816 and EMV2000 Specification.

### 6.14.4. Smart Card Reader Register List

| Module Name | Base Address |
|-------------|--------------|
|-------------|--------------|

| Module Name | Base Address |
|-------------|--------------|
| SCR0        | 0x01C2C400   |

| Register Name | Offset | Description                                        |
|---------------|--------|----------------------------------------------------|
| SCR_CSR       | 0x000  | Smart Card Reader Control and Status Register      |
| SCR_INTEN     | 0x004  | Smart Card Reader Interrupt Enable Register 1      |
| SCR_INTST     | 0x008  | Smart Card Reader Interrupt Status Register 1      |
| SCR_FCSR      | 0x00c  | Smart Card Reader FIFO Control and Status Register |
| SCR_FCNT      | 0x010  | Smart Card Reader RX and TX FIFO Counter Register  |
| SCR_RPT       | 0x014  | Smart Card Reader RX and TX Repeat Register        |
| SCR_DIV       | 0x018  | Smart Card Reader Clock and Baud Divisor Register  |
| SCR_LTIM      | 0x01c  | Smart Card Reader Line Time Register               |
| SCR_CTIM      | 0x020  | Smart Card Reader Character Time Register          |
| SCR_LCTRL     | 0x030  | Smart Card Reader Line Control Register            |
| SCR_FIFO      | 0x100  | Smart Card Reader RX and TX FIFO Access Point      |

## 6.14.5. Smart Card Reader Register Description

### 6.14.5.1. SMART CARD READER CONTROL AND STATUS REGISTER

| Offset: 0x0000 |            |         | Register Name: SCR_CSR<br>Default Value: 0x00000000                                                                           |
|----------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                   |
| 31             | R          | 0       | SCDET<br>Smart Card Detected<br>This bit is set to '1' when the <i>scdetect</i> input is active at least for a debounce time. |
| 30             | /          | /       | /                                                                                                                             |
| 24             | R/W        | 0       | SCDETPOL<br>Smart Card Detect Polarity<br>This bit set polarity of <i>scdetect</i> signal.                                    |

| Offset: 0x0000 |            |         | Register Name: SCR_CSR<br>Default Value: 0x00000000                                                                                                                         |
|----------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                                 |
|                |            |         | 0: Low Active<br>1: High Active                                                                                                                                             |
| 23:22          | R/W        | 0       | Protocol Selection (PTLSEL)<br>0x0 – T=0.<br>0x1 – T=1, no character repeating and no guard time is used when T=1 protocol is selected.<br>0x2 – Reserved<br>0x3 – Reserved |
| 21             | R/W        | 0       | ATRSTFLUSH<br>ATR Start Flush FIFO<br>When enabled, both FIFOs are flushed before the ATR is started.                                                                       |
| 20             | R/W        | 0       | TSRXE<br>TS Receive Enable<br>When set to '1', the TS character (the first ATR character) will be store in RXFIFO during card session.                                      |
| 19             | R/W        | 0       | CLKSTPPOL<br>Clock Stop Polarity<br>The value of the sclk output during the clock stop state.                                                                               |
| 18             | R/W        | 0       | PECRXE<br>Parity Error Character Receive Enable<br>Enables storage of the characters received with wrong parity in RX FIFO.                                                 |
| 17             | R/W        | 0       | MSBF<br>MSB First<br>When high, inverse bit ordering convention (msb to lsb) is used.                                                                                       |
| 16             | R/W        | 0       | DATAPOL<br>Data Plorarity<br>When high, inverse level convention is used (A='1', Z='0').                                                                                    |
| 15:12          | /          | /       | /                                                                                                                                                                           |
| 11             | R/W        | 0       | DEACTDeactivation. Setting of this bit initializes the deactivation sequence. When the deactivation is finished, the DEACT bit is automatically cleared.                    |
| 10             | R/W        | 0       | ACT<br>Activation. Setting of this bit initializes the activation sequence.                                                                                                 |

| <b>Offset: 0x0000</b> |                   |                | <b>Register Name: SCR_CSR</b><br><b>Default Value: 0x00000000</b>                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                       |                   |                | When the activation is finished, the ACT bit is automatically cleared.                                                                                                                                                                                                                                                                                                                                                                                   |
| 9                     | R/W               | 0              | <b>WARMRST</b><br>Warm Reset Command. Writing '1' to this bit initializes Warm Reset of the Smart Card. This bit is always read as '0'.                                                                                                                                                                                                                                                                                                                  |
| 8                     | R/W               | 0              | <b>CLKSTOP</b><br>Clock Stop. When this bit is asserted and the smart card I/O line is in 'Z' state, the SCR core stops driving of the smart card clock signal after the CLKSTOPDELAY time expires. The smart card clock is restarted immediately after the CLKSTOP signal is deasserted. New character transmission can be started after CLKSTARTDELAY time. The expiration of both times is signaled by the CLKSTOPRUN bit in the interrupt registers. |
| 7:3                   | /                 | /              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2                     | R/W               | 0              | <b>GINTEN</b><br>Global Interrupt Enable. When high, IRQ output assertion is enabled.                                                                                                                                                                                                                                                                                                                                                                    |
| 1                     | R/W               | 0              | <b>RXEN</b><br>Receiving Enable. When enabled the characters sent by the Smart Card are received by the UART and stored in RX FIFO. Receiving is internally disabled while a transmission is in progress.                                                                                                                                                                                                                                                |
| 0                     | R/W               | 0              | <b>TXEN</b><br>Transmission Enable. When enabled the characters are read from TX FIFO and transmitted through UART to the Smart Card.                                                                                                                                                                                                                                                                                                                    |

#### 6.14.5.2. SMART CARD READER INTERRUPT ENABLE REGISTER

| <b>Offset: 0x0004</b> |                   |                | <b>Register Name: SCR_INTEN</b><br><b>Default Value: 0x00000000</b> |
|-----------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| 31:24                 | /                 | /              | /                                                                   |
| 23                    | R/W               | 0              | <b>SCDEA</b><br>Smart Card Deactivation Interrupt Enable.           |

| Offset: 0x0004 |            |         | Register Name: SCR_INTEN                                      |
|----------------|------------|---------|---------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                   |
| 22             | R/W        | 0       | SCACT<br>Smart Card Activation Interrupt Enable.              |
| 21             | R/W        | 0       | SCINS<br>Smart Card Inserted Interrupt Enable.                |
| 20             | R/W        | 0       | SCREM<br>Smart Card Removed Interrupt Enable.                 |
| 19             | R/W        | 0       | ATRDONE<br>ATR Done Interrupt Enable.                         |
| 18             | R/W        | 0       | ATRFAIL<br>ATR Fail Interrupt Enable.                         |
| 17             | R/W        | 0       | C2CFULL<br>Two Consecutive Characters Limit Interrupt Enable. |
| 16             | R/W        | 0       | CLKSTOPRUN<br>Smart Card Clock Stop/Run Interrupt Enable.     |
| 15:13          | /          | /       | /                                                             |
| 12             | R/W        | 0       | RXPERR<br>RX Parity Error Interrupt Enable.                   |
| 11             | R/W        | 0       | RXDONE<br>RX Done Interrupt Enable.                           |
| 10             | R/W        | 0       | RXFIFOTHD<br>RX FIFO Threshold Interrupt Enable.              |
| 9              | R/W        | 0       | RXFIFOFULL<br>RX FIFO Full Interrupt Enable.                  |
| 8              | /          | /       | /                                                             |
| 7:5            | /          | /       | /                                                             |
| 4              | R/W        | 0       | TXPERR<br>TX Parity Error Interrupt Enable.                   |
| 3              | R/W        | 0       | TXDONE<br>TX Done Interrupt Enable.                           |
| 2              | R/W        | 0       | TXFIFOTHD<br>TX FIFO Threshold Interrupt Enable.              |
| 1              | R/W        | 0       | TXFIFOEMPTY                                                   |

| <b>Offset: 0x0004</b> |                   |                | <b>Register Name: SCR_INTEN</b><br><b>Default Value: 0x00000000</b> |
|-----------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
|                       |                   |                | TX FIFO Empty Interrupt Enable.                                     |
| 0                     | R/W               | 0              | TXFIFODONE<br>TX FIFO Done Interrupt Enable.                        |

#### 6.14.5.3. SMART CARD READER INTERRUPT STATUS REGISTER

This 16-bit register provides information about the state of each interrupt bit. You can clear the register bits individually by writing '1' to a bit you intend to clear.

| <b>Offset: 0x0008</b> |                   |                | <b>Register Name: SCR_INTST</b><br><b>Default Value: 0x00000000</b>                                                                          |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                           |
| 31:24                 | /                 | /              | /                                                                                                                                            |
| 23                    | R/W               | 0              | SCDEA<br>Smart Card Deactivation Interrupt. When enabled, this interrupt is asserted after the Smart Card deactivation sequence is complete. |
| 22                    | R/W               | 0              | SCACT<br>Smart Card Activation Interrupt. When enabled, this interrupt is asserted after the Smart Card activation sequence is complete.     |
| 21                    | R/W               | 0              | SCINS<br>Smart Card Inserted Interrupt. When enabled, this interrupt is asserted after the smart card insertion.                             |
| 20                    | R/W               | 0              | SCREM<br>Smart Card Removed Interrupt. When enabled, this interrupt is asserted after the smart card removal.                                |
| 19                    | R/W               | 0              | ATRDONE<br>ATR Done Interrupt. When enabled, this interrupt is asserted after the ATR sequence is successfully completed.                    |
| 18                    | R/W               | 0              | ATRFAIL<br>ATR Fail Interrupt. When enabled, this interrupt is asserted if the ATR sequence fails.                                           |
| 17                    | R/W               | 0              | C2CFULL<br>Two Consecutive Characters Limit Interrupt. When enabled, this interrupt is asserted if the time between two consecutive          |

| Offset: 0x0008 |            |         | Register Name: SCR_INTST<br>Default Value: 0x00000000                                                                                                                                                                                                                                                                                                      |
|----------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                |
|                |            |         | characters, transmitted between the Smart Card and the Reader in both directions, is equal the Two Characters Delay Limit described below. The C2CFULL interrupt is internally enabled from the ATR start to the deactivation or ATR restart initialization. It is recommended to use this counter to detect unresponsive Smart Cards.                     |
| 16             | R/W        | 0       | <p>CLKSTOPRUN</p> <p>Smart Card Clock Stop/Run Interrupt. When enabled, this interrupt is asserted in two cases:</p> <p>When the smart card clock is stopped.</p> <p>When the new character can be started after the clock restart.</p> <p>To distinguish between the two interrupt cases, we recommend reading the CLKSTOP bit in SCR_CTRL1 register.</p> |
| 15:13          | /          | /       | /                                                                                                                                                                                                                                                                                                                                                          |
| 12             | R/W        | 0       | <p>RXPERR</p> <p>RX Parity Error Interrupt. When enabled, this interrupt is asserted after the character with wrong parity was received when the number of repeated receptions exceeds RXREPEAT value or T=1 protocol is used.</p>                                                                                                                         |
| 11             | R/W        | 0       | <p>RXDONE</p> <p>RX Done Interrupt. When enabled, this interrupt is asserted after a character was received from the Smart Card.</p>                                                                                                                                                                                                                       |
| 10             | R/W        | 0       | <p>RXFIFOTHD</p> <p>RX FIFO Threshold Interrupt. When enabled, this interrupt is asserted if the number of bytes in RX FIFO is equal or exceeds the RX FIFO threshold.</p>                                                                                                                                                                                 |
| 9              | R/W        | 0       | <p>RXFIFOFULL</p> <p>RX FIFO Full Interrupt. When enabled, this interrupt is asserted if the RX FIFO is filled up.</p>                                                                                                                                                                                                                                     |
| 8:5            | /          | /       | /                                                                                                                                                                                                                                                                                                                                                          |
| 4              | R/W        | 0       | <p>TXPERR</p> <p>TX Parity Error Interrupt. When enabled, this interrupt is asserted if the Smart Card signals wrong character parity during the guard time after the character transmission was repeated TXREPEAT times or T=1 protocol is used.</p>                                                                                                      |
| 3              | R/W        | 0       | <p>TXDONE</p> <p>TX Done Interrupt. When enabled, this interrupt is asserted after one character was transmitted to the smart card.</p>                                                                                                                                                                                                                    |

| Offset: 0x0008 |            |         | Register Name: SCR_INTST                                                                                                                                          |
|----------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                       |
| 2              | R/W        | 0       | TXFIFOTHD<br>TX FIFO Threshold Interrupt. When enabled, this interrupt is asserted if the number of bytes in TX FIFO is equal or less than the TX FIFO threshold. |
| 1              | R/W        | 0       | TXFIFOEMPTY<br>TX FIFO Empty Interrupt. When enabled, this interrupt is asserted if the TX FIFO is emptied out.                                                   |
| 0              | R/W        | 0       | TXFIFODONE<br>TX FIFO Done Interrupt. When enabled, this interrupt is asserted after all bytes from TX FIFO were transferred to the Smart Card.                   |

#### 6.14.5.4. SMART CARD READER FIFO CONTROL AND STATUS REGISTER

| Offset: 0x000c |            |         | Register Name: SCR_FCSR                                                            |
|----------------|------------|---------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                        |
| 31:11          | /          | /       | /                                                                                  |
| 10             | R/W        | 0       | RXFIFOFLUSH<br>Flush RX FIFO. RX FIFO is flushed, when '1' is written to this bit. |
| 9              | R          | 0       | RXFIFOFULL<br>RX FIFO Full.                                                        |
| 8              | R          | 1       | RXFIFOEMPTY<br>RX FIFO Empty.                                                      |
| 7:3            | /          | /       | /                                                                                  |
| 2              | R/W        | 0       | TXFIFOFLUSH<br>Flush TX FIFO. TX FIFO is flushed, when '1' is written to this bit. |
| 1              | R          | 0       | TXFIFOFULL<br>TX FIFO Full.                                                        |
| 0              | R          | 1       | TXFIFOEMPTY<br>TX FIFO Empty.                                                      |

#### 6.14.5.5. SMART CARD READER FIFO COUNT REGISTER

| Offset: 0x0010 |            |         | Register Name: SCR_FIFOCNT<br>Default Value: 0x00000000                                                                                                                                |
|----------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                                            |
| 31:24          | R/W        | 0       | RXFTH<br>RX FIFO Threshold<br>These bits set the interrupt threshold of RX FIFO. The interrupt is asserted when the number of bytes it receives is equal to, or exceeds the threshold. |
| 23:16          | R/W        | 0       | TXFTH<br>TX FIFO Threshold<br>These bits set the interrupt threshold of TX FIFO. The interrupt is asserted when the number of bytes in TX FIFO is equal to or less than the threshold. |
| 15:8           | R          | 0       | RXFCNT<br>RX FIFO Counter<br>These bits provide the number of bytes stored in the RXFIFO.                                                                                              |
| 7:0            | R          | 0       | TXFCNT<br>TX FIFO Counter<br>These bits provide the number of bytes stored in the TXFIFO.                                                                                              |

#### 6.14.5.6. SMART CARD READER REPEAT CONTROL REGISTER

| Offset: 0x0014 |            |         | Register Name: SCR_REPEAT<br>Default Value: 0x00000000                                                                                                                                                                                                     |
|----------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                                                                                                                |
| 15:8           | /          | /       | /                                                                                                                                                                                                                                                          |
| 7:4            | R/W        | 0       | RXRPT<br>RX Repeat<br>This is a 4-bit register that specifies the number of attempts to request character re-transmission after wrong parity was detected. The re-transmission of the character is requested using the error signal during the guard time. |
| 3:0            | R/W        | 0       | TXRPT                                                                                                                                                                                                                                                      |

| <b>Offset: 0x0014</b> |                   |                | <b>Register Name: SCR_REPEAT</b><br><b>Default Value: 0x00000000</b>                                                                                                                     |
|-----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                       |
|                       |                   |                | <p>TX Repeat</p> <p>This is a 4-bit register that specifies the number of attempts to re-transmit the character after the Smart Card signals the wrong parity during the guard time.</p> |

#### 6.14.5.7. SMART CARD READER CLOCK DIVISOR REGISTER

| <b>Offset: 0x0018</b> |                   |                | <b>Register Name: SCR_CLKDIV</b><br><b>Default Value: 0x00000000</b>                                                                                                                                                                                 |
|-----------------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                   |
| 31:16                 | R/W               | 0              | <p>BAUDDIV</p> <p>Baud Clock Divisor. This 16-bit register defines the divisor value used to generate the Baud Clock impulses from the system clock.</p>                                                                                             |
| 15:0                  | R/W               | 0              | <p>SCCDIV</p> <p>Smart Card Clock Divisor. This 16-bit register defines the divisor value used to generate the Smart Card Clock from the system clock.</p> <p>is the frequency of Smart Card Clock Signal.</p> <p>is the frequency of APB Clock.</p> |

#### 6.14.5.8. SMART CARD READER LINE TIME REGISTER

| <b>Offset: 0x001c</b> |                   |                | <b>Register Name: SCR_LTIM</b><br><b>Default Value: 0x00000000</b>               |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                               |
| 31:24                 | /                 | /              | /                                                                                |
| 23:16                 | R/W               | 0              | <p>ATR</p> <p>ATR Start Limit. This 16-bit register defines the maximum time</p> |

| <b>Offset: 0x001c</b> |                   |                | <b>Register Name: SCR_LTIM</b><br><b>Default Value: 0x00000000</b>                                                                                                                                                                                  |
|-----------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                  |
|                       |                   |                | <p>between the rising edge of the <i>scrstn</i> signal and the start of ATR response.</p> <p>ATR Start Limit = 128* ATR*.</p>                                                                                                                       |
| 15:8                  | R/W               | 0              | <p><b>RST</b></p> <p>Reset Duration. This 16-bit register sets the duration of the Smart Card reset sequence. This value is same for the cold and warm reset.</p> <p>Cold/Warm Reset Duration = 128* RST*.</p>                                      |
| 7:0                   | R/W               | 0              | <p><b>ACT</b></p> <p>Activation/Deactivation Time. This 16-bit register sets the duration of each part of the activation and deactivation sequence.</p> <p>Activation/Deactivation Duration = 128* ACT *.</p> <p>is the Smart Card Clock Cycle.</p> |

#### 6.14.5.9. SMART CARD READER CHARACTER TIME REGISTER

| <b>Offset: 0x0020</b> |                   |                | <b>Register Name: SCR_CTIM</b><br><b>Default Value: 0x00000000</b>                                                                                                                                                                                             |
|-----------------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                             |
| 31:16                 | R/W               | 0              | <p><b>CHARLIMIT</b></p> <p>Character Limit. This 16-bit register sets the maximum time between the leading edges of two consecutive characters. The value is ETUs.</p>                                                                                         |
| 15:8                  | /                 | /              | /                                                                                                                                                                                                                                                              |
| 7:0                   | R/W               | 0              | <p><b>GUARDTIME</b></p> <p>Character Guard time. This 8-bit register sets a delay at the end of each character transmitted from the Smart Card Reader to the Smart Card. The value is in ETUs. The parity error is besides signaled during the guard time.</p> |

#### 6.14.5.10. SMART CARD READER LINE CONTROL REGISTER

This register provides direct access to smart card pads without serial interface assistance. You can use this register feature with synchronous and any other non-ISO 7816 and non-EMV cards.

| Offset: 0x0030 |                   |                | <b>Register Name: SCR_PAD</b><br><b>Default Value: 0x00000000</b>                                                                                                                 |
|----------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>     | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                |
| 31:8           | /                 | /              | /                                                                                                                                                                                 |
| 7              | R/W               | 0              | DSCVPPPP<br>Direct Smart Card Vpp Pause/Prog. It provides direct access to SCVPPPP output.                                                                                        |
| 6              | R/W               | 0              | DSCVPSEN<br>Direct Smart Card Vpp Enable. It provides direct access to SCVPSEN output.                                                                                            |
| 5              | R/W               | 0              | AUTOADEAVPP<br>Automatic Vpp Handling. When high, it enables automatic handling of DSVPPEN and DSVPPP signals during activation and deactivation sequence.                        |
| 4              | R/W               | 0              | DSCVCC<br>Direct Smart Card VCC. When DIRACCPADS='1', the DSCVCC bit provides direct access to SCVCC pad.                                                                         |
| 3              | R/W               | 0              | DSCRST<br>Direct Smart Card Clock. When DIRACCPADS='1', the DSCRST bit provides direct access to SCRST pad.                                                                       |
| 2              | R/W               | 0              | DSCLK<br>Direct Smart Card Clock. When DIRACCPADS='1', the DSCLK bit provides direct access to SCCLK pad.                                                                         |
| 1              | R/W               | 0              | DSCIO<br>Direct Smart Card Input/Output. When DIRACCPADS='1', the DSCIO bit provides direct access to SCIO pad.                                                                   |
| 0              | R/W               | 0              | DIRACCPADS<br>Direct Access to Smart Card Pads. When high, it disables a serial interface functionality and enables direct control of the smart card pads using following 4 bits. |

#### 6.14.5.11. SMART CARD READER FIFO DATA REGISTER

| Offset: 0x0100 |  | <b>Register Name: SCR_FIFO</b><br><b>Default Value: 0x00000000</b> |
|----------------|--|--------------------------------------------------------------------|
|                |  |                                                                    |

| <b>Bit</b> | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | /                 | /              | /                                                                                                                                                                                            |
| 7:0        | R/W               | 0              | FIFO_DATA<br>This 8-bit register provides access to the RX and TX FIFO buffers. The TX FIFO is accessed during the APB write transfer. The RX FIFO is accessed during the APB read transfer. |

## 6.14.6. Smart Card Reader Special Requirement

### CLOCK GENERATOR

The Clock Generator generates the Smart Card Clock signal and the Baud Clock Impulse signal, used in timing the Smart Card Reader.

The Smart Card Clock signal is used as the main clock for the smart card. Its frequency can be adjusted using the Smart Card Clock Divisor (SCCDIV). This value is used to divide the system clock. The SCCLK frequency is given by the following equation:

$$f_{scclk} = \frac{f_{sysclk}}{2 * (SCCDIV + 1)}$$

- Smart Card Clock Frequency
- System Clock (PCLK) Frequency

The Baud Clock Impulse signal is used to transmit and receive serial between the Smart Card Reader and the Smart Card. The baud rate can be modified using the Baud Clock Divisor (BAUDDIV). The value is used to divide the system clock. The BUAD rate is given by the following equation:

$$BAUD = \frac{f_{sysclk}}{2 * (BAUDDIV + 1)}$$

- Baud rate of the data stream between Smart Card and Reader

The duration of one bit, Elementary Time Unit (ETU), is defined in the ISO/IEC 7816-3 specification. During the first answer to reset response after the cold reset, the initial ETU must be equal to 372 Smart Card Clock Cycles.

$$\frac{1}{BAUD} = ETU = \frac{372}{f_{scclk}}$$

In this case, the BAUDDIV should be

$$BAUDDIV = \frac{372 * f_{sysclk}}{2 * f_{scclk}} - 1 = 372 * (SCCDIV + 1) - 1$$

After the ATR is completed, the ETU can be changed according to Smart Card abilities.

$$\frac{1}{BAUD} = ETU = \frac{F}{D} * \frac{1}{f_{seclk}}$$

Parameters F and D are defined in the ISO/IEC 7816-3 Specification.

### 6.14.7. SCIO Pad Configuration



## 6.15. SATA Host

### 6.15.1. Overview

The SATA/AHCI Interface implements the Serial Advanced Technology Attachment (SATA) storage interface for physical storage devices.

The SATA/AHCI Interface features:

- Support SATA 1.5Gb/s and SATA 3.0Gb/s
- Comply with SATA Spec. 2.6, and AHCI Revision 1.3 specifications
- Support industry-standard AMBA High-Performance Bus (AHB) and it is fully compliant with the AMBA Specification, Revision 2.0. Supports 32-bit Little Endian
- OOB signaling detection and generation
- SATA 1.5Gb/s and SATA 3.0Gb/s speed negotiation when Tx OON signal is selected
- Support device hot-plugging
- Support power management features including automatic Partial to Slumber transition
- Internal DMA Engine for command and data transaction
- Support hardware-assisted Native Command Queuing (NCQ) up to 32 entries
- Support external SATA (eSATA)

### 6.15.2. SATA\_AHCI Timing Diagram

Please refer to Serial ATA Specification Rev. 2.6 and Serial ATA Advanced Host Controller Interface (AHCI) Specification Rev. 1.1.

## 6.16. CAN

### 6.16.1. Overview

The CAN module is a controller for the Controller Area Network (CAN) used in automotive and general industrial environments. It implements the CAN 2.0A/B protocol as defined in the BOSCH CAN bus specification 2.0.

It features:

- Support industry-standard AMBA Peripheral Bus (APB) and it is fully compliant with the AMBA Specification, Revision 2.0
- Support APB 32-bit bus width operation
- Support the CAN 2.0A and 2.0B protocol specification
- Programmable data rate up to 1Mbps
- 64-byte receive buffers
- Support one shot transmission option
- Support two configurable filter modes
- Support listen-only mode
- Support self-test mode

## 6.16.2. CAN System Block Diagram



## 6.16.3. CAN Bit Time Configuration



$NBT \times BPR = f_{base} / f_{canbus}, f_{base} = f_{osc} / 2 = 1 / (2 \times t_{clk}), (NBT = 8\sim25 \text{ recommended})$

$TQ = 2 \times t_{clk} \times (32 \times BRP.5 + 16 \times BRP.4 + 8 \times BRP.3 + 4 \times BRP.2 + 2 \times BRP.1 + BRP.0 + 1)$

$t_{clk} = 1/f_{osc}$

$t_{syncseg} = 1 \times TQ$

$t_{tseg1} = TQ \times (8 \times TSEG1.3 + 4 \times TSEG1.2 + 2 \times TSEG1.1 + TSEG1.0 + 1)$

$t_{tseg2} = TQ \times (4 \times TSEG2.2 + 2 \times TSEG2.1 + TSEG2.0 + 1)$

## 6.17. Keypad

### 6.17.1. Overview

The keypad interface is used to connect external keypad devices. It can provide up to 8 rows and 8 columns. Key press or key release can be detected to the CPU by an interrupt. To prevent the switching noises, internal debouncing filter is provided.

It features:

- Support industry-standard AMBA Peripheral Bus (APB) and is fully compliant with the AMBA Specification, Revision 2.0.
- Interrupt for key press or key release
- Internal debouncing filter to prevent the switching noises

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

## 6.17.3. Keypad Interface Register Description

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

| <b>Offset: 0x00</b> |                   |                | <b>Register Name: KP_CTL</b><br><b>Default Value: 0x0000_0000</b> |
|---------------------|-------------------|----------------|-------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                |
|                     |                   |                | 0: Disable<br>1: Enable                                           |

### 6.17.3.2. KEYPAD TIMING REGISTER

| <b>Offset: 0x04</b> |                   |                | <b>Register Name: KP_TIMING</b><br><b>Default Value: 0x0200_0100</b>                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:16               | R/W               | 0x200          | <p><b>DBC_CYCLE</b><br/>Keypad Debounce Clock Cycle n<br/>It is used for filter switching noises. When row input is low level, the Keypad Interface would delay (n+1) clock to check whether it is still keeping on low level. If it is true, the Keypad Interface would scan the external keypad's state and get these state into internal registers. After scan, the interrupt is generated if enabled.</p> <p>Notes: The value below 0x10 can't be used.</p> |
| 15:0                | R/W               | 0x100          | <p><b>SCAN_CYCLE</b><br/>Keypad Scan Period Clock Cycle n<br/>When the Keypad Interface is enabled, it would scan the external keypad in period. The period time is <math>8*(n+1)/kp\_clk</math>. The kp_clk is input clock for Keypad Interface from CCU.</p> <p>Notes: The value below 0x10 can't be used.</p>                                                                                                                                                |

### 6.17.3.3. KEYPAD INTERRUPT CONFIGURE REGISTER

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: KP_INT_CFG</b><br><b>Default Value: 0x0000_0000</b>                                 |
|---------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                    |
| 31:2                | /                 | /              | /                                                                                                     |
| 1                   | R/W               | 0              | <p><b>REDGE_INT_EN</b><br/>Keypad input rising edge (key release) interrupt enable<br/>0: Disable</p> |

| <b>Offset: 0x08</b> |                   |                | <b>Register Name: KP_INT_CFG</b><br><b>Default Value: 0x0000_0000</b>                             |
|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                |
|                     |                   |                | 1: Enable                                                                                         |
| 0                   | R/W               | 0              | FEDGE_INT_EN<br>Keypad input falling edge (key press) interrupt enable<br>0: Disable<br>1: Enable |

#### 6.17.3.4. KEYPAD INTERRUPT STATUS REGISTER

| <b>Offset: 0x0C</b> |                   |                | <b>Register Name: KP_INT_STA</b><br><b>Default Value: 0x0000_0000</b>                                                                                                             |
|---------------------|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>          | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                |
| 31:2                | /                 | /              | /                                                                                                                                                                                 |
| 1                   | R/W               | 0              | REDGE_FLAG<br>Keypad input rising edge (key release) interrupt status<br>When it is '1', the key released interrupt occurred.<br>The interrupt is cleared when write '1'.         |
| 0                   | R/W               | 0              | FEDGE_FLAG<br>Keypad input falling edge (key press) interrupt status<br>When it is '1', the corresponding pressed interrupt occurred.<br>The interrupt is cleared when write '1'. |

#### 6.17.3.5. KEYPAD INPUT DATA REGISTER 0

| <b>Offset: 0x10</b>  |                   |                | <b>Register Name: KP_IN0</b><br><b>Default Value: 0xffff_ffff</b>   |
|----------------------|-------------------|----------------|---------------------------------------------------------------------|
| <b>Bit</b>           | <b>Read/Write</b> | <b>Default</b> | <b>Description</b>                                                  |
| [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) |

### 6.17.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) |

## 6.17.4. Keypad Interface Special Requirement

### 6.17.4.1. KEYPAD INTERFACE PIN LIST

| Port Name | Width | Direction | Description |
|-----------|-------|-----------|-------------|
| KP_OUT    | 8     | OUT       |             |
| KP_IN     | 8     | IN        |             |

# Appendix A

## Glossary

For Allwinnertech Only

**A**

|     |                              |                                                                                                                                                                                                                             |
|-----|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AES | Advanced Encryption Standard | A specification for the encryption of electronic data established by the U.S.National Institute of Standards and Technology (NIST) in 2001                                                                                  |
| AGC | Automatic Gain Control       | An adaptive system found in electronic devices that automatically controls the gain of a signal: the average output signal level is fed back to adjust the gain to an appropriate level for a range of input signal levels. |
| AHB | AMBA High-speed Bus          | A bus protocol introduced in Advanced Microcontroller Bus Architecture version 2 published by ARM Ltd company                                                                                                               |
| APB | Advanced Peripheral Bus      | APB is designed for low bandwidth control accesses, which has an address and data phase similar to AHB, but a much reduced, low complexity signal list (for example no bursts).                                             |
| AVS | Audio Video Standard         | A compression standard for digital audio and video                                                                                                                                                                          |

**C**

|     |                         |                                                                                                                                                           |
|-----|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| CIR | Consumer IR             | The CIR (Consumer IR) interface is used for remote control through infra-red light                                                                        |
| CRC | Cyclic Redundancy Check | A type of hash function used to produce a checksum in order to detect errors in data storage or transmission                                              |
| CSI | CMOS 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 |

**D**

|      |                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DES  | Data Encryption Standard              | A previously predominant algorithm for the encryption of electronic data                                                                                                                                                                                                                                                                                                                                                        |
| DEU  | Detail Enhancement Unit               | A unit used for display engine frontend data post processing                                                                                                                                                                                                                                                                                                                                                                    |
| DLL  | Delay-Locked Loop                     | A digital circuit similar to a phase-locked loop (PLL), with the main difference being the absence of an internal voltage-controlled oscillator, replaced by a delay line                                                                                                                                                                                                                                                       |
| DRC  | Dynamic Range Compression             | It reduces the volume of loud sounds or amplifies quiet sounds by narrowing or "compressing" an audio signal's dynamic range.                                                                                                                                                                                                                                                                                                   |
| DVFS | Dynamic Voltage and Frequency Scaling | Dynamic voltage scaling is a power management technique where the voltage used in a component is increased or decreased, depending on circumstances. Dynamic frequency scaling is a technique whereby the frequency of a microprocessor can be automatically adjusted on the fly so that the power consumption or heat generated by the chip can be reduced. These two are often used together to save power in mobile devices. |

**E**

|      |                                    |                                                                                                                                        |
|------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| EHCI | Enhanced Host Controller Interface | The register-level interface for a Host Controller for the USB Revision 2.0.                                                           |
| eMMC | Embedded Multi-Media Card          | An architecture consisting of an embedded storage solution with MMC interface, flash memory and controller, all in a small BGA package |

**F**

|          |                                            |                                                                                                                                                                                                                                                                               |
|----------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FBGA     | Fine Ball Grid Array                       | FBGA is based on BGA technology, but comes with thinner contacts and is mainly used in SoC design                                                                                                                                                                             |
| <b>G</b> |                                            |                                                                                                                                                                                                                                                                               |
| GIC      | Generic Interrupt Controller               | A centralized resource for supporting and managing interrupts in a system that includes at least one processor                                                                                                                                                                |
| <b>H</b> |                                            |                                                                                                                                                                                                                                                                               |
| HDMI     | High-Definition Multimedia Interface       | A compact audio/video interface for transmitting uncompressed digital data                                                                                                                                                                                                    |
| <b>I</b> |                                            |                                                                                                                                                                                                                                                                               |
| I2S      | IIS                                        | An electrical serial bus interface standard used for connecting digital audio devices together                                                                                                                                                                                |
| <b>L</b> |                                            |                                                                                                                                                                                                                                                                               |
| LSB      | Least Significant Bit                      | The bit position in a binary integer giving the units value, that is, determining whether the number is even or odd. It is sometimes referred to as the right-most bit, due to the convention in positional notation of writing less significant digits further to the right. |
| LRADC    | Low Resolution Analog to Digital Converter | A module which can transfer analog signals to digital signals                                                                                                                                                                                                                 |
| <b>M</b> |                                            |                                                                                                                                                                                                                                                                               |

|          |                                      |                                                                                                                                                                                                                                                                  |
|----------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC      | Media Access Control                 | A sublayer of the data link layer, which provides addressing and channel access control mechanisms that make it possible for several terminals or network nodes to communicate within a multiple access network that incorporates a shared medium, e.g.Ethernet. |
| MII      | Media Independent Interface          | An interface originally designed to connect a fast Ethernet MAC-block to a PHY chip, which now has been extended to support reduced signals and increased speeds                                                                                                 |
| MSB      | Most Significant Bit                 | The bit position in a binary number having the greatest value, which is sometimes referred to as the left-most bit due to the convention in positional notation of writing more significant digits further to the left                                           |
| <b>N</b> |                                      |                                                                                                                                                                                                                                                                  |
| NTSC     | National Television System Committee | An analog television system that is used in most of North America, and many other countries                                                                                                                                                                      |
| <b>O</b> |                                      |                                                                                                                                                                                                                                                                  |
| 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                                                                                                                  |
| OSD      | On-Screen Display                    | A feature of visual devices like VCRs and DVD players that displays program, position, and setting data on a connected TV or computer display                                                                                                                    |
| <b>P</b> |                                      |                                                                                                                                                                                                                                                                  |
| PAL      | Phase Alternating Line               | An analogue television color encoding system used in broadcast television systems in many countries                                                                                                                                                              |
| PCM      | Pulse Code Modulation                | A method used to digitally represent sampled analog signals                                                                                                                                                                                                      |

|          |                                  |                                                                                                                                                                                                                                   |
|----------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PID      | Packet Identifier                | Each table or elementary stream in a transport stream is identified by a 13-bit packet ID (PID). A demultiplexer extracts elementary streams from the transport stream in part by looking for packets identified by the same PID. |
| <b>S</b> |                                  |                                                                                                                                                                                                                                   |
| SPI      | Synchronous 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                                            |
| <b>T</b> |                                  |                                                                                                                                                                                                                                   |
| TP       | Touch Panel                      | A human-machine interactive interface                                                                                                                                                                                             |
| TS       | Transport Stream                 | A data stream defined by ISO13818-1, which consists of one or more programs with video and audio data.                                                                                                                            |
| <b>U</b> |                                  |                                                                                                                                                                                                                                   |
| USB OTG  | Universal Serial Bus On-The-Go   | A dual-role controller, which supports both Host and Device functions and is fully compliant with the On-The-Go Supplement to the USB 2.0 Specification, Revision 1.0a                                                            |