

# **Allwinner DE2.0 Specification**

**Revision 1.0** 

Jan.23, 2018

Copyright@2018 Allwinner Technology Co.,Ltd. All Rights Reserved.



# **Revision History**

| Revision | Date         | Description             |
|----------|--------------|-------------------------|
| 1.0      | Jan. 23,2018 | Initial Release Version |
|          |              |                         |



# **Glossary**

The glossary is intended to cover the acronyms used in the document.

| Term   | Definition                                                                                                       |
|--------|------------------------------------------------------------------------------------------------------------------|
| R      | Read only/non-Write                                                                                              |
| R/W    | Read/Write                                                                                                       |
| RC     | Read-Clear/non-Write                                                                                             |
| RS     | Read-Set/non-Write                                                                                               |
| RC/W   | Read-Clear/Write                                                                                                 |
| RS/W   | Read-Set/Write                                                                                                   |
| R/WAC  | Read/Write-Automatic-Clear, Clear the bit automatically when the operation of complete. Writing 0 has no effect. |
| R/WC   | Read/Write-Clear                                                                                                 |
| R/WS   | Read/Write-Set                                                                                                   |
| RC/WS  | Read-Clear/Write-Set                                                                                             |
| RS/WC  | Read-Set/Write-Clear                                                                                             |
| R/W1C  | Read/Write 1 to Clear, Write 0 has non-effect                                                                    |
| R/W1S  | Read/Write 1 to Set, Write 0 has non-effect                                                                      |
| R/W1T  | Read/Write 1 to Flip, Write 0 has non-effect                                                                     |
| R/W0C  | Read/Write 0 to Clear, Write 1 has non-effect                                                                    |
| R/W0S  | Read/Write 0 to Set, Write 1 has non-effect                                                                      |
| R/W0T  | Read/Write 0 to Flip, Write 1 has non-effect                                                                     |
| RC/W1S | Read-Clear/Write 1 to Set, Write 0 has non-effect                                                                |
| RS/W1C | Read-Set/Write 1 to Clear, Write 0 has non-effect                                                                |
| RC/W0S | Read-Clear/Write 0 to Set, Write 1 has non-effect                                                                |
| RS/W0C | Read-Set/Write 0 to Clear, Write 1 has non-effect                                                                |
| W      | Write only/non-Read                                                                                              |
| WC     | Write-Clear/non-Read                                                                                             |
| WS     | Write-Set/non-Read                                                                                               |
| W1     | After reset, Write at the first time, non-Write after the first time/Read                                        |
| WO1    | After reset, Write at the first time, non-Write after the first time/non-Read                                    |



# **Contents**

| Revision History                                          | 2  |
|-----------------------------------------------------------|----|
| Contents                                                  | 4  |
| Figures                                                   | 12 |
| Tables                                                    | 14 |
| 1 .H8 Display_Engine_Top                                  | 15 |
| 1.1 Overview                                              | 15 |
| 1.2 Block Diagram                                         | 16 |
| 1.3 Display system configurations and requirements        | 18 |
| 1.3.1 Memory Space Arrangement:                           | 18 |
| 1.4 Register list                                         | 18 |
| 1.5 Register Description                                  | 19 |
| 1.5.1 SCLK_GATE                                           | 19 |
| 1.5.2 HCLK_GATE                                           | 19 |
| 1.5.3 AHB_RESET                                           | 20 |
| 1.5.4 SCLK_DIV                                            | 20 |
| 1.5.5 DE2TCON_MUX                                         | 20 |
| 1.5.6 CMD_CTL                                             | 21 |
| 1.5.7 DI_CTL                                              | 21 |
| 2 .H3 Display_Engine_Top                                  | 22 |
| 2.1 Overview                                              | 22 |
| 2.2 Block Diagram                                         | 22 |
| 2.3 Display System Configurations and requirements        | 24 |
| 2.3.1 Speed requirements:                                 | 24 |
| 2.3.2 Memory Space Arrangement:                           | 24 |
| 2.4 Register list                                         | 24 |
| 2.5 Register Description                                  | 25 |
| 2.5.1 SCLK_GATE                                           | 25 |
| 2.5.2 HCLK_GATE                                           | 25 |
| 2.5.3 AHB_RESET                                           | 25 |
| 2.5.4 SCLK_DIV                                            | 26 |
| 2.5.5 DE2TCON_MUX                                         | 26 |
| 2.5.6 CMD_CTL                                             | 26 |
| 3 .H5 Display_Engine_Top                                  | 27 |
| 3.1 Overview                                              | 27 |
| 3.2 Block Diagram                                         | 28 |
| 3.3 Operations and Functional Descriptions                | 29 |
| 3.3.1 Configuration and Requirements                      | 29 |
| 3.3.2 Clock Sources                                       | 30 |
| 3.4 DE Register List                                      | 30 |
| 3.5 DE Register Description                               |    |
| 3.5.1 DE SCLK Gating Register(Default Value: 0x0000_0000) | 31 |



| 3.5.2 DE HCLK Gating Register(Default Value: 0x0000_0000)   | 31 |
|-------------------------------------------------------------|----|
| 3.5.3 DE AHB Reset Register(Default Value: 0x0000_0000)     | 31 |
| 3.5.4 DE SCLK Division Register(Default Value: 0x0000_0000) | 32 |
| 3.5.5 DE2TCON MUX Register(Default Value: 0x0000_0000)      | 32 |
| 4 .A83 Display_Engine_Top                                   | 33 |
| 4.1 Overview                                                | 33 |
| 4.2 Block Diagram                                           | 34 |
| 4.3 Display system configurations and requirements          | 37 |
| 4.3.1 Memory Space Arrangement:                             | 37 |
| 4.4 Register list                                           | 37 |
| 4.5 Register Description                                    | 37 |
| 4.5.1 SCLK_GATE                                             | 37 |
| 4.5.2 HCLK_GATE                                             | 38 |
| 4.5.3 AHB_RESET                                             | 38 |
| 4.5.4 SCLK_DIV                                              | 39 |
| 4.5.5 DE2TCON_MUX                                           | 39 |
| 5 .Sub_Module_Specification                                 | 40 |
| 5.1 DE ASE Specification                                    | 40 |
| 5.1.1 Register List                                         | 40 |
| 5.1.2 Register Description                                  | 40 |
| 5.1.2.1 Global Control Register                             | 40 |
| 5.1.2.2 ASE size register                                   | 40 |
| 5.1.2.3 ASE windows0 register                               | 41 |
| 5.1.2.4 ASE windows1 register                               | 41 |
| 5.1.2.5 ASE gain register                                   | 41 |
| 5.2 DE BWS Specification                                    | 42 |
| 5.2.1 Overview                                              | 42 |
| 5.2.2 Register List                                         | 42 |
| 5.2.3 Register Description                                  |    |
| 5.2.3.1 BWS_GCTRL_REG                                       | 42 |
| 5.2.3.2 BWS_SIZE_REG                                        |    |
| 5.2.3.3 BWS_WINO_REG                                        | 43 |
| 5.2.3.4 BWS_WIN1_REG                                        | 43 |
| 5.2.3.5 BWS_THRO_REG                                        |    |
| 5.2.3.6 BWS_THR1_REG                                        | 44 |
| 5.2.3.7 BWS_SLP0_REG                                        | 44 |
| 5.2.3.8 BWS_SLP1_REG                                        | 44 |
| 5.3 DE CSC Specification                                    |    |
| 5.3.1 Overview                                              |    |
| 5.3.2 Register List                                         |    |
| 5.3.3 Register Description                                  |    |
| 5.3.3.1 CSC_BYPASS_REG                                      |    |
| 5.3.3.2 CSC_COEFFO_REG                                      |    |
| 5.3.3.3 CSC_CONSTO_REG                                      |    |
| 5.3.3.4 CSC_COEFF1_REG                                      |    |
| 5.3.3.5 CSC_CONST1_REG                                      |    |
| 5.3.3.6 CSC COEFF2 REG                                      | 46 |



| 5.3.3.7 CSC_CONST2_REG                                                                          | 47 |
|-------------------------------------------------------------------------------------------------|----|
| 5.3.3.8 GLB_ALPHA_REG                                                                           | 47 |
| 5.4 DE DRC Specification                                                                        | 48 |
| 5.4.1 Overview                                                                                  | 48 |
| 5.4.2 Register List                                                                             | 48 |
| 5.4.3 Register Description                                                                      | 49 |
| 5.4.3.1 General control register (Default Value: 0x0000_0000)                                   | 49 |
| 5.4.3.2 DRC size setting register (Default Value: 0x0000_0000)                                  |    |
| 5.4.3.3 DRC control register (Default Value: 0x0000_0000)                                       |    |
| 5.4.3.4 DRC setting register (Default Value: 0x0000_0000)                                       |    |
| 5.4.3.5 DRC window position 0 register (Default Value: 0x0000_0000)                             | 51 |
| 5.4.3.6 DRC window position 1 register (Default Value: 0x0000_0000)                             | 51 |
| 5.4.3.7 Luminance histogram control register (Default Value: 0x0000_0000)                       | 51 |
| 5.4.3.8 Luminance histogram threshold setting 0 register (Default Value: 0x8060_4020)           |    |
| 5.4.3.9 Luminance histogram threshold setting 1 register (Default Value: 0x00E0_C0A0)           | 52 |
| 5.4.3.10 Luminance histogram statistics lum recording register N (N = $0^{-7}$ ) (Default Value |    |
|                                                                                                 |    |
| 5.4.3.11 Luminance histogram statistics counter recording register N (N = 0~7)                  | •  |
| 0x0000_0000)                                                                                    |    |
| 5.4.3.12 CSC coefficient 00 register (Default Value: 0x0000_04A7)                               |    |
| 5.4.3.13 CSC coefficient 01 register (Default Value: 0x0000_1E6F)                               |    |
| 5.4.3.14 CSC coefficient 02 register (Default Value: 0x0000_1CBF)                               |    |
| 5.4.3.15 CSC constant 03 register (Default Value: 0x0000_0877)                                  |    |
| 5.4.3.16 CSC coefficient 10 register (Default Value: 0x0000_04A7)                               |    |
| 5.4.3.17 CSC coefficient 11 register (Default Value: 0x0000_0000)                               |    |
| 5.4.3.18 CSC coefficient 12 register (Default Value: 0x0000_0662)                               |    |
| 5.4.3.19 CSC constant 13 register (Default Value: 0x0000_3211)                                  |    |
| 5.4.3.20 CSC coefficient 20 register (Default Value: 0x0000_04A7)                               |    |
| 5.4.3.21 CSC coefficient 21 register (Default Value: 0x0000_0812)                               |    |
| 5.4.3.22 CSC coefficient 22 register (Default Value: 0x0000_0000)                               |    |
| 5.4.3.23 CSC constant 23 register (Default Value: 0x0000_2EB1)                                  |    |
| 5.4.3.24 DRC spatial coefficient register N (N=0~2) (Default Value: 0x0000_0000)                |    |
| 5.4.3.25 DRC intensity coefficient register N (N=0~63) (Default Value: 0x0000_0000)             |    |
| 5.4.3.26 DRC luminance gain coefficient register N (N=0~127)                                    |    |
| 16bits luminance gain coefficient, unsigned data                                                |    |
| The high 5 bits is the integer part                                                             |    |
| LGC COEFO                                                                                       |    |
| 16bits luminance gain coefficient, unsigned data                                                |    |
| The high 5 bits is the integer part                                                             |    |
| The low 11 bits is the decimal part                                                             |    |
| 5.5 DE FCC Specification                                                                        |    |
| 5.5.1 Overview                                                                                  |    |
| 5.5.2 Register List                                                                             |    |
| 5.5.3 Register Description                                                                      |    |
| 5.5.3.1 FCC_CTRL_REG(Default Value: 0x0000_0000)                                                |    |
| 5.5.3.2 FCC INPUT SIZE REG(Default Value: 0x0000 0000)                                          |    |



| 5.5.3.3 FCC_OUTPUT_WINO_REG(Default Value: 0x0000_0000) | 57 |
|---------------------------------------------------------|----|
| 5.5.3.4 FCC_OUTPUT_WIN1_REG(Default Value: 0x0000_0000) | 57 |
| 5.5.3.5 FCC_HUE_RANGE_REG(Default Value: 0x0000_0000)   | 58 |
| 5.5.3.6 FCC_LOCAL_GAIN_REG                              | 58 |
| 5.5.3.7 INCSC_BYPASS_REG                                |    |
| 5.5.3.8 INCSC_COEFF0_REG(Default Value: 0x0000_0000)    | 59 |
| 5.5.3.9 INCSC_CONSTO_REG(Default Value: 0x0000_0000)    | 59 |
| 5.5.3.10 INCSC_COEFF1_REG(Default Value: 0x0000_0000)   |    |
| 5.5.3.11 INCSC_CONST1_REG(Default Value: 0x0000_0000)   |    |
| 5.5.3.12 INCSC_COEFF2_REG(Default Value: 0x0000_0000)   |    |
| 5.5.3.13 INCSC_CONST2_REG(Default Value: 0x0000_0000)   | 60 |
| 5.5.3.14 GLB_ALPHA_REG                                  | 60 |
| 5.6 DE FCE Specification                                |    |
| 5.6.1 Overview                                          |    |
| 5.6.2 Register List                                     |    |
| 5.6.3 Register Description                              |    |
| 5.6.3.1 GCTRL REG                                       |    |
| 5.6.3.2 FCE SIZE REG                                    |    |
| 5.6.3.3 FCE_WINO_REG                                    |    |
| 5.6.3.4 FCE_WIN1_REG                                    |    |
| 5.6.3.5 LCE_GAIN_REG                                    |    |
| 5.6.3.6 HIST_SUM_REG                                    |    |
| <br>5.6.3.7 HIST_STATUS_REG                             |    |
| 5.6.3.8 CE_STATUS_REG                                   |    |
| 5.6.3.9 FTC_GAIN_REG                                    |    |
| 5.6.3.10 FCE_INCSC_BYPASS_REG                           |    |
| 5.6.3.11 CE_LUT_REGN (N = 0:63)                         |    |
| 5.6.3.12 HIST CNT REGN (N = 0:255)                      |    |
| 5.7 DE UIS Specification                                |    |
| 5.7.1 Overview                                          |    |
| 5.7.2 Register List                                     | 66 |
| 5.7.3 Register Description                              |    |
| 5.7.3.1 UIS_CTRL_REG                                    | 66 |
| 5.7.3.2 UIS_STATUS_REG                                  |    |
| 5.7.3.3 UIS_FIELD_CTRL_REG                              |    |
| 5.7.3.4 UIS_BIST_REG                                    | 68 |
| 5.7.3.5 UIS_OUTSIZE_REG                                 | 68 |
| 5.7.3.6 UIS_INSIZE_REG                                  | 68 |
| 5.7.3.7 UIS_HSTEP_REG                                   | 69 |
| 5.7.3.8 UIS_VSTEP_REG                                   | 69 |
| 5.7.3.9 UIS_HPHASE_REG                                  | 69 |
| 5.7.3.10 UIS_VPHASEO_REG                                |    |
| 5.7.3.11 UIS_VPHASE1_REG                                |    |
| 5.7.3.12 UIS_HCOEF_REGN (N = 0:15)                      |    |
| 5.8 DE LTI Specification                                |    |
| 5.8.1 Overview                                          |    |
| 5.8.2 Register List                                     | 71 |



| 5.8.3 Register Description                     | 72 |
|------------------------------------------------|----|
| 5.8.3.1 Global control register                | 72 |
| 5.8.3.2 LTI size register                      | 72 |
| 5.8.3.3 LTI FIR filter coefficient register0   | 73 |
| 5.8.3.4 LTI FIR filter coefficient register1   | 73 |
| 5.8.3.5 LTI FIR filter coefficient register2   | 73 |
| 5.8.3.6 LTI FIR filter gain register           | 73 |
| 5.8.3.7 LTI coring threshold register          | 74 |
| 5.8.3.8 LTI differ filter control register     | 74 |
| 5.8.3.9 LTI adjustable gain parameter register | 74 |
| 5.8.3.10 LTI The overshoot of control register | 74 |
| 5.8.3.11 LTI window range expansion register   | 74 |
| 5.8.3.12 LTI edge strength threshold register  | 75 |
| 5.8.3.13 LTI_WINO_REG                          | 75 |
| 5.8.3.14 LTI_WIN1_REG                          | 75 |
| 5.8.3.15 LTI_INCSC_BYPASS_REG                  | 75 |
| 5.8.3.16 LTI_INCSC_COEFFO_REG                  | 76 |
| 5.8.3.17 LTI_INCSC_CONSTO_REG                  | 76 |
| 5.8.3.18 LTI_INCSC_COEFF1_REG                  | 76 |
| 5.8.3.19 LTI_INCSC_CONST1_REG                  | 76 |
| 5.8.3.20 LTI_INCSC_COEFF2_REG                  | 76 |
| 5.8.3.21 LTI_INCSC_CONST2_REG                  | 77 |
| 5.8.3.22 LTI_OUTCSC_BYPASS_REG                 | 77 |
| 5.8.3.23 LTI_OUTCSC_COEFF0_REG                 | 77 |
| 5.8.3.24 LTI_OUTCSC_CONSTO_REG                 | 77 |
| 5.8.3.25 LTI_OUTCSC_COEFF1_REG                 | 77 |
| 5.8.3.26 LTI_OUTCSC_CONST1_REG                 | 78 |
| 5.8.3.27 LTI_OUTCSC_COEFF2_REG                 | 78 |
| 5.8.3.28 LTI_OUTCSC_CONST2_REG                 | 78 |
| 5.9 DE Peaking Specification                   | 79 |
| 5.9.1 Overview                                 | 79 |
| 5.9.2 Block Diagram                            | 79 |
| 5.9.3 Register list                            | 80 |
| 5.9.4 Register Description                     | 80 |
| 5.9.4.1 LP_CTRL_REG                            | 80 |
| 5.9.4.2 LP_SIZE_REG                            | 81 |
| 5.9.4.3 LP_WINO_REG                            | 81 |
| 5.9.4.4 LP_WIN1_REG                            | 81 |
| 5.9.4.5 LP_FILTER_REG                          | 82 |
| 5.9.4.6 LP_CSTM_FILTERO_REG                    | 82 |
| 5.9.4.7 LP_CSTM_FILTER1_REG                    | 82 |
| 5.9.4.8 LP_CSTM_FILTER2_REG                    | 83 |
| 5.9.4.9 LP_GAIN_REG                            | 83 |
| 5.9.4.10 LP_GAINCTRL_REG                       | 83 |
| 5.9.4.11 LP_SHOOTCTRL_REG                      | 83 |
| 5.9.4.12 LP_CORING_REG                         | 83 |
| 5.9.4.13 LP_INCSC_BYPASS_REG                   | 84 |



| 5.9.4.14 LP_INCSC_COEFF0_REG                                     | 84 |
|------------------------------------------------------------------|----|
| 5.9.4.15 LP_INCSC_CONSTO_REG                                     |    |
| 5.9.4.16 LP_INCSC_COEFF1_REG                                     |    |
| 5.9.4.17 LP_INCSC_CONST1_REG                                     |    |
| 5.9.4.18 LP_INCSC_COEFF2_REG                                     |    |
| 5.9.4.19 LP_INCSC_CONST2_REG                                     |    |
| 5.9.4.20 LP_OUTCSC_BYPASS_REG                                    |    |
| 5.9.4.21 LP_OUTCSC_COEFF0_REG                                    |    |
| 5.9.4.22 LP_OUTCSC_CONSTO_REG                                    |    |
| 5.9.4.23 LP_OUTCSC_COEFF1_REG                                    |    |
| 5.9.4.24 LP_OUTCSC_CONST1_REG                                    |    |
| 5.9.4.25 LP_OUTCSC_COEFF2_REG                                    |    |
| 5.9.4.26 LP_OUTCSC_CONST2_REG                                    |    |
| 5.10 DE RT-MIXER Specification                                   |    |
| 5.10.1 Overview                                                  |    |
| 5.10.2 Block Diagram                                             |    |
| 5.10.3 DE RT-Mixer Description                                   |    |
| 5.10.3.1 Input Data Memory Layout                                |    |
| 5.10.3.2 Overlay                                                 |    |
| 5.10.3.3 Scaling                                                 |    |
| 5.10.3.4 Blender                                                 |    |
| 5.10.4 Memory Mapping List                                       |    |
| 5.10.5 Register List                                             |    |
| 5.10.6 GLB Register Description                                  |    |
| 5.10.6.1 Global control register                                 |    |
| 5.10.6.2 Global status register                                  |    |
| 5.10.6.3 Global double buffer control register                   |    |
| 5.10.6.4 Global size register                                    |    |
| 5.10.7 OVL_V Register Description                                |    |
| 5.10.7.1 OVL_V attribute control register                        |    |
| 5.10.7.2 OVL_V memory block size register                        |    |
| 5.10.7.3 OVL_V memory block coordinate register                  |    |
| 5.10.7.4 OVL_V memory pitch register0                            |    |
| 5.10.7.5 OVL_V memory pitch register1                            |    |
| 5.10.7.6 OVL V memory pitch register2                            |    |
| 5.10.7.7 OVL_V top field memory block low address register0      |    |
| 5.10.7.8 OVL_V top field memory block low address register1      |    |
| 5.10.7.9 OVL_V top field memory block low address register2      |    |
| 5.10.7.10 OVL_V bottom field memory block low address register0  |    |
| 5.10.7.11 OVL_V bottom field memory block low address register1  |    |
| 5.10.7.12 OVL_V bottom field memory block low address register2  |    |
| 5.10.7.13 OVL_V fill color register                              |    |
| 5.10.7.14 OVL_V top field memory block high address register0    |    |
| 5.10.7.15 OVL_V top field memory block high address register1    |    |
| 5.10.7.16 OVL_V top field memory block high address register2    |    |
| 5.10.7.17 OVL_V bottom field memory block high address register0 |    |
| 5.10.7.18 OVL V bottom field memory block high address register1 |    |
|                                                                  |    |



|      | 5.10.7.19 OVL_V bottom field memory block high address register2 | 100 |
|------|------------------------------------------------------------------|-----|
|      | 5.10.7.20 OVL_V overlay window size register                     | 100 |
|      | 5.10.7.21 OVL_V horizontal down sampling control register0       | 101 |
|      | 5.10.7.22 OVL_V horizontal down sampling control register1       | 101 |
|      | 5.10.7.23 OVL_V vertical down sampling control register0         | 101 |
|      | 5.10.7.24 OVL_V vertical down sampling control register1         | 102 |
|      | 5.10.8 OVL_UI Register Description                               | 102 |
|      | 5.10.8.1 OVL_UI attribute control register                       | 102 |
|      | 5.10.8.2 OVL_UI memory block size register                       | 104 |
|      | 5.10.8.3 OVL_UI memory block coordinate register                 | 104 |
|      | 5.10.8.4 OVL_UI memory pitch register                            | 104 |
|      | 5.10.8.5 OVL_UI top field memory block low address register      | 104 |
|      | 5.10.8.6 OVL_UI bottom field memory block low address register   | 105 |
|      | 5.10.8.7 OVL_UI fill color register                              | 105 |
|      | 5.10.8.8 OVL_UI top field memory block high address register     | 105 |
|      | 5.10.8.9 OVL_UI bottom field memory block high address register  | 105 |
|      | 5.10.8.10 OVL_UI overlay window size register                    | 106 |
|      | 5.10.9 BLD Register Description                                  | 106 |
|      | 5.10.9.1 BLD fill color control register                         | 106 |
|      | 5.10.9.2 BLD fill color register                                 | 107 |
|      | 5.10.9.3 BLD input memory size register                          | 108 |
|      | 5.10.9.4 BLD input memory offset register                        | 108 |
|      | 5.10.9.5 BLD routing control register                            | 108 |
|      | 5.10.9.6 BLD pre-multiply control register                       | 109 |
|      | 5.10.9.7 BLD background color register                           | 109 |
|      | 5.10.9.8 BLD output size setting register                        | 110 |
|      | 5.10.9.9 BLD control register                                    | 110 |
|      | 5.10.9.10 BLD color key control register                         | 111 |
|      | 5.10.9.11 BLD color key configuration register                   | 112 |
|      | 5.10.9.12 BLD color key max register                             |     |
|      | 5.10.9.13 BLD color key min register                             | 114 |
|      | 5.10.9.14 BLD output color control register                      | 115 |
| 5.13 | 1 DE RT-WB Controller Specification                              | 116 |
|      | 5.11.1 Overview                                                  | 116 |
|      | 5.11.2 Block Diagram                                             | 116 |
|      | 5.11.3 Operations and Function Descriptions                      | 116 |
|      | 5.11.3.1 Write-back flow                                         | 116 |
|      | 5.11.3.2 Key signal and key register                             | 118 |
|      | 5.11.4 RT-WB Register List                                       | 119 |
|      | 5.11.5 RT-WB Register Description                                | 120 |
|      | 5.11.5.1 WB_GCTRL_REG                                            | 120 |
|      | 5.11.5.2 WB_SIZE_REG                                             | 121 |
|      | 5.11.5.3 WB_CROP_COORD_REG                                       |     |
|      | 5.11.5.4 WB_CROP_SIZE_REG                                        |     |
|      | 5.11.5.5 WB_A_CH0_ADDR_REG                                       | 121 |
|      | 5.11.5.6 WB_A_CH1_ADDR_REG                                       | 122 |
|      | 5.11.5.7 WB A CH2 ADDR RFG                                       | 122 |



| 5.11.5.8 WB_A_HIGH_ADDR_REG              | 123 |
|------------------------------------------|-----|
| 5.11.5.9 WB B CH0 ADDR REG               |     |
| 5.11.5.10 WB_B_CH1_ADDR_REG              |     |
| 5.11.5.11 WB_B_CH2_ADDR_REG              |     |
| 5.11.5.12 WB_B_HIGH_ADDR_REG             |     |
|                                          |     |
| 5.11.5.13 WB_CH0_PITCH_REG               |     |
| 5.11.5.14 WB_CH12_PITCH_REG              |     |
| 5.11.5.15 WB_ADDR_SWITCH_REG             |     |
| 5.11.5.16 WB_FORMAT_REG                  |     |
| 5.11.5.17 WB_INT_REG                     |     |
| 5.11.5.18 WB_STATUS_REG                  |     |
| 5.11.5.19 WB_BYPASS_REG                  |     |
| 5.11.5.20 WB_CS_HORZ_REG                 |     |
| 5.11.5.21 WB_CS_VERT_REG                 |     |
| 5.11.5.22 WB_FS_INSIZE_REG               |     |
| 5.11.5.23 WB_FS_OUTSIZE_REG              |     |
| 5.11.5.24 WB_FS_HSTEP_REG                |     |
| 5.11.5.25 WB_FS_VSTEP_REG                |     |
| 5.11.5.26 WB_DEBUG_REG                   |     |
| 5.11.5.27 WB_CH0_HCOEF_REGN (N = 0:15)   |     |
| 5.11.5.28 WB_CH1_HCOEF_REGN (N = 0:15)   |     |
| 5.12 DE VSU Specification                |     |
| 5.12.1 Overview                          |     |
| 5.12.2 Block Diagram                     |     |
| 5.12.3 Video Scaler Register List        |     |
| 5.12.4 Video Scaler Register Description |     |
| 5.12.4.1 VS_CTRL_REG                     |     |
| 5.12.4.2 VS_STATUS_REG                   |     |
| 5.12.4.3 VS_FIELD_CTRL_REG               |     |
| 5.12.4.4 VS_OUT_SIZE_REG                 |     |
| 5.12.4.5 VS_Y_SIZE_REG                   |     |
| 5.12.4.6 VS_Y_HSTEP_REG                  | 132 |
| 5.12.4.7 VS_Y_VSTEP_REG                  |     |
| 5.12.4.8 VS_Y_HPHASE_REG                 | 132 |
| 5.12.4.9 VS_Y_VPHASEO_REG                | 132 |
| 5.12.4.10 VS_Y_VPHASE1_REG               | 133 |
| 5.12.4.11 VS_C_SIZE_REG                  | 133 |
| 5.12.4.12 VS_C_HSTEP_REG                 | 133 |
| 5.12.4.13 VS_C_VSTEP_REG                 | 133 |
| 5.12.4.14 VS_C_HPHASE_REG                | 134 |
| 5.12.4.15 VS_Y_VPHASE0_REG               | 134 |
| 5.12.4.16 VS_C_VPHASE1_REG               | 134 |
| 5.12.4.17 VS_Y_HCOEF0_REGN (N = 0:(M-1)) | 134 |
| 5.12.4.18 VS_Y_HCOEF1_REGN (N = 0:(M-1)) | 134 |
| 5.12.4.19 VS_Y_VCOEF_REGN (N = 0:(M-1))  | 135 |
| 5.12.4.20 VS_C_HCOEF0_REGN (N = 0:(M-1)) | 135 |
| 5.12.4.21 VS C HCOEF1 REGN (N = 0:(M-1)) |     |



| 5.12.4                  | 1.22 VS_C_VCOEF_REGN (N = 0:(M-1))              | 135 |
|-------------------------|-------------------------------------------------|-----|
| 5.13 DE Rotation        | n Specification                                 | 137 |
| 5.13.1 Ove              | rview                                           | 137 |
| 5.13.2 Bloc             | k Diagram                                       | 137 |
| 5.13.3 Desc             | cription                                        | 137 |
| 5.13.4 Cop <sup>-</sup> | y & Rotation                                    | 137 |
| 5.13.5 Regi             | ister List                                      | 138 |
| 5.13.6 Regi             | ister Description                               | 139 |
| 5.13.6                  | 5.1 Global control register                     | 139 |
| 5.13.6                  | 5.2 Interrupt register                          | 140 |
| 5.13.6                  | 5.3 Input data attribute register               | 140 |
| 5.13.6                  | 5.4 Input data size register                    | 141 |
| 5.13.6                  | 5.5 Input Y/RGB/ARGB memory pitch register      | 141 |
| 5.13.6                  | 5.6 Input U/UV memory pitch register            | 141 |
| 5.13.6                  | 5.7 Input V memory pitch register               | 141 |
| 5.13.6                  | 5.8 Input Y/RGB/ARGB memory address register0   | 142 |
| 5.13.6                  | 5.9 Input Y/RGB/ARGB memory address register1   | 142 |
| 5.13.6                  | 5.10 Input U/UV memory address register0        | 142 |
| 5.13.6                  | 5.11 Input U/UV memory address register1        | 142 |
| 5.13.6                  | 5.12 Input V memory address register0           | 142 |
| 5.13.6                  | 5.13 Input V memory address register1           | 143 |
| 5.13.6                  | 5.14 Output data size register                  | 143 |
| 5.13.6                  | 5.15 Output Y/RGB/ARGB memory pitch register    | 143 |
| 5.13.6                  | 5.16 Output U/UV memory pitch register          | 143 |
| 5.13.6                  | 5.17 Output V memory pitch register             | 144 |
| 5.13.6                  | 5.18 Output Y/RGB/ARGB memory address register0 | 144 |
| 5.13.6                  | 5.19 Output Y/RGB/ARGB memory address register1 | 144 |
| 5.13.6                  | 5.20 Output U/UV memory address register0       | 144 |
| 5.13.6                  | 5.21 Output U/UV memory address register1       | 144 |
| 5.13.6                  | 5.22 Output V memory address register0          | 145 |
| 5.13.€                  | 5.23 Output V memory address register1          | 145 |

# **Figures**

| Figure 1-1. Display Top Level Block Diagram | 16 |
|---------------------------------------------|----|
| Figure 1-2. RT-MIXERO Block Diagram         | 16 |
| Figure 1-3. POST_PROC1 Block Diagram        | 17 |
| Figure 1-4. POST_PROC2 Block Diagram        | 17 |
| Figure 1-5. RT-MIXER1 Block Diagram         | 18 |
| Figure 1-6. RT-WB Block Diagram             | 18 |
| Figure 2-1. Display Top Level Diagram       | 22 |
| Figure 2-2. RT-MIXERO Block Diagram         | 22 |
| Figure 2-3. POST_PROC1 Block Diagram        | 23 |
| Figure 2-4. POST_PROC2 Block Diagram        | 23 |
|                                             |    |



| Figure 2-5. RT-MIXER1 Block Diagram                     | 23  |
|---------------------------------------------------------|-----|
| Figure 2-6. RT-WB Block Diagram                         | 24  |
| Figure 3-1. DE System Block Diagram                     | 28  |
| Figure 3-2. RT-Mixer0 Blcok Diagram                     | 28  |
| Figure 3-3. RT-Mixer1 Block Diagram                     | 28  |
| Figure 3-4. VEP Block Diagram                           | 29  |
| Figure 3-5. DEP Block Diagram                           | 29  |
| Figure 4-1. DE System Block Diagram                     | 34  |
| Figure 4-2. RT-MIXER Core0 Block Diagram                | 34  |
| Figure 4-3. POST_PROC1 Block Diagram                    | 35  |
| Figure 4-4. POST_PROC2 Block Diagram                    | 35  |
| Figure 4-5. RT-MIXER Core1 Block Diagram                | 36  |
| Figure 4-6. RT-WB Block Diagram                         | 36  |
| Figure 4-7. CSR(Rotation) Block Diagram                 | 36  |
| Figure 5-1. Luma peaking module block diagram           | 79  |
| Figure 5-2. RT-Mixer General Diagram                    | 87  |
| Figure 5-3. Input data pixel sequence                   | 88  |
| Figure 5-4. Layers memory access and overlay processing | 89  |
| Figure 5-5. N Channel select pipe route processing      | 89  |
| Figure 5-6. Pipe memory access diagram                  | 90  |
| Figure 5-7. RT-WB Block Diagram                         | 116 |
| Figure 5-8. The main control flow of RT-WB              | 117 |
| Figure 5-9. Write-back address switch function          | 118 |
| Figure 5-10. VS block diagram                           | 129 |
| Figure 5-11. CSR Block Diagram                          | 137 |
| Figure 5-12 Rotation Diagram                            | 138 |



# **Tables**

| Table 3-1. RT-Mixer Configuration            | 29  |
|----------------------------------------------|-----|
| Table 3-2. RT-WB Configuration               | 30  |
| Table 3-3. DE Memory and Speed requirements  | 30  |
| Table 3-4. DE Clock Sources                  |     |
| Table 5-1. RTL programmable parameters table | 116 |
| Table 5-2. RTL programmable parameters table |     |



# 1 .H8 Display\_Engine\_Top

#### 1.1 Overview

The Display Engine(DE) is a hardware composer to transfer image layers from a local bus or a video buffer to the *LCD* interface, The DE support four overlay windows to blending, and support image post-processing in the video channel.

#### Feature:

- Support output size up to 4096x4096
- Support four alpha blending channels for main display, two channels for aux display.
- Support four overlay layers in each channel, and has a independent scaler.
- Support potter-duff compatible blending operation.
- Support input format YUV422/YUV420/YUV411/ARGB8888/XRGB8888/RGB888/ARGB4444/ ARGB1555 and RGB565.
- Support Frame Packing/Top-and-Bottom/Side-by-Side Full/Side-by-Side Half 3D format data.
- Support SmartColor2.0 for excellent display experience.
  - Adaptive edge sharping
  - Adaptive color enhancement
  - Adaptive contrast enhancement and fresh tone rectify.
- Support write back and rotation for high efficient dual display and miracast.



## 1.2 Block Diagram



Figure 1-1. Display Top Level Block Diagram



Figure 1-2. RT-MIXERO Block Diagram





Figure 1-3. POST\_PROC1 Block Diagram

### DE2.0 post processing, include:

|      | O,                              |
|------|---------------------------------|
| FCE  | Fresh and Contrast enhancement  |
| BWS  | Black and white stretch         |
| LTI  | Luminance transient improvement |
| PEAK | Luma Peaking                    |
| ASE  | Adaptive Saturation Enhancement |
| FCC  | Fancy color curvature change    |



Figure 1-4. POST\_PROC2 Block Diagram





Figure 1-5. RT-MIXER1 Block Diagram



Figure 1-6. RT-WB Block Diagram

- Support RGB888 and YUV444 input data format.
- Support input size from 8x4 to 2048x2048.
- Support output size from 8x4 to 2048x2048.
- Support fine down scaling ratio from 1x to 1/2x, and the anti-aliasing filter is 16-phase 4-tap in horizontal, 16-phase 2-tap/4-tap filter in vertical.
- Support coarse down scaling.

## 1.3 Display system configurations and requirements

### 1.3.1 Memory Space Arrangement:

| Module name | Base address |            |
|-------------|--------------|------------|
| DE          | 0x01000000   | 0x013FFFFF |

| Module name    | Offset Address  | Memory Range |
|----------------|-----------------|--------------|
| Display system | 0x000000        | 64K          |
| RT-WB          | VB 0x010000 64K |              |
| Rotate         | 0x020000        | 64K          |
| DI             | 0x030000        | 128K         |
| RT-Mixer0      | 0x100000        | 1M           |
| RT-Mixer1      | 0x200000        | 1M           |

### 1.4 Register list

Display system top register list:

| Register name | Offset | Description |
|---------------|--------|-------------|
|---------------|--------|-------------|



| SCLK_GATE   | 0x000 | DE SCLK Gating Register   |
|-------------|-------|---------------------------|
| HCLK_GATE   | 0x004 | DE HCLK Gating Register   |
| AHB_RESET   | 0x008 | DE AHB Reset register     |
| SCLK_DIV    | 0x00C | DE SCLK Division register |
| DE2TCON_MUX | 0x010 | DE2TCON MUX register      |
| CMD_CTL     | 0x014 | CMD Control register      |
| DI_CTL      | 0x01C | DI Control register       |

## 1.5 Register Description

## **1.5.1 SCLK\_GATE**

| Offset: 0x000 |            |             | Register Name: SCLK_GATE |
|---------------|------------|-------------|--------------------------|
| Bit           | Read/Write | Default/Hex | Description              |
| 31:4          | /          | /           | Reserved                 |
|               |            |             | ROT_SCLK_GATE            |
| 3             | R/W        | 0x0         | 0: clock gate            |
|               |            |             | 1: clock pass            |
|               |            |             | RT_WB_SCLK_GATE          |
| 2             | R/W        | 0x0         | 0: clock gate            |
|               |            |             | 1: clock pass            |
|               |            |             | CORE1_SCLK_GATE          |
| 1             | R/W        | 0x0         | 0: clock gate            |
|               |            |             | 1: clock pass            |
|               |            |             | COREO_SCLK_GATE          |
| 0             | R/W        | 0x0         | 0: clock gate            |
|               |            |             | 1: clock pass            |

## 1.5.2 HCLK\_GATE

| Offset: 0x004 |            |             | Register Name: HCLK_GATE |
|---------------|------------|-------------|--------------------------|
| Bit           | Read/Write | Default/Hex | Description              |
| 29:4          | /          | /           | Reserved                 |
|               |            |             | ROT_HCLK_GATE            |
| 3             | R/W        | 0x0         | 0: clock gate            |
|               |            |             | 1: clock pass            |
|               |            |             | RT_WB_HCLK_GATE          |
| 2             | R/W        | 0x0         | 0: clock gate            |
|               |            |             | 1: clock pass            |
|               |            |             | CORE1_HCLK_GATE          |
| 1             | R/W        | 0x0         | 0: clock gate            |
|               |            |             | 1: clock pass            |
| 0             | R/W        | 0x0         | COREO_HCLK_GATE          |



|  | 0: clock gate |
|--|---------------|
|  | 1: clock pass |

### 1.5.3 AHB\_RESET

| Offset: 0x008 |            |             | Register Name: AHB_RESET |
|---------------|------------|-------------|--------------------------|
| Bit           | Read/Write | Default/Hex | Description              |
| 29:4          | /          | /           | Reserved                 |
|               |            |             | ROT_SCLK_RESET           |
| 3             | R/W        | 0x0         | 0: reset on              |
|               |            |             | 1: reset off             |
|               |            |             | RT_WB_SCLK_RESET         |
| 2             | R/W        | 0x0         | 0: reset on              |
|               |            |             | 1: reset off             |
|               |            |             | CORE1_SCLK_RESET         |
| 1             | R/W        | 0x0         | 0: reset on              |
|               |            |             | 1: reset off             |
|               |            |             | COREO_HCLK_RESET         |
| 0             | R/W        | 0x0         | 0: reset on              |
|               |            |             | 1: reset off             |

## **1.5.4 SCLK\_DIV**

| Offset: 0x00C |            |             | Register Name: SCLK_DIV |
|---------------|------------|-------------|-------------------------|
| Bit           | Read/Write | Default/Hex | Description             |
| 31:16         | /          | /           | Reserved                |
| 15:12         | R/W        | 0x0         | ROT_SCLK_DIV            |
| 11:8          | R/W        | 0x0         | RT_WB_SCLK_DIV          |
| 7:4           | R/W        | 0x0         | CORE1_SCLK_DIV          |
| 3:0           | R/W        | 0x0         | COREO_SCLK_DIV          |

### 1.5.5 DE2TCON\_MUX

| Offset: 0x010 |            |             | Register Name: DE2TCON_MUX        |  |
|---------------|------------|-------------|-----------------------------------|--|
| Bit           | Read/Write | Default/Hex | Description                       |  |
| 31:1          | /          | /           | Reserved                          |  |
|               |            |             | DE2TCON_MUX                       |  |
| 0             | R/W        | 0x0         | 0: MIXERO-> TCONO; MIXER1-> TCON1 |  |
|               |            |             | 1: MIXERO-> TCON1; MIXER1-> TCON0 |  |



### 1.5.6 CMD\_CTL

| Offset: 0x014 |            |             | Register Name: CMD_CTL |
|---------------|------------|-------------|------------------------|
| Bit           | Read/Write | Default/Hex | Description            |
| 31:20         | /          | /           | Reserved               |
| 19:16         | R/W        | 0x0         | RT_WB_CMD_CTL          |
| 15:8          | /          | /           | /                      |
| 7:4           | R/W        | 0x0         | CORE1_CMD_CTL          |
| 3:0           | R/W        | 0x0         | COREO_CMD_CTL          |

Note: The number of sending command to DRAM are about N+2.

### 1.5.7 DI\_CTL

| Offset: 0x01C |            |             | Register Name: DI_CTL                                            |
|---------------|------------|-------------|------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                      |
| 31:5          | /          | /           | /                                                                |
|               |            |             | CORE1_DI_CTL                                                     |
| 4             | R/W        | 0x0         | 0: DI disable                                                    |
| 4             |            |             | 1: DI enable                                                     |
|               |            |             | Note: if DI enable, VSU use DI data, otherwise use overlay data. |
| 3:0           | /          | /           | /                                                                |
|               | R/W        | 0x0         | COREO_DI_CTL                                                     |
| 0             |            |             | 0: DI disable                                                    |
| 0             |            |             | 1: DI enable                                                     |
|               |            |             | Note: if DI enable, VSU use DI data, otherwise use overlay data. |



# 2 .H3 Display\_Engine\_Top

#### 2.1 Overview

- Support input layer size up to 2048x2048, and output size up to 2048x2048.
- Support four alpha blending channel for main display, two channel for aux display.
- Support 4 overlay layer in each channel, and has a independent scaler.
- Support potter-duff compatible blending operation.
- Support display enhancement 2.0 for excellent display experience.
- Support write back for high efficient dual display.

### 2.2 Block Diagram



Figure 2-1. Display Top Level Diagram



Figure 2-2. RT-MIXERO Block Diagram





PROC1

Figure 2-3. POST\_PROC1 Block Diagram

DE2.0 post processing, include:

FCE: Fresh and Contrast enhancement

BWS: Black and white stretch

LTI : Luminance transient improvement

PEAK: Luma Peaking

ASE: Adaptive Saturation Enhancement FCC: Fancy color curvature change



Figure 2-4. POST\_PROC2 Block Diagram



Figure 2-5. RT-MIXER1 Block Diagram





Figure 2-6. RT-WB Block Diagram

- Support RGB888 and YUV444 input data format.
- Support input size from 8x4 to 2048x2048.
- Support output size from 8x4 to 2048x2048.
- Support fine down scaling ratio from 1x to 1/2x, and the anti-aliasing filter is 16-phase 4-tap in horizontal, 16-phase 2-tap/4-tap filter in vertical.
- Support coarse down scaling.

### 2.3 Display System Configurations and requirements

#### 2.3.1 Speed requirements:

| Module Name | Speed(Mhz) | Description |
|-------------|------------|-------------|
| RT-MIXERO   | 250        |             |
| RT-MIXER1   | 250        |             |
| RT-WB       | 250        |             |

#### 2.3.2 Memory Space Arrangement:

| Module name | Base address |            |
|-------------|--------------|------------|
| DE          | 0x01000000   | 0x012FFFFF |

| Module name    | Memory Range | Offset Address |
|----------------|--------------|----------------|
| Display system | 64K          | 0x000000       |
| RT-WB          | 64K          | 0x010000       |
| RT-Mixer0      | 1M           | 0x100000       |
| RT-Mixer1      | 1M           | 0x200000       |

### 2.4 Register list

Display system top register list:

| Register name | Offset | Description |
|---------------|--------|-------------|
| SCLK_GATE     | 0x000  |             |
| HCLK_GATE     | 0x004  |             |
| AHB_RESET     | 0x008  |             |



| SCLK_DIV    | 0x00C |  |
|-------------|-------|--|
| DE2TCON_MUX | 0X010 |  |

## 2.5 Register Description

## **2.5.1 SCLK\_GATE**

| Offset: 0 | <b>&lt;</b> 000 |             | Register Name: SCLK_GATE |
|-----------|-----------------|-------------|--------------------------|
| Bit       | Read/Write      | Default/Hex | Description              |
| 31:3      | /               | /           | Reserved                 |
|           |                 |             | RT_WB_SCLK_GATE          |
| 2         | R/W             | 0x0         | 0: clock gate            |
|           |                 |             | 1: clock pass            |
|           |                 |             | CORE1_SCLK_GATE          |
| 1         | R/W             | 0x0         | 0: clock gate            |
|           |                 |             | 1: clock pass            |
|           |                 |             | COREO_SCLK_GATE          |
| 0         | R/W             | 0x0         | 0: clock gate            |
|           |                 |             | 1: clock pass            |

## 2.5.2 HCLK\_GATE

| Offset: 0x004 |                            |     | Register Name: HCLK_GATE |
|---------------|----------------------------|-----|--------------------------|
| Bit           | Bit Read/Write Default/Hex |     | Description              |
| 29:3          | /                          | /   | Reserved                 |
|               |                            |     | RT_WB_HCLK_GATE          |
| 2             | R/W                        | 0x0 | 0: clock gate            |
|               |                            |     | 1: clock pass            |
|               |                            |     | CORE1_HCLK_GATE          |
| 1             | R/W                        | 0x0 | 0: clock gate            |
|               |                            |     | 1: clock pass            |
|               |                            |     | COREO_HCLK_GATE          |
| 0             | R/W                        | 0x0 | 0: clock gate            |
|               |                            |     | 1: clock pass            |

### 2.5.3 AHB\_RESET

| Offset: 0x008 |            |             | Register Name: AHB_RESET |
|---------------|------------|-------------|--------------------------|
| Bit           | Read/Write | Default/Hex | Description              |
| 29:4          | /          | /           | Reserved                 |
| 2             | R/W        | 0x0         | RT_WB_SCLK_RESET         |



|   |     |     | 0: reset on      |
|---|-----|-----|------------------|
|   |     |     | 1: reset off     |
|   |     |     | CORE1_SCLK_RESET |
| 1 | R/W | 0x0 | 0: reset on      |
|   |     |     | 1: reset off     |
|   |     |     | COREO_HCLK_RESET |
| 0 | R/W | 0x0 | 0: reset on      |
|   |     |     | 1: reset off     |

### **2.5.4 SCLK\_DIV**

| Offset: 0x00C              |     |             | Register Name: SCLK_DIV |
|----------------------------|-----|-------------|-------------------------|
| Bit Read/Write Default/Hex |     | Default/Hex | Description             |
| 31:12                      | /   | /           | Reserved                |
| 11:8                       | R/W | 0x0         | RT_WB_SCLK_DIV          |
| 7:4                        | R/W | 0x0         | CORE1_SCLK_DIV          |
| 3:0                        | R/W | 0x0         | COREO_SCLK_DIV          |

## 2.5.5 DE2TCON\_MUX

| Offset: 0x010              |     |             | Register Name: DE2TCON_MUX        |
|----------------------------|-----|-------------|-----------------------------------|
| Bit Read/Write Default/Hex |     | Default/Hex | Description                       |
| 31:1                       | /   | /           | Reserved                          |
|                            |     |             | DE2TCON_MUX                       |
| 0                          | R/W | 0x0         | 0: MIXERO-> TCON0; MIXER1-> TCON1 |
|                            |     |             | 1: MIXERO-> TCON1; MIXER1-> TCON0 |

### 2.5.6 CMD\_CTL

| Offset: 0x014 |                           |     | Register Name: CMD_CTL |
|---------------|---------------------------|-----|------------------------|
| Bit           | it Read/Write Default/Hex |     | Description            |
| 31:20         | /                         | /   | Reserved               |
| 19:16         | R/W                       | 0x0 | RT_WB_CMD_CTL          |
| 15:8          | /                         | /   | /                      |
| 7:4           | R/W                       | 0x0 | CORE1_CMD_CTL          |
| 3:0           | R/W                       | 0x0 | COREO_CMD_CTL          |

Note: The number of sending command to dram are about N+2



# 3 .H5 Display\_Engine\_Top

#### 3.1 Overview

The Display Engine(DE) is a hardware composer to transfer image layers from a local bus or a video buffer to the *LCD* interface, The DE support four overlay windows to blending, and support image post-processing in the video channel. The display system block diagram show as the Figure 1-1.

#### Feature:

- Support output size up to 4096x4096
- Support four alpha blending channels for main display, two channels for aux display.
- Support four overlay layers in each channel, and has a independent scaler.
- Support potter-duff compatible blending operation.
- Support input format YUV422/YUV420/YUV411/ARGB8888/XRGB8888/ARGB4444/ ARGB1555 and RGB565.
- Support Frame Packing/Top-and-Bottom/Side-by-Side Full/Side-by-Side Half 3D format data.
- Support SmartColor2.0 for excellent display experience.
  - Adaptive edge sharping
  - Adaptive color enhancement
  - Adaptive contrast enhancement and fresh tone rectify.
- Support write back for high efficient dual display and miracast.



## 3.2 Block Diagram



Figure 3-1. DE System Block Diagram



Figure 3-2. RT-Mixer0 Blcok Diagram



Figure 3-3. RT-Mixer1 Block Diagram





Figure 3-4. VEP Block Diagram



Figure 3-5. DEP Block Diagram

### 3.3 Operations and Functional Descriptions

#### 3.3.1 Configuration and Requirements

The following table describes the configuration and speed of **DE System**.

Module **VEP Pipe** Overlay **FBD** DI DNR Scaler Type/Line **Blend DEP Buffer** CH<sub>0</sub> 4 layers Ν Ν Ν VScaler/4096 Υ CH1 4 layers Ν Ν Ν GScaler/2048 Ν RT-Mixer0 Υ CSC GScaler/2048 CH2 4 layers Ν Ν Ν Ν CH3 4 layers Ν Ν GScaler/2048 Ν Ν CH0 4 layers Ν Ν Ν VScaler/2048 CSC Υ RT-Mixer1 CSC CH1 4 layers Ν Ν Ν GScaler/2048 Ν

**Table 3-1. RT-Mixer Configuration** 



#### **Table 3-2. RT-WB Configuration**

| Module | Input                       | Scaler Type/ Line Buffer |
|--------|-----------------------------|--------------------------|
|        | RT-MixerO Blending output   |                          |
| RT-WB  | RT-Mixer0 Post-Proc2 output | GScaler/2048             |
| KI-WD  | RT-Mixer1 Blending output   | G3Cdle1/2048             |
|        | RT-Mixer1 Post-Proc2 output |                          |

#### Table 3-3. DE Memory and Speed requirements

| Module Name    | Base Address | Memory Range | Speed(MHz) |
|----------------|--------------|--------------|------------|
| Display System | 0x01000000   | 32K          | 432M       |
| RT-WB          | 0x01010000   | 32K          | 432M       |
| RT-Mixer0      | 0x01100000   | 1M           | 432M       |
| RT-Mixer1      | 0x01200000   | 1M           | 432M       |

#### 3.3.2 Clock Sources

Display Engine controller get two different clocks, Users can select one of them to make DE Clock Source. The following table describes the clock sources for DE. Users can see *Clock Controller Unit(CCU)* for clock setting, configuration and gating information.

Table 3-4. DE Clock Sources

| Clock Sources   | Description                                              |
|-----------------|----------------------------------------------------------|
| PLL_DE          | PLL_DE,default value is 250MHz for DE.                   |
| PLL_PERIPHO(2x) | Peripheral Clock0 source, divide to about 250MHz for DE. |

## 3.4 DE Register List

| Module Name | Base Address |
|-------------|--------------|
| DE          | 0x01000000   |

| Register Name | Offset | Description               |
|---------------|--------|---------------------------|
| DE_SCLK_GATE  | 0x00   | DE SCLK Gating Register   |
| DE_HCLK_GATE  | 0x04   | DE HCLK Gating Register   |
| DE_AHB_RESET  | 0x08   | DE AHB Reset register     |
| DE_SCLK_DIV   | 0x0c   | DE SCLK Division register |
| DE2TCON_MUX   | 0x10   | DE2TCON MUX register      |



## 3.5 DE Register Description

## 3.5.1 DE SCLK Gating Register(Default Value: 0x0000\_0000)

| Offset: 0x00 |            |             | Register Name: DE_SCLK_GATE |
|--------------|------------|-------------|-----------------------------|
| Bit          | Read/Write | Default/Hex | Description                 |
| 31:3         | /          | /           | Reserved                    |
|              |            |             | RT_WB_SCLK_GATE             |
| 2            | R/W        | 0x0         | 0: clock gate               |
|              |            |             | 1: clock pass               |
|              |            |             | CORE1_SCLK_GATE             |
| 1            | R/W        | 0x0         | 0: clock gate               |
|              |            |             | 1: clock pass               |
|              |            |             | COREO_SCLK_GATE             |
| 0            | R/W        | 0x0         | 0: clock gate               |
|              |            |             | 1: clock pass               |

### 3.5.2 DE HCLK Gating Register(Default Value: 0x0000\_0000)

| Offset: 0x04 |                            |     | Register Name: DE_HCLK_GATE |
|--------------|----------------------------|-----|-----------------------------|
| Bit          | Bit Read/Write Default/Hex |     | Description                 |
| 31:3         | /                          | /   | /                           |
|              |                            |     | WB_HCLK_GATE                |
| 2            | R/W                        | 0x0 | 0: clock gate               |
|              |                            |     | 1: clock pass               |
|              |                            |     | CORE1_HCLK_GATE             |
| 1            | R/W                        | 0x0 | 0: clock gate               |
|              |                            |     | 1: clock pass               |
|              |                            |     | COREO_HCLK_GATE             |
| 0            | R/W                        | 0x0 | 0: clock gate               |
|              |                            |     | 1: clock pass               |

### 3.5.3 DE AHB Reset Register(Default Value: 0x0000\_0000)

| Offset: 0x08 |                        |     | Register Name: DE_AHB_RESET |
|--------------|------------------------|-----|-----------------------------|
| Bit          | Read/Write Default/Hex |     | Description                 |
| 31:3         | /                      | /   | /                           |
|              |                        |     | RT_WB_SCLK_RESET            |
| 2            | R/W                    | 0x0 | 0: reset on                 |
|              |                        |     | 1: reset off                |



|   |     |     | CORE1_SCLK_RESET |
|---|-----|-----|------------------|
| 1 | R/W | 0x0 | 0: reset on      |
|   |     |     | 1: reset off     |
|   |     |     | COREO_HCLK_RESET |
| 0 | R/W | 0x0 | 0: reset on      |
|   |     |     | 1: reset off     |

## 3.5.4 DE SCLK Division Register(Default Value: 0x0000\_0000)

| Offset: 0x0C |            |             | Register Name: DE_SCLK_DIV |
|--------------|------------|-------------|----------------------------|
| Bit          | Read/Write | Default/Hex | Description                |
| 31:12        | /          | /           | /                          |
| 11:8         | R/W        | 0x0         | WB_SCLK_DIV                |
| 7:4          | R/W        | 0x0         | CORE1_SCLK_DIV             |
| 3:0          | R/W        | 0x0         | COREO_SCLK_DIV             |

## 3.5.5 DE2TCON MUX Register(Default Value: 0x0000\_0000)

| Offset: 0x10 |            |             | Register Name: DE2TCON_MUX        |
|--------------|------------|-------------|-----------------------------------|
| Bit          | Read/Write | Default/Hex | Description                       |
| 31:1         | /          | /           | /                                 |
|              |            |             | DE2TCON_MUX                       |
| 0            | R/W        | 0x0         | 0: MIXERO-> TCON0; MIXER1-> TCON1 |
|              |            |             | 1: MIXERO-> TCON1; MIXER1-> TCON0 |



# 4 .A83 Display\_Engine\_Top

#### 4.1 Overview

- Support output size up to 2048x2048
- Support four alpha blending channels for main display, two channels for aux display.
- Support four overlay layers in each channel, and has a independent scaler.
- Support potter-duff compatible blending operation.
- Support input format YUV422/YUV420/YUV411/ARGB8888/XRGB8888/RGB8888/ARGB4444/ ARGB1555 and RGB565.
- Support Frame Packing/Top-and-Bottom/Side-by-Side Full/Side-by-Side Half 3D format data.
- Support SmartColor2.0 for excellent display experience.
  - Adaptive edge sharping
  - Adaptive color enhancement
  - Adaptive contrast enhancement and fresh tone rectify.
- Support write back and rotation for high efficient dual display and miracast.



## 4.2 Block Diagram



Figure 4-1. DE System Block Diagram



Figure 4-2. RT-MIXER Core0 Block Diagram





**POST PROC1** 

Figure 4-3. POST\_PROC1 Block Diagram

#### DE2.0 post processing, include:

• FCE: Fresh and Contrast enhancement

BWS: Black and white stretch

• LTI : Luminance transient improvement

PEAK: Luma Peaking

ASE: Adaptive Saturation EnhancementFCC: Fancy color curvature change



Figure 4-4. POST\_PROC2 Block Diagram

**NOTE: DRC: Dynamic Range Controller** 





Figure 4-5. RT-MIXER Core1 Block Diagram



Figure 4-6. RT-WB Block Diagram

- Support RGB888 and YUV444 input data format
- Support input size from 8×4 to 4096×4096
- Support output size from 8×4 to 1920\*1200
- Support fine down scaling ratio from  $1\times$  to  $1/2\times$ , and the anti-aliasing filter is 16-phase 4-tap in horizontal , 16-phase 2-tap/4-tap filter in vertical
- Support coarse down scaling.

#### **Memory to Memory rotation**



Figure 4-7. CSR(Rotation) Block Diagram

#### Input Format:

- 1.16/32bit of RGB and ARGB type,
- YUV422 interleave



- YUV420 combine and planar
- 4.24bit RGB

#### **Output Format:**

- If the input is RGB type, the output format is same as the input format
- If the input format is YUV type, the output format is YUV planar(YUV is stored at 3 address, respectively)

# 4.3 Display system configurations and requirements

# 4.3.1 Memory Space Arrangement:

| Module name | Base address |            |
|-------------|--------------|------------|
| DE          | 0x01000000   | 0x013F0000 |

| Module name    | Memory Range | Offset Address |
|----------------|--------------|----------------|
| Display system | 64K          | 0x000000       |
| RT-WB          | 64K          | 0x010000       |
| CSR            | 64K          | 0x020000       |
| RT-Mixer0      | 1M           | 0x100000       |
| RT-Mixer1      | 1M           | 0x200000       |

# 4.4 Register list

Display system top register list:

| Register name | Offset | Description |
|---------------|--------|-------------|
| SCLK_GATE     | 0x000  |             |
| HCLK_GATE     | 0x004  |             |
| AHB_RESET     | 0x008  |             |
| SCLK_DIV      | 0x00C  |             |
| DE2TCON_MUX   | 0X010  |             |

# 4.5 Register Description

## 4.5.1 SCLK\_GATE

| Offset: 0x000 | Register Name: SCLK_GATE |
|---------------|--------------------------|
|---------------|--------------------------|



| Bit                     | Read/Write | Default/Hex | Description     |  |
|-------------------------|------------|-------------|-----------------|--|
| 31:4                    | /          | /           | Reserved        |  |
|                         |            |             | CSR_SCLK_GATE   |  |
| 3                       | R/W        | 0x0         | 0: clock gate   |  |
|                         |            |             | 1: clock pass   |  |
|                         |            |             | RT_WB_SCLK_GATE |  |
| 2                       | R/W        | 0x0         | 0: clock gate   |  |
|                         |            |             | 1: clock pass   |  |
|                         |            |             | CORE1_SCLK_GATE |  |
| 1                       | R/W        | 0x0         | 0: clock gate   |  |
|                         |            |             | 1: clock pass   |  |
|                         |            |             | COREO_SCLK_GATE |  |
| 0 R/W 0x0 0: clock gate |            | 0x0         | 0: clock gate   |  |
|                         |            |             | 1: clock pass   |  |

# 4.5.2 HCLK\_GATE

| Offset: 0x004 |            |             | Register Name: HCLK_GATE |  |
|---------------|------------|-------------|--------------------------|--|
| Bit           | Read/Write | Default/Hex | Description              |  |
| 29:4          | /          | /           | Reserved                 |  |
|               |            |             | CSR_HCLK_GATE            |  |
| 3             | R/W        | 0x0         | 0: clock gate            |  |
|               |            |             | 1: clock pass            |  |
|               |            |             | RT_WB_HCLK_GATE          |  |
| 2             | R/W        | 0x0         | 0: clock gate            |  |
|               |            |             | 1: clock pass            |  |
|               |            |             | CORE1_HCLK_GATE          |  |
| 1             | R/W        | 0x0         | 0: clock gate            |  |
|               |            |             | 1: clock pass            |  |
|               |            |             | COREO_HCLK_GATE          |  |
| 0             | R/W        | 0x0         | 0: clock gate            |  |
|               |            |             | 1: clock pass            |  |

# 4.5.3 AHB\_RESET

| Offset: 0 | Offset: 0x008 |             | Register Name: AHB_RESET |  |
|-----------|---------------|-------------|--------------------------|--|
| Bit       | Read/Write    | Default/Hex | Description              |  |
| 29:4      | /             | /           | Reserved                 |  |
|           |               |             | CSR_SCLK_RESET           |  |
| 3         | R/W           | 0x0         | 0: reset on              |  |
|           |               |             | 1: reset off             |  |
|           |               |             | RT_WB_SCLK_RESET         |  |
| 2         | R/W           | 0x0         | 0: reset on              |  |
|           |               |             | 1: reset off             |  |



|   |     |     | CORE1_SCLK_RESET |
|---|-----|-----|------------------|
| 1 | R/W | 0x0 | 0: reset on      |
|   |     |     | 1: reset off     |
|   |     |     | COREO_HCLK_RESET |
| 0 | R/W | 0x0 | 0: reset on      |
|   |     |     | 1: reset off     |

# 4.5.4 SCLK\_DIV

| Offset: 0x00C |            |             | Register Name: SCLK_DIV |  |
|---------------|------------|-------------|-------------------------|--|
| Bit           | Read/Write | Default/Hex | Description             |  |
| 31:16         | /          | /           | Reserved                |  |
| 15:8          | R/W        | 0x0         | CSR_SCLK_DIV            |  |
| 11:8          | R/W        | 0x0         | RT_WB_SCLK_DIV          |  |
| 7:4           | R/W        | 0x0         | CORE1_SCLK_DIV          |  |
| 3:0           | R/W        | 0x0         | COREO_SCLK_DIV          |  |

# 4.5.5 DE2TCON\_MUX

| Offset: 0x010 |            |             | Register Name: DE2TCON_MUX        |  |
|---------------|------------|-------------|-----------------------------------|--|
| Bit           | Read/Write | Default/Hex | Description                       |  |
| 31:1          | /          | /           | Reserved                          |  |
|               |            |             | DE2TCON_MUX                       |  |
| 0             | R/W 0x0    |             | 0: MIXERO-> TCON0; MIXER1-> TCON1 |  |
|               |            |             | 1: MIXERO-> TCON1; MIXER1-> TCON0 |  |



# 5 .Sub\_Module\_Specification

# **5.1 DE ASE Specification**

# **5.1.1 Register List**

| Module name | Memory Range | Offset Address |
|-------------|--------------|----------------|
| ASE         | 8K           | 0xA8000        |

| Register name | Offset | Description             |
|---------------|--------|-------------------------|
| ASE_CTRL_REG  | 0x000  | Global control register |
| ASE_SIZE_REG  | 0x004  | ASE size register       |
| ASE_WINO_REG  | 0x008  | Windows top position    |
| ASE_WIN1_REG  | 0х00с  | Windows bottom position |
| ASE_WEIGHT    | 0x010  | ASE gain register       |

# **5.1.2** Register Description

#### 5.1.2.1 Global Control Register

| Offset | Offset: 0x000 |                         | Register Name: ASE_CTL_REG                                                                 |
|--------|---------------|-------------------------|--------------------------------------------------------------------------------------------|
| Bit    | Read/Write    | Default/Hex Description |                                                                                            |
| 31:2   | /             | /                       | Reserved                                                                                   |
|        |               |                         | WINDOW_EN                                                                                  |
|        |               |                         | LCE window function enable                                                                 |
| 1      | R/W           |                         | 0:Disable                                                                                  |
| 1      | K/VV          | 0x0                     | 0:Disable 1:Enable Note: When window function enable, only the area inside the window will |
|        |               |                         |                                                                                            |
|        |               |                         | be processed.                                                                              |
|        |               |                         | ASE_EN                                                                                     |
| 0      | R/W 0x0       | 0x0                     | 0: disable                                                                                 |
|        |               |                         | 1: enable                                                                                  |

#### **5.1.2.2** ASE size register

| Offset: 0x004 |            |             | Register Name: ASE_SIZE_REG                     |  |
|---------------|------------|-------------|-------------------------------------------------|--|
| Bit           | Read/Write | Default/Hex | lex Description                                 |  |
| 31:28         | /          | /           | Reserved                                        |  |
| 27:16         | R/W        | 0v0         | HEIGHT                                          |  |
| 27:16         | K/VV       | 0x0         | The real height = The value of these bits add 1 |  |



| 15:12 | /      | /    | /                                              |
|-------|--------|------|------------------------------------------------|
| 11.0  | D /\A/ | 0.40 | WIDTH                                          |
| 11:0  | R/W    | 0x0  | The real width = The value of these bits add 1 |

# 5.1.2.3 ASE windows0 register

| Offset: | 0x008      |             | Register Name: ASE_WINO_REG                                           |  |
|---------|------------|-------------|-----------------------------------------------------------------------|--|
| Bit     | Read/Write | Default/Hex | Description                                                           |  |
| 31:28   | /          | /           | /                                                                     |  |
|         |            |             | WIN_TOP                                                               |  |
| 27:16   | R/W        | 0           | Window Top position                                                   |  |
|         |            |             | Top position is the left-top y coordinate of display window in pixels |  |
| 15:12   | /          | /           | /                                                                     |  |
|         |            |             | WIN_LEFT                                                              |  |
| 11:0    | R/W        | 0           | Window Left position                                                  |  |
|         |            |             | Left position is left-top x coordinate of display window in pixels    |  |

# 5.1.2.4 ASE windows1 register

| Offset: | 0x00C      |             | Register Name: ASE_WIN1_REG                                              |  |
|---------|------------|-------------|--------------------------------------------------------------------------|--|
| Bit     | Read/Write | Default/Hex | Description                                                              |  |
| 31:28   | /          | /           | /                                                                        |  |
|         |            |             | WIN_BOT                                                                  |  |
| 27:16   | R/W        | 0           | Window Bottom position                                                   |  |
|         |            |             | Bottom position is right-bottom y coordinate of display window in pixels |  |
| 15:12   | /          | /           | /                                                                        |  |
|         |            |             | WIN_RIGHT                                                                |  |
| 11:0    | R/W        | 0           | Window Right position                                                    |  |
|         |            |             | Right position is right-bottom x coordinate of display window in pixels  |  |

# 5.1.2.5 ASE gain register

| Offset: 0x010 |            |             | Register Name: ASE_WEIGHT |
|---------------|------------|-------------|---------------------------|
| Bit           | Read/Write | Default/Hex | Description               |
| 31:6          | /          | /           | Reserved                  |
| 5:0           | R/W        | 0x0         | ASE_WEIGHT                |



# **5.2 DE BWS Specification**

#### 5.2.1 Overview

The BWS(Black and White Stetch) features:

- Support data format with 8-bit pre channel.
- Support Maximum input frame size 4096×2160
- Interface: Stream-to-stream pixel interface

# 5.2.2 Register List

| Module name | Memory Range | Offset Address |
|-------------|--------------|----------------|
| BWS         | 8K           | 0xA2000        |

| Register name | Offset | Description                     |
|---------------|--------|---------------------------------|
| BWS_GCTRL_REG | 0x000  | Control register                |
| BWS_SIZE_REG  | 0x004  | Size setting register           |
| BWS_WINO_REG  | 0x008  | Window setting register0        |
| BWS_WIN1_REG  | 0x00C  | Window setting register1        |
| BWS_THRO_REG  | 0x020  | BWS threshold setting register0 |
| BWS_THR1_REG  | 0x024  | BWS threshold setting register1 |
| BWS_SLPO_REG  | 0x028  | BWS slope setting register0     |
| BWS_SLP1_REG  | 0x02C  | BWS slope setting register1     |

# **5.2.3** Register Description

#### 5.2.3.1 BWS\_GCTRL\_REG

| Offset: | : 0x000    |                             | Register Name: GCTRL_REG                                                          |
|---------|------------|-----------------------------|-----------------------------------------------------------------------------------|
| Bit     | Read/Write | ite Default/Hex Description |                                                                                   |
|         |            |                             | WINDOW_EN                                                                         |
|         |            |                             | BWS window function enable                                                        |
| 21      | D (M)      | 0,40                        | 0:Disable                                                                         |
| 31      | R/W        | 0x0                         | 1:Enable  Note: When window function enable, only the area inside the window will |
|         |            |                             |                                                                                   |
|         |            |                             | be processed.                                                                     |
| 30:1    | /          | /                           | /                                                                                 |
|         |            |                             | EN                                                                                |
|         |            |                             | BWS module enable                                                                 |
| 0       | R/W        | 0x0                         | 0: Disable                                                                        |
|         |            |                             | 1: Enable                                                                         |
|         |            |                             | Note: When module disable, the clock of the calculation circuit will be gated     |



|  | automatically    |
|--|------------------|
|  | l automatically. |
|  | automaticany.    |

Note: All bits in BWS\_CTRL\_REG is double-buffered.

# 5.2.3.2 BWS\_SIZE\_REG

| Offset: 0x004 |            |             | Register Name: BWS_SIZE_REG             |  |
|---------------|------------|-------------|-----------------------------------------|--|
| Bit           | Read/Write | Default/Hex | Description                             |  |
| 31:28         | /          | /           | /                                       |  |
|               |            |             | HEIGHT                                  |  |
| 27:16         | R/W        | 0x0         | Input height                            |  |
|               |            |             | The actual height is register value + 1 |  |
| 15:12         | /          | /           | /                                       |  |
|               |            |             | WIDTH                                   |  |
| 11:0          | R/W        | 0x0         | Input width                             |  |
|               |            |             | The actual width is register value + 1  |  |

#### **5.2.3.3 BWS\_WINO\_REG**

| Offset: 0 | 0x008      |             | Register Name: BWS_WINO_REG                                           |  |
|-----------|------------|-------------|-----------------------------------------------------------------------|--|
| Bit       | Read/Write | Default/Hex | Description                                                           |  |
| 31:28     | /          | /           | 1                                                                     |  |
|           |            |             | WIN_TOP                                                               |  |
| 27:16     | R/W        | 0           | Window Top position                                                   |  |
|           |            |             | Top position is the left-top y coordinate of display window in pixels |  |
| 15:12     | /          | /           | 1                                                                     |  |
|           |            |             | WIN_LEFT                                                              |  |
| 11:0      | R/W        | 0           | Window Left position                                                  |  |
|           |            |             | Left position is left-top x coordinate of display window in pixels    |  |

#### 5.2.3.4 BWS\_WIN1\_REG

| Offset: 0x00C |            |             | Register Name: BWS_WIN1_REG                                              |  |
|---------------|------------|-------------|--------------------------------------------------------------------------|--|
| Bit           | Read/Write | Default/Hex | Description                                                              |  |
| 31:28         | /          | /           | /                                                                        |  |
|               |            |             | WIN_BOT                                                                  |  |
| 27:16         | R/W        | 0           | Window Bottom position                                                   |  |
|               |            |             | Bottom position is right-bottom y coordinate of display window in pixels |  |
| 15:12         | /          | /           | /                                                                        |  |
|               |            |             | WIN_RIGHT                                                                |  |
| 11:0          | R/W        | 0           | Window Right position                                                    |  |
|               |            |             | Right position is right-bottom x coordinate of display window in pixels  |  |

#### **5.2.3.5 BWS\_THRO\_REG**

| Offset: 0x020 |            |             | Register Name: BWS_THRO_REG |
|---------------|------------|-------------|-----------------------------|
| Bit           | Read/Write | Default/Hex | Description                 |
| 31:24         | /          | /           | /                           |



| 23:16 | R/W   | 0x0     | BLACK Black level stretch threshold 1 |
|-------|-------|---------|---------------------------------------|
| 15:8  | /     | /       | /                                     |
| 7:0   | R/W   | 0.40    | MIN                                   |
| 7.0   | ry vv | R/W 0x0 | Black level stretch threshold 0       |

## **5.2.3.6 BWS\_THR1\_REG**

| Offset: 0x024 |            |                         | Register Name: BWS_THR1_REG     |
|---------------|------------|-------------------------|---------------------------------|
| Bit           | Read/Write | Default/Hex Description |                                 |
| 31:24         | /          | /                       | /                               |
| 23:16         | R/W        | 0x0                     | MAX                             |
| 20:20         |            |                         | White level stretch threshold 1 |
| 15:8          | /          | /                       | 1                               |
| 7:0           | R/W        | 0x0                     | WHITE                           |
|               |            |                         | White level stretch threshold 0 |

## 5.2.3.7 BWS\_SLP0\_REG

| Offset: 0x028 |            |             | Register Name: BWS_SLPO_REG |  |
|---------------|------------|-------------|-----------------------------|--|
| Bit           | Read/Write | Default/Hex | fault/Hex Description       |  |
| 31:26         | /          | /           | 1                           |  |
| 25.46         | R/W        | 0x0         | SLOPE1                      |  |
| 25:16         |            |             | Black level stretch slope 1 |  |
| 15:10         | /          | /           | /                           |  |
| 9:0           | R/W        | 0x0         | SLOPE0                      |  |
|               |            |             | Black level stretch slope 0 |  |

#### **5.2.3.8 BWS\_SLP1\_REG**

| Offset: 0x02C |            |             | Register Name: BWS_SLP1_REG |
|---------------|------------|-------------|-----------------------------|
| Bit           | Read/Write | Default/Hex | Description                 |
| 31:26         | /          | /           | /                           |
| 25.16         | R/W        | 0x0         | SLOPE3                      |
| 25:16         |            |             | White level stretch slope 1 |
| 15:10         | /          | /           | /                           |
| 9:0           | R/W        | 0x0         | SLOPE2                      |
|               |            |             | White level stretch slope 0 |



# **5.3 DE CSC Specification**

#### 5.3.1 Overview

The CSC features:

- Support 33-bit data format with 8-bit pre channel.
- Interface: Stream-to-stream pixel interface

## 5.3.2 Register List

| Module | Offset Address | Memory Range |
|--------|----------------|--------------|
| CSC    | 0x011F0000     | 8K           |

| Register name  | Offset              | Description                        |
|----------------|---------------------|------------------------------------|
| CSC_BYPASS_REG | 0x000               | CSC bypass setting register        |
| CSC_COEFFO_REG | 0x010, 0x014, 0x018 | CSC CH0 coefficients registers     |
| CSC_CONSTO_REG | 0x01C               | CSC CH0 constant register          |
| CSC_COEFF1_REG | 0x020, 0x024, 0x028 | CSC CH1 coefficients registers     |
| CSC_CONST1_REG | 0x02C               | CSC CH1 constant register          |
| CSC_COEFF2_REG | 0x030, 0x034, 0x038 | CSC CH2 coefficients registers     |
| CSC_CONST2_REG | 0x03C               | CSC CH2 constant register          |
| GLB_ALPHA_REG  | 0x040               | Direct output alpha value register |

# **5.3.3** Register Description

#### 5.3.3.1 CSC\_BYPASS\_REG

| Offset: 0x00 |                            |     | Register Name: CSC_BYPASS_REG |
|--------------|----------------------------|-----|-------------------------------|
| Bit          | Bit Read/Write Default/Hex |     | Description                   |
| 31:1         | /                          | /   | 1                             |
|              | R/W                        | 0x0 | CSC_BYPASS                    |
| 0            |                            |     | CSC bypass                    |
|              |                            |     | 0: Bypass                     |
|              |                            |     | 1: Not bypass                 |

#### 5.3.3.2 CSC\_COEFFO\_REG

| Offset:             |                               |
|---------------------|-------------------------------|
| C00 component: 0x10 | Register Name: CSC_COEFF0_REG |
| C01 component: 0x14 |                               |



| C02 com | ponent: 0x18               |     |                                                 |
|---------|----------------------------|-----|-------------------------------------------------|
| Bit     | Bit Read/Write Default/Hex |     | Description                                     |
| 31:13   | /                          | /   | /                                               |
| 12:0    | R/W                        | 0x0 | COEFF                                           |
| 12.0    | N/ VV                      | UXU | The value equals to coefficient*2 <sup>10</sup> |

## 5.3.3.3 CSC\_CONSTO\_REG

| Offset: 0x1C |            |             | Register Name: CSC_CONST0_REG                   |  |
|--------------|------------|-------------|-------------------------------------------------|--|
| Bit          | Read/Write | Default/Hex | Description                                     |  |
| 31:20        | /          | /           | 1                                               |  |
| 19:0         | R/W        | 0x0         | CONST                                           |  |
| 19.0         | N/ VV      | UXU         | The value equals to coefficient*2 <sup>10</sup> |  |

# 5.3.3.4 CSC\_COEFF1\_REG

| Offset:             |               |             | Davistas Namas CCC COFFEA DEC                   |  |
|---------------------|---------------|-------------|-------------------------------------------------|--|
| C10 component: 0x20 |               |             |                                                 |  |
| C11 com             | nponent: 0x24 |             | Register Name: CSC_COEFF1_REG                   |  |
| C12 com             | nponent: 0x28 |             |                                                 |  |
| Bit                 | Read/Write    | Default/Hex | Description                                     |  |
| 31:13               | /             | /           | /                                               |  |
| 12.0                | 12:0 R/W      | V 0x0       | COEFF                                           |  |
| 12:0                |               |             | The value equals to coefficient*2 <sup>10</sup> |  |

# 5.3.3.5 CSC\_CONST1\_REG

| Offset: 0 | Offset: 0x2C |             | Register Name: CSC_CONST1_REG                   |
|-----------|--------------|-------------|-------------------------------------------------|
| Bit       | Read/Write   | Default/Hex | Description                                     |
| 31:20     | /            | /           | /                                               |
| 19:0      | R/W          | 0x0         | CONST                                           |
| 19.0      | K/ VV        | UXU         | The value equals to coefficient*2 <sup>10</sup> |

# 5.3.3.6 CSC\_COEFF2\_REG

| Offset:             |                     |             | Desired Name of Control DEC                     |  |
|---------------------|---------------------|-------------|-------------------------------------------------|--|
| C20 component: 0x30 |                     |             |                                                 |  |
| C21 com             | nponent: 0x34       |             | Register Name: CSC_COEFF2_REG                   |  |
| C22 com             | C22 component: 0x38 |             |                                                 |  |
| Bit                 | Read/Write          | Default/Hex | Description                                     |  |
| 31:13               | /                   | /           | /                                               |  |
| 43.0                | D /\A/              | 0x0         | COEFF                                           |  |
| 12:0                | R/W                 |             | The value equals to coefficient*2 <sup>10</sup> |  |



# 5.3.3.7 CSC\_CONST2\_REG

| Offset: 0 | )x3C       |             | Register Name: CSC_CONST2_REG                   |  |
|-----------|------------|-------------|-------------------------------------------------|--|
| Bit       | Read/Write | Default/Hex | Description                                     |  |
| 31:20     | /          | /           | 1                                               |  |
| 19:0      | R/W        | 0x0         | CONST                                           |  |
| 25.0      | .,,        | 57.0        | The value equals to coefficient*2 <sup>10</sup> |  |

#### 5.3.3.8 GLB\_ALPHA\_REG

| Offset: 0x40 |            |                                  | Register Name: GLB_ALPHA_REG         |
|--------------|------------|----------------------------------|--------------------------------------|
| Bit          | Read/Write | ad/Write Default/Hex Description |                                      |
| 31:24        | 5 /14/     | 055                              | GLOBAL ALPHA                         |
| 31.24        | R/W        | 0xFF                             | The direct output global alpha value |
| 23:0         | /          | /                                | /                                    |



# 5.4 DE DRC Specification

#### 5.4.1 Overview

The dynamic range controller (DRC) is a post-processing module which adjusts the image mapping curve according to the histogram frame by frame. The control function can be defined by the software driver according to the application. A typical application is Content-based backlight control.

#### Feature:

- Support data format with 8-bit per channel
- Support 2048\*2048 input/output
- Support HISTOGRAM and DRC in HSV color space

# **5.4.2** Register List

| Module | Offset Address | Memory Range |
|--------|----------------|--------------|
| DRC    | 0x011b0000     | 64K          |

| Register Name  | Offset       | Description                                                 |  |  |
|----------------|--------------|-------------------------------------------------------------|--|--|
| GNECTL_REG     | 0x0000       | Module general control register                             |  |  |
| DRC_SIZE_REG   | 0x0004       | DRC size setting register                                   |  |  |
| DRC_CTL_REG    | 0x0010       | DRC control register                                        |  |  |
| DRC_SET_REG    | 0x0018       | DRC setting register                                        |  |  |
| DRC_WPO_REG    | 0x001C       | DRC window position register0                               |  |  |
| DRC_WP1_REG    | 0x0020       | DRC window position register1                               |  |  |
| LH_CTL_REG     | 0x0030       | Luminance histogram control register                        |  |  |
| LH_THRO_REG    | 0x0034       | Luminance histogram threshold setting register0             |  |  |
| LH_THR1_REG    | 0x0038       | Luminance histogram threshold setting register1             |  |  |
| TH CITIMAN DEC | 0x0040 + N*4 | Luminance histogram statistics luminance recording register |  |  |
| LH_SLUMN_REG   | (N=0 ~ 7)    | Luminance histogram statistics luminance recording register |  |  |
| LH_SCNTN_REG   | 0x0060 + N*4 | Luminance hictogram statistics counter recording register   |  |  |
| LH_3CNTN_REG   | (N=0 ~ 7)    | Luminance histogram statistics counter recording register   |  |  |
| CSC_C00_REG    | 0x00C0       | CSC coefficient 00 register                                 |  |  |
| CSC_C01_REG    | 0x00C4       | CSC coefficient 01 register                                 |  |  |
| CSC_C02_REG    | 0x00C8       | CSC coefficient 02 register                                 |  |  |
| CSC_C03_REG    | 0x00CC       | CSC constant 03 register                                    |  |  |
| CSC_C10_REG    | 0x00D0       | CSC coefficient 10 register                                 |  |  |
| CSC_C11_REG    | 0x00D4       | CSC coefficient 11 register                                 |  |  |
| CSC_C12_REG    | 0x00D8       | CSC coefficient 12 register                                 |  |  |
| CSC_C13_REG    | 0x00DC       | CSC constant 13 register                                    |  |  |
| CSC_C20_REG    | 0x00E0       | CSC coefficient 20 register                                 |  |  |



| CSC_C21_REG      | 0x00E4      | CSC coefficient 21 register              |  |
|------------------|-------------|------------------------------------------|--|
| CSC_C22_REG      | 0x00E8      | CSC coefficient 22 register              |  |
| CSC_C23_REG      | 0x00EC      | CSC constant 23 register                 |  |
| DDC CDACOEL DECN | 0x0F0 + N*4 | DDC spatial coefficient registers        |  |
| DRC_SPACOFF_REGN | (N=0,1,2)   | DRC spatial coefficient registers        |  |
| DDC INTCOFF DECN | 0x100 + N*4 | DDC intensity as efficient registers     |  |
| DRC_INTCOFF_REGN | (N=0 ~ 63)  | DRC intensity coefficient registers      |  |
| DDC ICCOFF DECN  | 0x200 + N*4 |                                          |  |
| DRC_LGCOFF_REGN  | (N=0 ~ 127) | DRC Luminance gain coefficient registers |  |

# **5.4.3 Register Description**

# 5.4.3.1 General control register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: GNECTL_REG                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
|                |            |             | BIST_EN                                                                  |
| 31             | R/W        | 0x0         | BIST enable                                                              |
| 31             | N/ VV      | OXO         | 0x0: disable                                                             |
|                |            |             | 0x1: enable                                                              |
| 30:10          | /          | /           | /                                                                        |
|                |            |             | MOD                                                                      |
|                |            |             | Work mode selection. If bit 0 of the register is set ZERO, the following |
|                |            |             | setting will be ignored.                                                 |
| 09:08          | R/W        | 0x0         | 0x0: reserved                                                            |
|                |            |             | 0x1: reserved                                                            |
|                |            |             | 0x2: DRC mode                                                            |
|                |            |             | 0x3: reserved                                                            |
| 07:05          | /          | /           | /                                                                        |
|                |            |             | COEF_SWITCH_EN                                                           |
|                |            |             | 0x0: DONOT switch                                                        |
|                |            |             | 0x1: Switch RAM use external RDY_EN                                      |
| 04             | R/W        | 0x0         |                                                                          |
| 01             | 1,7,11     | o Ao        | Note: When LCD SYNC negative edge comes and COEF_SWITCH_EN is 1,         |
|                |            |             | DRC_LGCOFF_REGN will switch to the latest updated RAM if external        |
|                |            |             | RDY_EN equal to 1, and then the bit will also be self-cleared if switch  |
|                |            |             | action successes.                                                        |
| 03:02          | /          | /           | /                                                                        |
| 01             | R/W        | 0x0         | Reserved                                                                 |
|                | .,,        | 0.00        | Note: Must set to 0.                                                     |
|                |            |             | DRC_EN                                                                   |
|                | R/W        | 0x0         | DRC module enable                                                        |
| 00             |            |             | 0x0: disabled                                                            |
|                |            |             | 0x1: enable                                                              |
| <u> </u>       |            |             |                                                                          |



|  | Note: When module disable, the input data will be bypassed to output, |
|--|-----------------------------------------------------------------------|
|  | and the clock of calculation circuit will be gated automatically.     |

# 5.4.3.2 DRC size setting register (Default Value: 0x0000\_0000)

| Offset: 0 | x0004                  |     | Register Name: DRC_SIZE_REG                            |
|-----------|------------------------|-----|--------------------------------------------------------|
| Bit       | Read/Write Default/Hex |     | Description                                            |
| 31:29     | /                      | /   | /                                                      |
|           |                        | 0x0 | DRC_HEIGHT                                             |
| 28:16     | R/W                    |     | Display height                                         |
| 28:16     |                        |     | The real display height = The value of these bits + 1. |
|           |                        |     | Note: Must set to 7~2047 when module enable.           |
| 15:13     | /                      | /   | /                                                      |
|           |                        |     | DRC_WIDTH                                              |
| 12:00     | R/W                    | 0x0 | Display width                                          |
|           |                        |     | The real display width = The value of these bits + 1.  |

# 5.4.3.3 DRC control register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: DRC_CTL_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:10          | /          | /           | /                                                                   |
|                |            |             | HSV_MODE_EN                                                         |
|                |            |             | Enable Using component V calculated from three source components to |
|                |            |             | process Luma Histogram and DRC.                                     |
| 09             | R/W        | 0x0         | 0x0: disable                                                        |
|                |            |             | 0x1: enable                                                         |
|                |            |             |                                                                     |
|                |            |             | Note: Must set to 1.                                                |
|                |            |             | DRC_WIN_EN                                                          |
| 08             | R/W        | 0x0         | Output window function enable                                       |
| 08             |            |             | 0x0: disable                                                        |
|                |            |             | 0x1: enable                                                         |
| 07:01          | /          | /           | /                                                                   |
|                |            | 0x0         | DRC_DB_EN                                                           |
| 00             | D (\A)     |             | DRC double buffer function enable control                           |
| 00             | R/W        |             | 0x0: disable                                                        |
|                |            |             | 0x1: enable                                                         |

# 5.4.3.4 DRC setting register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: DRC_SET_REG  |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:16          | /          | /           | /                           |
| 15.00          | R/W        | 0x0         | DRC_LGC_ABSLUMPERVAL        |
| 15:08          |            |             | Abs luminance percent value |



| 07:02 | /     | /   | /                        |
|-------|-------|-----|--------------------------|
|       |       |     | DRC_ADJUST_EN            |
| 01    | D (M) | 0.0 | DRC adjust enable        |
| 01    | R/W   | 0x0 | 0x0: disable             |
|       |       |     | 0x1: enable              |
|       |       | 0x0 | DRC_LGC_ABSLUMSHF        |
| 00    | D (M) |     | Abs luminance shift bits |
| 00    | R/W   |     | 0x0: shift 8bits         |
|       |       |     | 0x1: shift 9bits         |

# 5.4.3.5 DRC window position 0 register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: DRC_WP0_REG                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:28          | /          | /           | /                                                                     |
|                |            |             | DRC_WIN_TOP                                                           |
| 27:16          | R/W        | 0x0         | Window Top position                                                   |
|                |            |             | Top position is the left-top y coordinate of display window in pixels |
| 15:12          | /          | /           |                                                                       |
|                |            |             | DRC_WIN_LEFT                                                          |
| 11:00          | R/W        | 0x0         | Window Left position                                                  |
|                |            |             | Left position is left-top x coordinate of display window in pixels    |

# 5.4.3.6 DRC window position 1 register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: DRC_WP1_REG                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:28          | /          | /           | /                                                                           |
|                |            |             | DRC_WIN_BOT                                                                 |
| 27.16          | D /\A/     | 0x0         | Window Bottom position                                                      |
| 27:16          | R/W        |             | Bottom position is the right-bottom y coordinate of display window in       |
|                |            |             | pixels                                                                      |
| 15:12          | /          | /           | /                                                                           |
|                |            |             | DRC_WIN_RIGHT                                                               |
| 11:0           | R/W        | 0x0         | Window Right position                                                       |
|                |            |             | Right position is the right-bottom x coordinate of display window in pixels |

## 5.4.3.7 Luminance histogram control register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: LH_CTL_REG |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:02          | /          | /           | /                         |
|                |            |             | LH_MOD                    |
| 1              | R/W        | 0x0         | 0: Current frame case     |
|                |            |             | 1: Average case           |
| 0              | R/W        | 0x0         | LH_REC_CLR                |



|  | If the bit is set, the all of the luminance statistics recording registers will be |
|--|------------------------------------------------------------------------------------|
|  | clear, and the bit will self-clear when the recording registers is clear done.     |

#### 5.4.3.8 Luminance histogram threshold setting 0 register (Default Value: 0x8060\_4020)

| Offset: 0 | k0034      |             | Register Name: LH_THRO_REG |
|-----------|------------|-------------|----------------------------|
| Bit       | Read/Write | Default/Hex | Description                |
| 31:24     | R/W        | 0.480       | LH_THRES_VAL4              |
| 31.24     | R/VV       | 0x80        | Step4 threshold value      |
| 23:16     | R/W        | 0x60        | LH_THRES_VAL3              |
| 23.10     |            |             | Step3 threshold value      |
| 15:8      | D /\A/     | 0x40        | LH_THRES_VAL2              |
| 15:8      | R/W        |             | Step2 threshold value      |
| 7.0       | D /\A/     | 0x20        | LH_THRES_VAL1              |
| 7:0       | R/W        |             | Step1 threshold value      |

#### 5.4.3.9 Luminance histogram threshold setting 1 register (Default Value: 0x00E0\_C0A0)

| Offset: 0 | k0038      |             | Register Name: LH_THR1_REG |
|-----------|------------|-------------|----------------------------|
| Bit       | Read/Write | Default/Hex | Description                |
| 31:24     | /          | /           | /                          |
| 23:16     | R/W        | 0xE0        | LH_THRES_VAL7              |
| 23.10     |            |             | Step7 threshold value      |
| 15:08     | R/W        | 0xC0        | LH_THRES_VAL6              |
| 15:08     |            |             | Step6 threshold value      |
| 07:00     | R/W        | 0xA0        | LH_THRES_VAL5              |
| 07:00     |            |             | Step5 threshold value      |

Note: When setting LHT\_REG0 and LHT\_REG1, make sure that THRES\_VAL1<THRES\_VAL2<...<THRES\_VAL7.

# 5.4.3.10 Luminance histogram statistics lum recording register N (N = $0^{\sim}7$ ) (Default Value: $0\times0000\_0000$ )

| Offset: 0x0040 + N*4 |            |             | Register Name: LH_SLUM_REGN |
|----------------------|------------|-------------|-----------------------------|
| Bit                  | Read/Write | Default/Hex | Description                 |
| 31:00                | R/W        | 0x0         | LH_LUM_DATA                 |
|                      |            |             | Luminance statistics data   |

# 5.4.3.11 Luminance histogram statistics counter recording register N (N = $0^{-7}$ ) (Default Value: $0\times0000\_0000$ )

| Offset: 0x0060 + N*4 |            |             | Register Name: LH_SCNT_REGN |
|----------------------|------------|-------------|-----------------------------|
| Bit                  | Read/Write | Default/Hex | Description                 |
| 31:24                | /          | /           | /                           |
| 22.00                | R/W        | 0x0         | LH_CNT_DATA                 |
| 23:00                |            |             | Luminance statistics data   |



#### 5.4.3.12 CSC coefficient 00 register (Default Value: 0x0000\_04A7)

| Offset: 0x00C0 |            |             | Register Name: CSC_C00_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:13          | /          | /           | /                          |
| 12.0           | R/W        | 0x04A7      | C00                        |
| 12:0           |            |             | Note: must set to 0x0400.  |

#### 5.4.3.13 CSC coefficient 01 register (Default Value: 0x0000\_1E6F)

| Offset: 0x00C4 |            |             | Register Name: CSC_C01_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:13          | /          | /           | 1                          |
| 12.0           | R/W        | 0x1E6F      | C01                        |
| 12:0           |            |             | Note: must set to 0x0000.  |

#### 5.4.3.14 CSC coefficient 02 register (Default Value: 0x0000\_1CBF)

| Offset: 0x00C8 |            |             | Register Name: CSC_C02_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:13          | /          | /           | /                          |
| 12:0 R/W       | Ov1CDE     | C02         |                            |
| 12.0           | r/vv       | 0x1CBF      | Note: must set to 0x0000.  |

#### 5.4.3.15 CSC constant 03 register (Default Value: 0x0000\_0877)

| Offset: 0x00CC |            |             | Register Name: CSC_C03_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:14          | /          | /           | /                          |
| 12.0           | 13:0 R/W   | 0x0877      | C03                        |
| 13:0           |            |             | Note: must set to 0x0000.  |

#### 5.4.3.16 CSC coefficient 10 register (Default Value: 0x0000\_04A7)

| Offset: 0x00D0 |            |             | Register Name: CSC_C10_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:13          | /          | /           | 1                          |
| 12.0           | D //A/     | 0.044.7     | C10                        |
| 12:0           | R/W        | 0x04A7      | Note: must set to 0x0000.  |

#### 5.4.3.17 CSC coefficient 11 register (Default Value: 0x0000\_0000)

| Offset: 0x | :00D4      |             | Register Name: CSC_C11_REG |
|------------|------------|-------------|----------------------------|
| Bit        | Read/Write | Default/Hex | Description                |
| 31:13      | /          | /           | /                          |
| 12:0       | R/W        | 0x0000      | C11                        |



|  |  |  | Note: must set to 0x0400. |
|--|--|--|---------------------------|
|--|--|--|---------------------------|

#### 5.4.3.18 CSC coefficient 12 register (Default Value: 0x0000\_0662)

| Offset: 0x | (00D8      |             | Register Name: CSC_C12_REG |
|------------|------------|-------------|----------------------------|
| Bit        | Read/Write | Default/Hex | Description                |
| 31:13      | /          | /           | 1                          |
| 12:0 R/W   | D ///      | 0x0662      | C12                        |
| 12.0       | R/W        |             | Note: must set to 0x0000.  |

#### 5.4.3.19 CSC constant 13 register (Default Value: 0x0000\_3211)

| Offset: 0x00DC |            |             | Register Name: CSC_C13_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:14          | /          | /           | /                          |
| 12.0           | D /W       | 0x3211      | C13                        |
| 13:0           | R/W        |             | Note: must set to 0x0000.  |

#### 5.4.3.20 CSC coefficient 20 register (Default Value: 0x0000\_04A7)

| Offset: 0x00E0 |            |             | Register Name: CSC_C20_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:13          | /          | /           | /                          |
| 12:0           | R/W        | 0x04A7      | C20                        |
|                |            |             | Note: must set to 0x0000.  |

# 5.4.3.21 CSC coefficient 21 register (Default Value: 0x0000\_0812)

| Offset: 0x00E4 |            |             | Register Name: CSC_C21_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:13          | /          | /           | /                          |
| 12.0 P/W       | 0,0013     | C21         |                            |
| 12:0           | R/W        | 0x0812      | Note: must set to 0x0000.  |

#### 5.4.3.22 CSC coefficient 22 register (Default Value: 0x0000\_0000)

| Offset: 0x00E8 |            |             | Register Name: CSC_C22_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:13          | /          | /           | /                          |
| 12.0           | D/M        | 00000       | C22                        |
| 12:0           | R/W        | 0x0000      | Note: must set to 0x0400.  |

#### 5.4.3.23 CSC constant 23 register (Default Value: 0x0000\_2EB1)

|--|



| Bit   | Read/Write | Default/Hex | Description               |
|-------|------------|-------------|---------------------------|
| 31:14 | /          | /           | /                         |
| 13:0  | R/W        | 0x2EB1      | C23                       |
| 13.0  | K/ VV      | UXZEBI      | Note: must set to 0x0000. |

#### 5.4.3.24 DRC spatial coefficient register N (N=0~2) (Default Value: 0x0000\_0000)

| Offset: 0 | k00F0 + N*4 |             | Register Name: DRC_SPACOFF_REGN          |  |
|-----------|-------------|-------------|------------------------------------------|--|
| Bit       | Read/Write  | Default/Hex | Description                              |  |
| 31:24     | /           | /           | /                                        |  |
| 23:16     | D /\A/      | 0.40        | SPA_COEF2                                |  |
| 23.10     | R/W         | 0x0         | 8 bits unsigned spatial coefficient data |  |
| 15.00     | D /\A/      | 0x0         | SPA_COEF1                                |  |
| 15:08 R/W | K/ VV       |             | 8 bits unsigned spatial coefficient data |  |
| 07:00     | R/W         | 0x0         | SPA_COEF0                                |  |
| 07.00     | K/ VV       | UXU         | 8 bits unsigned spatial coefficient data |  |

#### 5.4.3.25 DRC intensity coefficient register N (N=0~63) (Default Value: 0x0000\_0000)

| Offset: 0 | k0100 + N*4 |             | Register Name: DRC_INTCOFF_REGN            |
|-----------|-------------|-------------|--------------------------------------------|
| Bit       | Read/Write  | Default/Hex | Description                                |
| 21.24     | D/M/        | 0.40        | INT_COEF3                                  |
| 31:24     | R/W         | 0x0         | 8 bits unsigned intensity coefficient data |
| 22.16     | D /\A/      | 0.40        | INT_COEF2                                  |
| 23:16     | R/W         | 0x0         | 8 bits unsigned intensity coefficient data |
| 15.00     | 15:08 R/W   | 0.40        | INT_COEF1                                  |
| 15:08     |             | 0x0         | 8 bits unsigned intensity coefficient data |
| 07:00     | R/W         | 0x0         | INT_COEF0                                  |
| 07.00     | r/vv        | UXU         | 8 bits unsigned intensity coefficient data |

#### 5.4.3.26 DRC luminance gain coefficient register N (N=0~127)

| Offset: 0 | k0200 + N*4 |             | Register Name: DRC_LGCOFF_REGN                   |
|-----------|-------------|-------------|--------------------------------------------------|
| Bit       | Read/Write  | Default/Hex | Description                                      |
|           |             |             | LGC_COEF1                                        |
| 31:16     | R/W         | UDF         | 16bits luminance gain coefficient, unsigned data |
| 31.10     | K/VV        | ODF         | The high 5 bits is the integer part              |
|           |             |             | The low 11 bits is the decimal part              |
|           |             |             | LGC_COEF0                                        |
| 15:00     | D /\A/      | UDF         | 16bits luminance gain coefficient, unsigned data |
| 15.00     | R/W         | ODF         | The high 5 bits is the integer part              |
|           |             |             | The low 11 bits is the decimal part              |

Note: Double-buffered registers. When SYNC negative edge comes and COEF\_SWITCH\_EN is 1, coefficient RAM will switch to the latest updated RAM if external RDY\_EN equal to 1.



# 5.5 DE FCC Specification

#### 5.5.1 Overview

Fancy color curvature change (FCC) is to adjust fancy colors so that a better vivid vision effect can be achieved. The FCC has the following features:

- Support RGB888 input and output format
- Support window clipping up to 8192x8192 pixels
- Support local adjustment for hue/ saturation in HSV space
- Support red/green/blue/cyan/magenta/yellow areas modifying in local adjustment mode

# 5.5.2 Register List

| Module name | Memory Range | Offset Address |
|-------------|--------------|----------------|
| FCC         | 8K           | 0xAA000        |

| Register name       | Offset        | Description                         |
|---------------------|---------------|-------------------------------------|
| FCC_CTL_REG         | 0x000         | FCC control register                |
| FCC_INPUT_SIZE_REG  | 0x004         | FCC input size register             |
| FCC_OUTPUT_WINO_REG | 0x008         | FCC output window setting register0 |
| FCC_OUTPUT_WIN1_REG | 0x00c         | FCC output window setting register1 |
| FCC_HUE_RANGE_REG   | 0x010 - 0x024 | FCC hue range register              |
| FCC_LOCAL_GAIN_REG  | 0x030 - 0x044 | FCC local gain register             |
| INCSC_BYPASS_REG    | 0x050         |                                     |
| INCSC_COEFFO_REG    | 0x060 - 0x068 |                                     |
| INCSC_CONSTO_REG    | 0х06с         |                                     |
| INCSC_COEFF1_REG    | 0x070 - 0x078 |                                     |
| INCSC_CONST1_REG    | 0x07c         |                                     |
| INCSC_COEFF2_REG    | 0x080 - 0x088 |                                     |
| INCSC_CONST2_REG    | 0x08c         |                                     |
| GLB_ALPHA_REG       | 0x90          |                                     |

# 5.5.3 Register Description

#### 5.5.3.1 FCC\_CTRL\_REG(Default Value: 0x0000\_0000)

| Offset: 0x000 |            |             | Register Name: FCC_CTL_REG    |
|---------------|------------|-------------|-------------------------------|
| Bit           | Read/Write | Default/Hex | Description                   |
| 31:9          | /          | /           | /                             |
|               |            |             | WIN_EN                        |
| 8             | R/W        | 0x0         | Output window function enable |
|               |            |             | 0: disable                    |



|     |     |     | 1: enable                                                           |
|-----|-----|-----|---------------------------------------------------------------------|
| 7:1 | /   | /   | /                                                                   |
|     |     |     | Enable                                                              |
|     |     |     | Enable control                                                      |
| 0   | R/W | 0x0 | 0:disable                                                           |
|     |     |     | 1:enable                                                            |
|     |     |     | If the bit is disabled, the input data will by-pass to next module. |

# 5.5.3.2 FCC\_INPUT\_SIZE\_REG(Default Value: 0x0000\_0000)

| Offset: 0 | 0x004      |             | Register Name: FCC_INPUT_SIZE_REG                      |
|-----------|------------|-------------|--------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                            |
| 31:29     | /          | /           | 1                                                      |
|           |            |             | HEIGHT                                                 |
| 28:16     | R/W        | 0           | Processing height                                      |
|           |            |             | The real display height = The value of these bits + 1. |
| 15:13     | /          | /           | 1                                                      |
|           |            |             | WIDTH                                                  |
| 12:00     | R/W        | 0           | Processing width                                       |
|           |            |             | The real display width = The value of these bits + 1.  |

# 5.5.3.3 FCC\_OUTPUT\_WIN0\_REG(Default Value: 0x0000\_0000)

| Offset: 0 | 0x008      |             | Register Name: FCC_OUTPUT_WINO_REG                                    |
|-----------|------------|-------------|-----------------------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                                           |
| 31:29     | /          | /           | /                                                                     |
|           |            |             | WIN_TOP                                                               |
| 28:16     | R/W        | 0           | Window Top position                                                   |
|           |            |             | Top position is the left-top y coordinate of display window in pixels |
| 15:13     | /          | /           | /                                                                     |
|           |            |             | WIN_LEFT                                                              |
| 12:00     | R/W        | 0           | Window Left position                                                  |
|           |            |             | Left position is left-top x coordinate of display window in pixels    |

# 5.5.3.4 FCC\_OUTPUT\_WIN1\_REG(Default Value: 0x0000\_0000)

| Offset: | 0x00C      |             | Register Name: FCC_OUTPUT_WIN1_REG                                       |
|---------|------------|-------------|--------------------------------------------------------------------------|
| Bit     | Read/Write | Default/Hex | Description                                                              |
| 31:29   | /          | /           | /                                                                        |
|         |            |             | WIN_BOT                                                                  |
| 28:16   | R/W        | 0           | Window Bottom position                                                   |
|         |            |             | Bottom position is right-bottom y coordinate of display window in pixels |
| 15:12   | /          | /           | /                                                                        |
|         |            |             | WIN_RIGHT                                                                |
| 12:00   | R/W        | 0           | Window Right position                                                    |
|         |            |             | Right position is right-bottom x coordinate of display window in pixels  |



# 5.5.3.5 FCC\_HUE\_RANGE\_REG(Default Value: 0x0000\_0000)

| Offset: |               |             |                                  |
|---------|---------------|-------------|----------------------------------|
| H/R con | nponent: 0x01 | 0           |                                  |
| H/G con | nponent: 0x01 | 4           |                                  |
| H/B con | nponent: 0x01 | 8           | Register Name: FCC_HUE_RANGE_REG |
| H/C con | nponent: 0x01 | С           |                                  |
| H/M co  | mponent: 0x02 | 20          |                                  |
| H/Y con | nponent: 0x02 | 4           |                                  |
| Bit     | Read/Write    | Default/Hex | Description                      |
| 31:28   | /             | /           |                                  |
| 27.16   | D/M           | 2/14/       | HMAX                             |
| 27:16   | R/W           | 0           | the max value of hue             |
| 15:12   | /             | /           |                                  |
| 11.0    | D /\A/        |             | HMIN                             |
| 11:0    | R/W           | 0           | the min value of hue             |

# 5.5.3.6 FCC\_LOCAL\_GAIN\_REG

| Offset:              |               |             |                                                              |
|----------------------|---------------|-------------|--------------------------------------------------------------|
| H/R cor              | mponent: 0x03 | 0           |                                                              |
| H/G co               | mponent: 0x03 | 4           |                                                              |
| H/B component: 0x038 |               |             | Register Name: FCC_LOCAL_HGAIN_REG                           |
| H/C cor              | mponent: 0x03 | С           |                                                              |
| H/M co               | mponent: 0x04 | 10          |                                                              |
| H/Y cor              | mponent: 0x04 | 4           |                                                              |
| Bit                  | Read/Write    | Default/Hex | Description                                                  |
| 31:25                | /             | /           | /                                                            |
| 24.16                | 2/11/         | 0           | HGAIN                                                        |
| 24:16                | R/W           |             | the local gain of hue(Hgain),this is a sign number.          |
| 15:9                 | /             | /           | /                                                            |
| 0.0                  | D/M           | 0           | SGAIN                                                        |
| 8:0                  | R/W           | 0           | the local gain of Saturation (Sgain), this is a sign number. |

#### 5.5.3.7 INCSC\_BYPASS\_REG

| Offset: 0x050              |     |             | Register Name: INCSC_BYPASS_REG |
|----------------------------|-----|-------------|---------------------------------|
| Bit Read/Write Default/Hex |     | Default/Hex | Description                     |
| 31:1                       | /   | /           |                                 |
|                            | R/W | 0x0         | CSC_BYPASS                      |
| 0                          |     |             | CSC bypass                      |
| 0                          |     |             | 0: Bypass                       |
|                            |     |             | 1: Not bypass                   |



#### 5.5.3.8 INCSC\_COEFF0\_REG(Default Value: 0x0000\_0000)

| Offset: C00 component: 0x060 C01 component: 0x064 C02 component: 0x068 |     |             | Register Name: INCSC_COEFF0_REG                       |
|------------------------------------------------------------------------|-----|-------------|-------------------------------------------------------|
| Bit Read/Write Default/Hex                                             |     | Default/Hex | Description                                           |
| 31:13                                                                  | /   | /           | /                                                     |
| 12:0                                                                   | R/W | 0x0         | COEFF The value equals to coefficient*2 <sup>10</sup> |

#### 5.5.3.9 INCSC\_CONSTO\_REG(Default Value: 0x0000\_0000)

| Offset:<br>C03 component: 0x06C |       |             | Register Name: INCSC_CONSTO_REG                 |
|---------------------------------|-------|-------------|-------------------------------------------------|
| Bit Read/Write Default/Hex      |       | Default/Hex | Description                                     |
| 31:20                           | /     | /           | 1                                               |
| 10.0                            | R/W   | 0.40        | CONST                                           |
| 19:0                            | K/ VV | 0x0         | The value equals to coefficient*2 <sup>10</sup> |

#### 5.5.3.10 INCSC\_COEFF1\_REG(Default Value: 0x0000\_0000)

| Offset:                    |                      |             |                                                 |
|----------------------------|----------------------|-------------|-------------------------------------------------|
| C10 component: 0x070       |                      |             | Davistar Names INCCC COFFEA DEC                 |
| C11 component: 0x074       |                      |             | Register Name: INCSC_COEFF1_REG                 |
| C12 com                    | C12 component: 0x078 |             |                                                 |
| Bit Read/Write Default/Hex |                      | Default/Hex | Description                                     |
| 31:13                      | /                    | /           | /                                               |
| 12.0                       | 13.0 P/W 0.0         |             | COEFF                                           |
| 12:0                       | R/W                  | 0x0         | The value equals to coefficient*2 <sup>10</sup> |

#### 5.5.3.11 INCSC\_CONST1\_REG(Default Value: 0x0000\_0000)

| Offset:<br>C13 com | nponent: 0x07              | C   | Register Name: INCSC_CONST1_REG                 |
|--------------------|----------------------------|-----|-------------------------------------------------|
| Bit                | Bit Read/Write Default/Hex |     | Description                                     |
| 31:20              | /                          | /   | /                                               |
| 10.0               | 19:0 R/W                   | 0x0 | CONST                                           |
| 19:0               |                            |     | The value equals to coefficient*2 <sup>10</sup> |

#### 5.5.3.12 INCSC\_COEFF2\_REG(Default Value: 0x0000\_0000)

| Offset:              |                                 |
|----------------------|---------------------------------|
| C20 component: 0x080 | Posistar Nama INCSC COEFF2 REC  |
| C21 component: 0x084 | Register Name: INCSC_COEFF2_REG |
| C22 component: 0x088 |                                 |



| Bit   | Read/Write | Default/Hex | Description                                     |  |
|-------|------------|-------------|-------------------------------------------------|--|
| 31:13 | /          | /           | /                                               |  |
| 12.0  | D /\A/     | 0.40        | COEFF                                           |  |
| 12:0  | R/W        | 0x0         | The value equals to coefficient*2 <sup>10</sup> |  |

# 5.5.3.13 INCSC\_CONST2\_REG(Default Value: 0x0000\_0000)

| Offset:<br>C23 component: 0x08C |                            |     | Register Name: INCSC_CONST2_REG                 |
|---------------------------------|----------------------------|-----|-------------------------------------------------|
| Bit                             | Bit Read/Write Default/Hex |     | Description                                     |
| 31:20                           | /                          | /   | /                                               |
| 19:0                            | R/W                        | 0x0 | CONST                                           |
| 19.0                            | N/ VV                      | UXU | The value equals to coefficient*2 <sup>10</sup> |

#### 5.5.3.14 GLB\_ALPHA\_REG

| Offset: 0x090                          |        |             | Register Name: GLB_ALPHA_REG             |
|----------------------------------------|--------|-------------|------------------------------------------|
| Bit Read/Write Default/Hex Description |        | Description |                                          |
| 31:24                                  | D ()A/ | 055         | GLOBAL ALPHA                             |
| 31:24                                  | R/W    | 0xFF        | The global alpha value for video channel |
| 23:0                                   | /      | /           | 1                                        |



# **5.6 DE FCE Specification**

#### 5.6.1 Overview

The FCE(Fresh and Contrast Enhancement) features:

- Support data format with 8-bit pre channel.
- Support Maximum input frame size 4096×2160
- Interface: Stream-to-stream pixel interface

# 5.6.2 Register List

| Module name | Memory Range | Offset Address |
|-------------|--------------|----------------|
| FCE         | 8K           | 0xA0000        |

| Register name        | Offset    | Description                          |
|----------------------|-----------|--------------------------------------|
| GCTRL_REG            | 0x000     | Control register                     |
| FCE_SIZE_REG         | 0x004     | Size setting register                |
| FCE_WINO_REG         | 0x008     | Window setting register0             |
| FCE_WIN1_REG         | 0x00C     | Window setting register1             |
| LCE_GAIN_REG         | 0x010     | LCE gain setting register            |
| HIST_SUM_REG         | 0x020     | Histogram sum register               |
| HIST_STATUS_REG      | 0x024     | Histogram status register            |
| CE_STATUS_REG        | 0x028     | CE LUT status register               |
| FTC_GAIN_REG         | 0x030     | FTC gain setting register            |
| FCE_INCSC_BYPASS_REG | 0x040     | Input CSC bypass setting register    |
| CE_LUT_REGN          | 0x100+N*4 | CE LUT register N (N=0:63)           |
| HIST_CNT_REGN        | 0x200+N*4 | Histogram count register N (N=0:255) |

# **5.6.3 Register Description**

## **5.6.3.1 GCTRL\_REG**

| Offset: 0x000 |            |             | Register Name: GCTRL_REG                                                      |  |
|---------------|------------|-------------|-------------------------------------------------------------------------------|--|
| Bit           | Read/Write | Default/Hex | Description                                                                   |  |
|               |            |             | WINDOW_EN                                                                     |  |
|               |            |             | LCE/CE/ <del>FTD</del> /FTC window function enable                            |  |
|               |            |             | 0:Disable                                                                     |  |
| 31            | R/W        | 0x0         | 1:Enable                                                                      |  |
|               |            |             | Note: When window function enable, only the area inside the window will be    |  |
|               |            |             | processed. <b>Histogram</b> function will be not effected by window function. |  |
|               |            |             | Note: double-buffered register.                                               |  |



| 30:21         | /              | /              | /                                                                             |
|---------------|----------------|----------------|-------------------------------------------------------------------------------|
|               |                |                | FTC_EN                                                                        |
|               |                |                | FTC function enable                                                           |
| 20            | R/W            | 0x0            | 0: Disable                                                                    |
|               |                |                | 1: Enable                                                                     |
|               |                |                | Note: double-buffered register.                                               |
|               |                |                | FTD_EN                                                                        |
|               |                |                | FTD function enable                                                           |
| <del>19</del> | <del>R/W</del> | <del>0x0</del> | <del>0: Disable</del>                                                         |
|               |                |                | 1: Enable                                                                     |
|               |                |                | Note: double buffered register.                                               |
|               |                |                | LCE_EN                                                                        |
|               |                |                | LCE function enable                                                           |
| 18            | R/W            | 0x0            | 0: Disable                                                                    |
|               |                |                | 1: Enable                                                                     |
|               |                |                | Note: double-buffered register.                                               |
|               |                |                | CE_EN                                                                         |
|               |                |                | CE function enable                                                            |
| 17            | R/W            | 0x0            | 0: Disable                                                                    |
|               |                |                | 1: Enable                                                                     |
|               |                |                | Note: double-buffered register.                                               |
|               |                |                | HIST_EN                                                                       |
|               |                |                | Histogram function enable                                                     |
| 16            | R/W            | 0x0            | 0: Disable                                                                    |
|               |                |                | 1: Enable                                                                     |
|               |                |                | Note: double-buffered register.                                               |
| 15:1          | /              | /              | /                                                                             |
|               |                |                | EN                                                                            |
|               |                |                | FCE module enable                                                             |
| 0             | R/W            | 0x0            | 0: Disable                                                                    |
|               | K/W            | N/ VV UXU      | 1: Enable                                                                     |
|               |                |                | Note: When module disable, the clock of the calculation circuit will be gated |
|               |                |                | automatically.                                                                |

# 5.6.3.2 FCE\_SIZE\_REG

| Offset: 0 | 0x004      |             | Register Name: FCE_SIZE_REG             |
|-----------|------------|-------------|-----------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                             |
| 31:28     | /          | /           | /                                       |
|           |            |             | HEIGHT                                  |
| 27:16     | R/W        | 0x0         | Input height                            |
|           |            |             | The actual height is register value + 1 |
| 15:12     | /          | /           | /                                       |
|           |            |             | WIDTH                                   |
| 11:0      | R/W        | 0x0         | Input width                             |
|           |            |             | The actual width is register value + 1  |



# 5.6.3.3 FCE\_WINO\_REG

| Offset: | 0x008      |             | Register Name: FCE_WIN0_REG                                           |
|---------|------------|-------------|-----------------------------------------------------------------------|
| Bit     | Read/Write | Default/Hex | Description                                                           |
| 31:28   | /          | /           | /                                                                     |
|         |            |             | WIN_TOP                                                               |
| 27:16   | R/W        | 0           | Window Top position                                                   |
|         |            |             | Top position is the left-top y coordinate of display window in pixels |
| 15:12   | /          | /           | /                                                                     |
|         |            |             | WIN_LEFT                                                              |
| 11:0    | R/W        | 0           | Window Left position                                                  |
|         |            |             | Left position is left-top x coordinate of display window in pixels    |

# 5.6.3.4 FCE\_WIN1\_REG

| Offset: | 0x00C      |             | Register Name: FCE_WIN1_REG                                              |
|---------|------------|-------------|--------------------------------------------------------------------------|
| Bit     | Read/Write | Default/Hex | Description                                                              |
| 31:28   | /          | /           | /                                                                        |
|         |            |             | WIN_BOT                                                                  |
| 27:16   | R/W        | 0           | Window Bottom position                                                   |
|         |            |             | Bottom position is right-bottom y coordinate of display window in pixels |
| 15:12   | /          | /           | /                                                                        |
|         |            |             | WIN_RIGHT                                                                |
| 11:0    | R/W        | 0           | Window Right position                                                    |
|         |            |             | Right position is right-bottom x coordinate of display window in pixels  |

# 5.6.3.5 LCE\_GAIN\_REG

| Offset: 0 | )x010      |             | Register Name: LCE_GAIN_REG                   |
|-----------|------------|-------------|-----------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                   |
| 31:16     | /          | /           | /                                             |
|           |            |             | LCE_BLEND                                     |
| 15:8      | R/W        | 0x0         | Blending ratio of C2 and SOURCE               |
|           |            |             | Note: U0.8 format. Range from 0 to (255/256). |
| 7:6       | /          | /           | /                                             |
|           |            |             | LCE_GAIN                                      |
| 5:0       | R/W        | 0x0         | LCE gain                                      |
|           |            |             | Note: U2.4 format. Range from 0 to (63/16).   |

# **5.6.3.6 HIST\_SUM\_REG**

| Offset: 0x020 |            |             | Register Name: HIST_SUM_REG |
|---------------|------------|-------------|-----------------------------|
| Bit           | Read/Write | Default/Hex | Description                 |
| 31:0          | D          | 0.40        | SUM                         |
| 31.0          | r.         | 0x0         | Pixel level sum             |



| Note: Register will clear when reset module. And double-buffered register |
|---------------------------------------------------------------------------|
| refresh when pixel counter equal to WIDTH × HEIGHT.                       |

#### 5.6.3.7 HIST\_STATUS\_REG

| Offset: 0 | 0x024      |             | Register Name: HIST_STATUS_REG                            |
|-----------|------------|-------------|-----------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                               |
| 21.0      | D          | 0.40        | HIST_NUM                                                  |
| 31:8      | R          | 0x0         | Histogram pixel number counter                            |
| 7:2       | /          | /           | /                                                         |
|           |            |             | BIST_EN                                                   |
| 1         | R/W        | 0x0         | BIST enable                                               |
| 1         | r, vv      | UXU         | 0: Disable                                                |
|           |            |             | 1: Enable                                                 |
|           |            | 00          | HIST_CNT_VALID                                            |
| 0         |            |             | 0: AHB access not valid                                   |
| U         | R          | 0x0         | 1: AHB access valid                                       |
|           |            |             | Note: This bit switch to 0 when HIST_CNT_REG are updated. |

# 5.6.3.8 CE\_STATUS\_REG

| Offset: 0x028 |            |             | Register Name: CE_STATUS_REG                                            |
|---------------|------------|-------------|-------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                             |
| 31:1          | /          | /           | /                                                                       |
|               |            |             | CELUT_ACCESS_SWITCH                                                     |
|               |            |             | 0: Module access                                                        |
| 0             | R/W        | 0x0         | 1: AHB access                                                           |
|               |            |             | Note: When module access, CELUT registers can't access through AHB bus. |
|               |            |             | When AHB access, CELUT will return the input address for data output.   |

# 5.6.3.9 FTC\_GAIN\_REG

| Offset: 0x030 |            |             | Register Name: FTC_GAIN_REG |
|---------------|------------|-------------|-----------------------------|
| Bit           | Read/Write | Default/Hex | Description                 |
| 31:24         | /          | /           | /                           |
| 22:16         | R/W        | 0           | FTC_H_GAIN_2                |
| 23:16         | K/ VV      | U           | FTC gain value2             |
| 15:8          | /          | /           | /                           |
| - 0           | D ///      |             | FTC_H_GAIN_1                |
| 7:0           | R/W        | 0           | FTC gain value1             |

# 5.6.3.10 FCE\_INCSC\_BYPASS\_REG

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



|   |       |     | CSC_BYPASS    |
|---|-------|-----|---------------|
| 0 | R/W   | 0x0 | CSC bypass    |
| 0 | r/ vv | UXU | 0: Bypass     |
|   |       |     | 1: Not bypass |

# 5.6.3.11 CE\_LUT\_REGN (N = 0:63)

| Offset: 0 | )x100 + N*4 |             | Register Name: CE_LUT_REGN |
|-----------|-------------|-------------|----------------------------|
| Bit       | Read/Write  | Default/Hex | Description                |
| 31:24     | R/W         | LIDE        | CELUT3                     |
| 31.24     | r, vv       | UDF         | (N*4+3) level LUT          |
| 22.16     | R/W         | UDF         | CELUT2                     |
| 23:16     | K/VV        |             | (N*4+2) level LUT          |
| 15.0      | D/M         | R/W UDF     | CELUT1                     |
| 15:8      | :8   K/W    |             | (N*4+1) level LUT          |
| 7:0       | R/W         | LIDE        | CELUTO                     |
|           |             | R/W UDF     | (N*4) level LUT            |

Note: Registers can access in burst mode.

# 5.6.3.12 HIST\_CNT\_REGN (N = 0:255)

| Offset: 0x200 + N*4 |            |             | Register Name: HIST_CNT_REGN                                            |
|---------------------|------------|-------------|-------------------------------------------------------------------------|
| Bit                 | Read/Write | Default/Hex | Description                                                             |
| 31:22               | /          | /           | 1                                                                       |
|                     |            |             | HIST                                                                    |
|                     |            |             | Level N counter.                                                        |
|                     |            |             | Note:                                                                   |
| 21:0                | R/W        | UDF         | 1.Registers switch to AHB bus access mode when HIST_CNT_VALID = 1. When |
|                     |            |             | HIST_CNT_VALID = 0, accessing registers will return 0x00000000.         |
|                     |            |             | 2.Registers will be clear to zero when LCD SYNC positive edge comes.    |
|                     |            |             | 3.Registers can access in burst mode.                                   |



# 5.7 DE UIS Specification

#### 5.7.1 Overview

UI Scaler(UIS) provides RGB format image resizing function for display engine. It receives data from overlay module, performs the image resizing function, and outputs to routing modules.

The UIS can receive ARGB8888 data format, and then converts to a required size ARGB8888 image for display. Horizontal and vertical direction scaling are implemented independently.

#### The US features:

- Support ARGB8888 data format with 8-bit pre channel.
- Support input and output size from 4x2 to 4096x4096
- Support 1/16x to 32x resize ratio.
- Support 16-phase 4-tap horizontal anti-alias filter, 16-phase linear filter in vertical.
- Point-to-point display size up to **W** pixels/line. (**W** is RTL programmable, default value 2048)

#### 5.7.2 Register List

| Register name      | Offset    | Description                                       |
|--------------------|-----------|---------------------------------------------------|
| UIS_CTRL_REG       | 0x000     | Control register                                  |
| UIS_STATUS_REG     | 0x008     | Status register                                   |
| UIS FIELD_CTRL_REG | 0x00C     | Field control register                            |
| UIS_BIST_REG       | 0x010     | BIST control register                             |
| UIS_OUTSIZE_REG    | 0x040     | Output size register                              |
| UIS_INSIZE_REG     | 0x080     | Input size register                               |
| UIS _HSTEP_REG     | 0x088     | Horizontal step register                          |
| UIS_VSTEP_REG      | 0x08C     | Vertical step register                            |
| UIS_HPHASE_REG     | 0x090     | Horizontal initial phase register                 |
| UIS_VPHASEO_REG    | 0x098     | Vertical initial phase 0 register                 |
| UIS_VPHASE1_REG    | 0x09C     | Vertical initial phase 1 register                 |
| UIS_HCOEF_REGN     | 0x200+N*4 | Horizontal filter coefficient register N (N=0:15) |

**Note:** All registers except some bits in **UIS\_CTRL\_REG**, **UIS\_FIELD\_CTRL\_REG**, **UIS\_STATUS\_REG** are double-buffered refreshed by **REG\_RDY**.

#### **5.7.3 Register Description**

#### 5.7.3.1 UIS\_CTRL\_REG

| Offset: 0x000 |                            |     | Register Name: UIS_CTRL_REG |
|---------------|----------------------------|-----|-----------------------------|
| Bit           | Bit Read/Write Default/Hex |     | Description                 |
| 31            | R/W                        | 0x0 | BIST_EN                     |



|      | ı       |         | Ţ                                                                                        |
|------|---------|---------|------------------------------------------------------------------------------------------|
|      |         |         | BIST enable                                                                              |
|      |         |         | 0: Disable                                                                               |
|      |         |         | 1: Enable                                                                                |
|      |         |         | CORE_RST                                                                                 |
| 30   | R/W     | 0x0     | Core circuit reset                                                                       |
| 30   | I N/ VV | UXU     | 0: Do noting                                                                             |
|      |         |         | 1: Reset core circuit                                                                    |
| 29:5 | /       | /       | /                                                                                        |
|      |         |         | COEF_SWITCH_RDY                                                                          |
|      |         | 0x0     | Coefficients RAM switch                                                                  |
|      |         |         | 0: DONOT switch                                                                          |
| 4    | R/W     |         | 1: Switch RAM use <b>REG_RDY</b>                                                         |
|      |         |         | Note: When LCD SYNC go low and COEF_SWITCH_RDY is 1, coefficient RAM                     |
|      |         |         | will switch to the latest updated RAM if <b>REG_RDY</b> is 1, and then the bit will also |
|      |         |         | be self-cleared if switch action successes.                                              |
| 3:1  | /       | /       | /                                                                                        |
|      |         |         | EN                                                                                       |
|      |         |         | UI Scaler enable                                                                         |
| 0    | D /\A/  | 0.0     | 0: Disable                                                                               |
| 0    | K/ VV   | R/W 0x0 | 1: Enable                                                                                |
|      |         |         | Note: When module disabled, the core clock to the core circuit will be gated, and        |
|      |         |         | the input data will be bypassed to down-stream module.                                   |
|      |         | •       |                                                                                          |

**Note:** Only bit **EN** is double-buffered.

# 5.7.3.2 UIS\_STATUS\_REG

| Offset: 0 | x008       |             | Register Name: UIS_STATUS_REG                                        |
|-----------|------------|-------------|----------------------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                                          |
| 31:28     | /          | /           | /                                                                    |
| 27.16     | В          | 0.40        | LINE_CNT                                                             |
| 27:16     | R          | 0x0         | Output line number                                                   |
| 15:5      | /          | /           | /                                                                    |
|           | R          | R 0x0       | BUSY                                                                 |
| 4         |            |             | Core circuit status                                                  |
| 4         |            |             | 0: idle (finish, module disable, waiting for LCD SYNC negative edge) |
|           |            |             | 1: busy (core circuit calculating)                                   |
| 3:0       | /          | /           | /                                                                    |

**Note:** Whole WORD is non-double-buffered.

#### 5.7.3.3 UIS\_FIELD\_CTRL\_REG

| Offset: 0x00C |            |             | Register Name: UIS_FIELD_CTRL_REG |
|---------------|------------|-------------|-----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                       |
| 31:6          | /          | /           | /                                 |
|               |            |             | LCD_SYNC_REVERSE                  |
| _             | R/W        | 0v0         | Reverse LCD SYNC                  |
| 5             | K/ VV      | 0x0         | 0: DONOT reverse                  |
|               |            |             | 1: Reverse                        |



|     | R/W     | 0x0     | LCD_FILED_REVERSE                                                                 |
|-----|---------|---------|-----------------------------------------------------------------------------------|
| 4   |         |         | Reverse LCD FILED                                                                 |
| 4   | I NY VV |         | 0: DONOT reverse                                                                  |
|     |         |         | 1: Reverse                                                                        |
| 3:1 | /       | /       | /                                                                                 |
|     | R/W     | R/W 0x0 | FIELD_SEL_VPHASE_EN                                                               |
|     |         |         | Vertical initial phase switch control                                             |
| 0   |         |         | 0: Vertical initial phase fix to phase0                                           |
|     |         |         | 1: Switch Vertical initial phase by LCD FIELD (Switch to phase0 when LCD FILED is |
|     |         |         | 1, and switch to phase1 when LCD FIELD is 0)                                      |

Note: Only bit FIELD\_SEL\_VPHASE\_EN is double-buffered.

#### 5.7.3.4 UIS\_BIST\_REG

| Offset: 0x010 |                  |             | Register Name: UIS_BIST_REG      |
|---------------|------------------|-------------|----------------------------------|
| Bit           | Read/Write       | Default/Hex | Description                      |
| 31:21         | /                | /           | /                                |
| 20.16         | 20:16 W          | 0x0         | BIST_RAM_SEL                     |
| 20:16         |                  |             | Select the index of RAM for BIST |
| 15:1          | /                | /           | /                                |
|               |                  | W 0x0       | BIST_EN                          |
| 0             | <b>\ \ \ \ \</b> |             | BIST enable                      |
| U             | VV               |             | 0: Disable                       |
|               |                  |             |                                  |

Note: Whole WORD is non-double-buffered.

#### 5.7.3.5 UIS\_OUTSIZE\_REG

| Offset: 0 | )x040      |             | Register Name: UIS_OUTSIZE_REG          |
|-----------|------------|-------------|-----------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                             |
| 31:29     | /          | /           | /                                       |
|           |            |             | OUT_HEIGHT                              |
| 28:16     | R/W        | 0x0         | Output height                           |
|           |            |             | The actual height is register value + 1 |
| 15:13     | /          | /           | /                                       |
|           |            |             | OUT_WIDTH                               |
| 12:0      | R/W        | 0x0         | Output width                            |
|           |            |             | The actual width is register value + 1  |

#### 5.7.3.6 UIS\_INSIZE\_REG

| Offset: 0x080 |            |             | Register Name: UIS_INSIZE_REG           |
|---------------|------------|-------------|-----------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                             |
| 31:29         | /          | /           | /                                       |
|               |            |             | IN_HEIGHT                               |
| 28:16         | R/W        | 0x0         | Input height                            |
|               |            |             | The actual height is register value + 1 |
| 15:13         | /          | /           | /                                       |



|      |     |     | IN_WIDTH                               |
|------|-----|-----|----------------------------------------|
| 12:0 | R/W | 0x0 | Input width                            |
|      |     |     | The actual width is register value + 1 |

## 5.7.3.7 UIS\_HSTEP\_REG

| Offset: 0 | )x088      |             | Register Name: UIS_HSTEP_REG                |  |
|-----------|------------|-------------|---------------------------------------------|--|
| Bit       | Read/Write | Default/Hex | Description                                 |  |
| 31:25     | /          | /           | /                                           |  |
| 24.20     | R/W        | 0x0         | HSTEP_INT                                   |  |
| 24:20     |            |             | The integer part of horizontal scale ratio  |  |
| 10.2      | D //A/     | 00          | HSTEP_FRAC                                  |  |
| 19:2      | R/W        | 0x0         | The fraction part of horizontal scale ratio |  |
| 1:0       | /          | /           | /                                           |  |

#### 5.7.3.8 UIS\_VSTEP\_REG

| Offset: 0 | )x08C      |             | Register Name: UIS_VSTEP_REG              |  |
|-----------|------------|-------------|-------------------------------------------|--|
| Bit       | Read/Write | Default/Hex | Description                               |  |
| 31:25     | /          | /           | 1                                         |  |
| 24.20     | R/W        | 0x0         | VSTEP_INT                                 |  |
| 24:20     |            |             | The integer part of vertical scale ratio  |  |
| 10.2      | D /\A/     | 0.40        | VSTEP_FRAC                                |  |
| 19:2      | R/W        | 0x0         | The fraction part of vertical scale ratio |  |
| 1:0       | /          | /           | /                                         |  |

#### 5.7.3.9 UIS\_HPHASE\_REG

| Offset: 0x090 |            |             | Register Name: UIS_HPHASE_REG                 |
|---------------|------------|-------------|-----------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                   |
| 31:24         | /          | /           | /                                             |
| 23:20         | R/W        | 0x0         | HPHASE_INT                                    |
|               |            |             | The integer part of horizontal initial phase  |
| 10.2          | D /\A/     | 0.40        | HPHASE_FRAC                                   |
| 19:2          | R/W        | 0x0         | The fraction part of horizontal initial phase |
| 1:0           | /          | /           | 1                                             |

**Note:** *HPHASE* is a SIGNED parameter.

# 5.7.3.10 UIS\_VPHASEO\_REG

| Offset: 0x098 |            |             | Register Name: UIS_VPHASE0_REG               |  |  |
|---------------|------------|-------------|----------------------------------------------|--|--|
| Bit           | Read/Write | Default/Hex | Description                                  |  |  |
| 31:24         | /          | /           | 1                                            |  |  |
| 22.20         | R/W        | 0x0         | VPHASEO_INT                                  |  |  |
| 23:20         |            |             | The integer part of vertical initial phase0  |  |  |
| 19:2          | R/W        | 0x0         | VPHASEO_FRAC                                 |  |  |
|               |            |             | The fraction part of vertical initial phase0 |  |  |



| 1:0 | / | / | / |
|-----|---|---|---|
|-----|---|---|---|

Note: VPHASEO is a SIGNED parameter.

#### 5.7.3.11 UIS\_VPHASE1\_REG

| Offset: 0x09C |            |             | Register Name: UIS_VPHASE1_REG               |  |  |
|---------------|------------|-------------|----------------------------------------------|--|--|
| Bit           | Read/Write | Default/Hex | Description                                  |  |  |
| 31:24         | /          | /           | /                                            |  |  |
| 23:20         | R/W        | 0x0         | VPHASE1_INT                                  |  |  |
|               |            |             | The integer part of vertical initial phase1  |  |  |
| 10.2          | D /\A/     | 00          | VPHASE1_FRAC                                 |  |  |
| 19:2          | R/W        | 0x0         | The fraction part of vertical initial phase1 |  |  |
| 1:0           | /          | /           | /                                            |  |  |

**Note:** *VPHASE1* is a SIGNED parameter.

#### 5.7.3.12 **UIS\_HCOEF\_REGN (N = 0:15)**

| Offset: 0 | 0x200 + N*4 |             | Register Name: UIS_HCOEF_REGN              |  |
|-----------|-------------|-------------|--------------------------------------------|--|
| Bit       | Read/Write  | Default/Hex | Description                                |  |
| 21.24     | 24.24       | 0x0         | COEF3                                      |  |
| 31:24     | R/W         |             | The most right hand-side pixel coefficient |  |
| 22:16     | D /\A/      | 0.40        | COEF2                                      |  |
| 23:16     | R/W         | 0x0         | The right hand-side pixel coefficient      |  |
| 15.0      | D /\A/      | 0x0         | COEF1                                      |  |
| 15:8      | R/W         |             | The left hand-side pixel coefficient       |  |
| 7.0       | R/W         | 0.40        | COEF0                                      |  |
| 7:0       |             | /W 0x0      | The most left hand-side pixel coefficient  |  |

**Note:** HCOEFF is a two's complement. The register value equals to coefficient\*2<sup>6</sup>. **N** represents the phase.



# 5.8 DE LTI Specification

#### 5.8.1 Overview

Luminance transient improvement (DLTI) is a method to enhance the image quality. The method of the luminance signal transition bands were detected, when the luminance signal transition, so that the signal transition zone is narrow, steep edge, so as to improve the clarity of the image, the image is more clear and bright.

This algorithm uses the one-dimensional stacking hook signal method commonly used, through a hook signal superimposed on the input signal, the signal edge becomes steeper, and then calculate the signal of a window within the scope of the maximum and minimum values, will limit the signal after superposition in the minimum and maximum range, to get the final results. Sketch of the algorithm is as follows:



#### **5.8.2 Register List**

| Module name | Memory Range | Offset Address |
|-------------|--------------|----------------|
| LTI         | 8K           | 0xA4000        |

| Register name     | Offset | Description                                         |
|-------------------|--------|-----------------------------------------------------|
| LTI_EN            | 0x000  | Global control register                             |
| LTI_SIZE          | 0x00C  | LTI size register                                   |
| LTI_FIR_COFF0     | 0x010  | LTI FIR filter coefficient register0                |
| LTI_FIR_COFF1     | 0x014  | LTI FIR filter coefficient register1                |
| LTI_FIR_COFF2     | 0x018  | LTI FIR filter coefficient register2                |
| LTI_FIR_GAIN      | 0x01C  | LTI FIR filter gain register                        |
| LTI_COR_TH        | 0x020  | LTI coring threshold register                       |
| LTI_DIFF_CTL      | 0x024  | LTI scaling coefficient/offset of frist derivation  |
| LTI_EDGE_GAIN     | 0x028  | LTI edge gain                                       |
| LTI_OS_CON        | 0x02C  | LTI coring/clipping threshold of Y shoot value      |
| LTI_WIN_EXPANSION | 0x030  | LTI window range control register                   |
| LTI_EDGE_LEVEL_TH | 0x034  | LTI edge level threshold in edge-adaptive filtering |
| LTI_WINO_REG      | 0x038  | LTI window setting register0                        |



| LTI_WIN1_REG          | 0x03c               | LTI window setting register1          |
|-----------------------|---------------------|---------------------------------------|
| LTI_INCSC_BYPASS_REG  | 0x050               | Input CSC bypass setting register     |
| LTI_INCSC_COEFF0_REG  | 0x060, 0x064, 0x068 | Input CSC CH0 coefficients registers  |
| LTI_INCSC_CONSTO_REG  | 0x06C               | Input CSC CH0 constant register       |
| LTI_INCSC_COEFF1_REG  | 0x070, 0x074, 0x078 | Input CSC CH1 coefficients registers  |
| LTI_INCSC_CONST1_REG  | 0x07C               | Input CSC CH1 constant register       |
| LTI_INCSC_COEFF2_REG  | 0x080, 0x084, 0x088 | Input CSC CH2 coefficients registers  |
| LTI_INCSC_CONST2_REG  | 0x08C               | Input CSC CH2 constant register       |
| LTI_OUTCSC_BYPASS_REG | 0x090               | Output CSC bypass setting register    |
| LTI_OUTCSC_COEFFO_REG | 0x0A0, 0x0A4, 0x0A8 | Output CSC CH0 coefficients registers |
| LTI_OUTCSC_CONSTO_REG | 0x0AC               | Output CSC CH0 constant register      |
| LTI_OUTCSC_COEFF1_REG | 0x0B0, 0x0B4, 0x0B8 | Output CSC CH1 coefficients registers |
| LTI_OUTCSC_CONST1_REG | 0x0BC               | Output CSC CH1 constant register      |
| LTI_OUTCSC_COEFF2_REG | 0x0C0, 0x0C4, 0x0C8 | Output CSC CH2 coefficients registers |
| LTI_OUTCSC_CONST2_REG | 0x0CC               | Output CSC CH2 constant register      |

# **5.8.3 Register Description**

# 5.8.3.1 Global control register

| Offset: 0x000 |            |             | Register Name: LTI_CTL |
|---------------|------------|-------------|------------------------|
| Bit           | Read/Write | Default/Hex | Description            |
| 31:25         | /          | /           | Reserved               |
|               |            |             | WIN_EN                 |
| 24            | R/W        | 0x0         | 0: disable             |
|               |            |             | 1: enable              |
| 23:17         | /          | /           |                        |
|               |            |             | NONLINEAR_LIMIT_EN     |
| 16            | R/W        | 0x0         | 0: disable             |
|               |            |             | 1: enable              |
| 15:9          | /          | /           |                        |
|               |            |             | SEL                    |
| 8             | R/W        | 0x0         | 0: select window range |
|               |            |             | 1: select first differ |
| 7:1           | /          | /           | 1                      |
|               |            |             | LTI_EN                 |
| 0             | R/W        | 0x0         | 0: LTI close           |
|               |            |             | 1: LTI open            |

# 5.8.3.2 LTI size register

| Offset: 0x00C |            |             | Register Name: LTI_SIZE |
|---------------|------------|-------------|-------------------------|
| Bit           | Read/Write | Default/Hex | Description             |
| 31:28         | /          | /           | Reserved                |
| 27:16         | R/W        | 0x0         | HEIGHT                  |



|       |        |        | The real height = The value of these bits add 1 |
|-------|--------|--------|-------------------------------------------------|
| 15:12 | /      | /      | /                                               |
| 11.0  | D /\A/ | 0.0    | WIDTH                                           |
| 11:0  | R/W    | /W 0x0 | The real width = The value of these bits add 1  |

# 5.8.3.3 LTI FIR filter coefficient register0

| Offset: 0 | k010       |             | Register Name: LTI_FIR_COFF0 |
|-----------|------------|-------------|------------------------------|
| Bit       | Read/Write | Default/Hex | Description                  |
| 31:24     | /          | /           | /                            |
|           |            |             | C1                           |
| 23:16     | R/W        | 0x0         | FIR filter coefficient C1    |
|           |            |             | Note: in two's complement.   |
| 15:8      | /          | /           | /                            |
|           |            |             | CO                           |
| 7:0       | R/W        | 0x0         | FIR filter coefficient CO    |
|           |            |             | Note: in two's complement.   |

# 5.8.3.4 LTI FIR filter coefficient register1

| Offset: 0 | x014       |             | Register Name: LTI_FIR_COFF1 |
|-----------|------------|-------------|------------------------------|
| Bit       | Read/Write | Default/Hex | Description                  |
| 31:24     | /          | /           | /                            |
|           |            |             | С3                           |
| 23:16     | R/W        | 0x0         | FIR filter coefficient C3    |
|           |            |             | Note: in two's complement.   |
| 15:8      | /          | /           | /                            |
|           |            |             | C2                           |
| 7:0       | R/W        | 0x0         | FIR filter coefficient C2    |
|           |            |             | Note: in two's complement.   |

# 5.8.3.5 LTI FIR filter coefficient register2

| Offset: 0x018 |            |             | Register Name: LTI_FIR_COFF2 |
|---------------|------------|-------------|------------------------------|
| Bit           | Read/Write | Default/Hex | Description                  |
| 31:8          | /          | /           | /                            |
|               |            |             | C4                           |
| 7:0           | R/W        | 0x0         | FIR filter coefficient C4    |
|               |            |             | Note: in two's complement.   |

# 5.8.3.6 LTI FIR filter gain register

| Offset: 0x01C |            |             | Register Name: LTI_FIR_GAIN |
|---------------|------------|-------------|-----------------------------|
| Bit           | Read/Write | Default/Hex | Description                 |
| 31:4          | /          | /           | /                           |
| 3:0           | R/W        | 0x0         | FIR FILTER GAIN             |



# 5.8.3.7 LTI coring threshold register

| Offset: 0x020 |            |             | Register Name: LTI_COR_TH |
|---------------|------------|-------------|---------------------------|
| Bit           | Read/Write | Default/Hex | Description               |
| 31:10         | /          | /           | /                         |
| 0.0           | R/W        | 0x0         | LTI_COR_TH                |
| 9:0           |            |             | Coring threshold          |

### 5.8.3.8 LTI differ filter control register

| Offset: 0x024 |            |             | Register Name: LTI_DIFF_CTL |
|---------------|------------|-------------|-----------------------------|
| Bit           | Read/Write | Default/Hex | Description                 |
| 31:21         | /          | /           | /                           |
| 20.16         | R/W        | 0x0         | DIFF_SLOPE                  |
| 20:16         |            |             | Differ gain slope control   |
| 15:8          | /          | /           | /                           |
| 7:0           | R/W        | 0x0         | DIFF_OFFSET                 |
|               |            |             | Differ gain offset control  |

# 5.8.3.9 LTI adjustable gain parameter register

| Offset: 0x028 |            |             | Register Name: LTI_EDGE_GAIN                  |
|---------------|------------|-------------|-----------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                   |
| 31:5          | /          | /           | /                                             |
| 4:0           | R/W        | 0x0         | LTI_EDGE_GAIN  Edge adjustable gain parameter |

### 5.8.3.10 LTI The overshoot of control register

| Offset: 0x02C |            |             | Register Name:LTI_OS_CON            |
|---------------|------------|-------------|-------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                         |
| 31            | /          | /           | /                                   |
| 30:28         | D /\A/     | 0.0         | PEAK_LIMIT                          |
| 30.28         | R/W        | 0x0         | Shifting bit for nonlinear limit    |
| 27:24         | /          | /           |                                     |
| 23:16         | D ()A/     | 0x0         | CLIP_Y                              |
| 23.10         | R/W        |             | Clipping threshold of Y shoot value |
| 15:8          | /          | /           | /                                   |
| 7:0           | R/W        | V 0x0       | CORE_X                              |
|               |            |             | Coring threshold of Y shoot value   |

# 5.8.3.11 LTI window range expansion register

| Offset: 0x030 |            |             | Register Name: LTI_WIN_EXPANSION |
|---------------|------------|-------------|----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                      |



| 31:8 | /      | /    | /                     |
|------|--------|------|-----------------------|
| 7:0  | D /\A/ | 0.40 | LTI_WIN_EXPANSION     |
| 7.0  | R/W    | 0x0  | Window expansion size |

# 5.8.3.12 LTI edge strength threshold register

| Offset: 0x034 |            |             | Register Name: LTI_EDGE_ELVEL_TH                |
|---------------|------------|-------------|-------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                     |
| 31:8          | /          | /           | /                                               |
| 7:0           | R/W        | 0x0         | LTI_EDGE_ELVEL_TH                               |
|               |            |             | Edge level threshold in edge-adaptive filtering |

# 5.8.3.13 LTI\_WINO\_REG

| Offset: 0 | x038       |             | Register Name: LTI_EDGE_ELVEL_TH |
|-----------|------------|-------------|----------------------------------|
| Bit       | Read/Write | Default/Hex | Description                      |
| 31:8      | /          | /           | /                                |
| 27:16     | R/W        | 0X0         | WIN_TOP Window Top position      |
| 15:12     | /          | /           | /                                |
| 11:0      | R/W        | 0x0         | LTI_LEFT Window Left position    |

# 5.8.3.14 LTI\_WIN1\_REG

| Offset: 0x03c |            |             | Register Name: LTI_EDGE_ELVEL_TH |
|---------------|------------|-------------|----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                      |
| 31:8          | /          | /           | /                                |
| 27:16         | R/W        | 0X0         | WIN_BOT                          |
| 27.10         |            |             | Window bottom position           |
| 15:12         | /          | /           | /                                |
| 11:0          | R/W        | 0x0         | LTI_WIGHT                        |
|               |            |             | Window wright position           |

#### 5.8.3.15 LTI\_INCSC\_BYPASS\_REG

| Offset: 0x50 |            |             | Register Name: LTI_INCSC_BYPASS_REG |
|--------------|------------|-------------|-------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                         |
| 31:1         | /          | /           | 1                                   |
|              | R/W        | 0x0         | CSC_BYPASS                          |
| 0            |            |             | CSC bypass                          |
| 0            |            |             | 0: Bypass                           |
|              |            |             | 1: Not bypass                       |



### 5.8.3.16 LTI\_INCSC\_COEFFO\_REG

| Offset: |              |             | Register Name: LTI_INCSC_COEFF0_REG             |
|---------|--------------|-------------|-------------------------------------------------|
| C00 com | ponent: 0x60 |             |                                                 |
| C01 com | ponent: 0x64 |             |                                                 |
| C02 com | ponent: 0x68 |             |                                                 |
| Bit     | Read/Write   | Default/Hex | Description                                     |
| 31:13   | /            | /           | /                                               |
| 12:0    | R/W          | N 0x0       | COEFF                                           |
|         |              |             | The value equals to coefficient*2 <sup>10</sup> |

# 5.8.3.17 LTI\_INCSC\_CONSTO\_REG

| Offset: 0x6C |            |             | Register Name: LTI_INCSC_CONSTO_REG                    |
|--------------|------------|-------------|--------------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                            |
| 31:20        | /          | /           | /                                                      |
| 19:0         | R/W        | 0x0         | CONST  The value equals to coefficient*2 <sup>10</sup> |

# 5.8.3.18 LTI\_INCSC\_COEFF1\_REG

| Offset: |               |             | Register Name: LTI_INCSC_COEFF1_REG             |
|---------|---------------|-------------|-------------------------------------------------|
| C10 com | nponent: 0x70 |             |                                                 |
| C11 com | ponent: 0x74  |             |                                                 |
| C12 com | nponent: 0x78 |             |                                                 |
| Bit     | Read/Write    | Default/Hex | Description                                     |
| 31:13   | /             | /           | /                                               |
| 12:0    | R/W           | W 0x0       | COEFF                                           |
|         |               |             | The value equals to coefficient*2 <sup>10</sup> |

### 5.8.3.19 LTI\_INCSC\_CONST1\_REG

| Offset: ( | x7C        |             | Register Name: LTI_INCSC_CONST1_REG             |
|-----------|------------|-------------|-------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                     |
| 31:20     | /          | /           | /                                               |
| 19:0      | R/W        | 0x0         | CONST                                           |
| 19.0      | 11,7 VV    | 0.00        | The value equals to coefficient*2 <sup>10</sup> |

### 5.8.3.20 LTI\_INCSC\_COEFF2\_REG

| Offset: |                            |   | Register Name: LTI_INCSC_COEFF2_REG |
|---------|----------------------------|---|-------------------------------------|
| C20 com | ponent: 0x80               |   |                                     |
| C21 com | ponent: 0x84               |   |                                     |
| C22 com | ponent: 0x88               |   |                                     |
| Bit     | Bit Read/Write Default/Hex |   | Description                         |
| 31:13   | /                          | / | /                                   |



| 12.0 | D /// | 0.40 | COEFF                                           |
|------|-------|------|-------------------------------------------------|
| 12:0 | R/W   | 0x0  | The value equals to coefficient*2 <sup>10</sup> |

### 5.8.3.21 LTI\_INCSC\_CONST2\_REG

| Offset: 0x8C |            |             | Register Name: LTI_INCSC_CONST2_REG             |
|--------------|------------|-------------|-------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                     |
| 31:20        | /          | /           | 1                                               |
| 19:0         | R/W        | 0x0         | CONST                                           |
|              |            |             | The value equals to coefficient*2 <sup>10</sup> |

### 5.8.3.22 LTI\_OUTCSC\_BYPASS\_REG

| Offset: 0x90 |            |             | Register Name: LTI_OUTCSC_BYPASS_REG |
|--------------|------------|-------------|--------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                          |
| 31:1         | /          | /           | /                                    |
|              | R/W        | 0x0         | CSC_BYPASS                           |
| 0            |            |             | CSC bypass                           |
| U            |            |             | 0: Bypass                            |
|              |            |             | 1: Not bypass                        |

# 5.8.3.23 LTI\_OUTCSC\_COEFFO\_REG

| Offset: |               |             | Register Name: LTI_OUTCSC_COEFF0_REG            |
|---------|---------------|-------------|-------------------------------------------------|
| C00 com | nponent: 0xA0 |             |                                                 |
| C01 com | nponent: 0xA4 |             |                                                 |
| C02 com | ponent: 0xA8  |             |                                                 |
| Bit     | Read/Write    | Default/Hex | Description                                     |
| 31:13   | /             | /           | /                                               |
| 12.0    | D //A/        | 00          | COEFF                                           |
| 12:0    | K/VV          | R/W 0x0     | The value equals to coefficient*2 <sup>10</sup> |

# 5.8.3.24 LTI\_OUTCSC\_CONSTO\_REG

| Offset: 0xAC                   |        |             | Register Name: LTI_OUTCSC_CONST0_REG            |
|--------------------------------|--------|-------------|-------------------------------------------------|
| Bit Read/Write Default/Hex Def |        | Default/Hex | Description                                     |
| 31:20                          | /      | /           | /                                               |
| 19:0 R/W                       | D /\A/ | CONST       | CONST                                           |
|                                | K/VV   | 0x0         | The value equals to coefficient*2 <sup>10</sup> |

#### 5.8.3.25 LTI\_OUTCSC\_COEFF1\_REG

| Offset:             | Offset:    |             |                                      |
|---------------------|------------|-------------|--------------------------------------|
| C10 component: 0xB0 |            |             | Register Name: LTI_OUTCSC_COEFF1_REG |
| C11 component: 0xB4 |            |             |                                      |
| C12 component: 0xB8 |            |             |                                      |
| Bit                 | Read/Write | Default/Hex | Description                          |



| 31:13 | /   | /   | 1                                                     |
|-------|-----|-----|-------------------------------------------------------|
| 12:0  | R/W | 0x0 | COEFF The value equals to coefficient*2 <sup>10</sup> |

# 5.8.3.26 LTI\_OUTCSC\_CONST1\_REG

| Offset: (                  | )xBC |             | Register Name: LTI_OUTCSC_CONST1_REG            |
|----------------------------|------|-------------|-------------------------------------------------|
| Bit Read/Write Default/Hex |      | Default/Hex | Description                                     |
| 31:20                      | /    | /           | 1                                               |
| 19:0                       | R/W  | 0x0         | CONST                                           |
| 19:0                       | K/VV | UXU         | The value equals to coefficient*2 <sup>10</sup> |

# 5.8.3.27 LTI\_OUTCSC\_COEFF2\_REG

| Offset: C20 component: 0xC0 C21 component: 0xC4 C22 component: 0xC8 |     |             | Register Name: LTI_OUTCSC_COEFF2_REG                  |
|---------------------------------------------------------------------|-----|-------------|-------------------------------------------------------|
| Bit Read/Write Default/Hex                                          |     | Default/Hex | Description                                           |
| 31:13                                                               | /   | /           | /                                                     |
| 12:0                                                                | R/W | 0x0         | COEFF The value equals to coefficient*2 <sup>10</sup> |

# 5.8.3.28 LTI\_OUTCSC\_CONST2\_REG

| Offset: 0xCC |            |             | Register Name: LTI_OUTCSC_CONST2_REG            |  |
|--------------|------------|-------------|-------------------------------------------------|--|
| Bit          | Read/Write | Default/Hex | Description                                     |  |
| 31:20        | /          | /           | 1                                               |  |
| 19:0         | R/W        | 0x0         | CONST                                           |  |
| 19.0         | N/ VV      | UXU         | The value equals to coefficient*2 <sup>10</sup> |  |



# **5.9 DE Peaking Specification**

#### 5.9.1 Overview

The Luma Peaking module enhances mid-high frequence of luma channel in images. The chroma channels will bypass.

The Luma Peaking module including following feature:

- Maximum input frame size: 4096×2160.
- Data width: 8bit /10bit(hardware programmable) per channel.
- Interface: Stream-to-stream pixel interface.

#### 5.9.2 Block Diagram

Figure 5-1 shows the block diagram of luma peaking module. It is a stream-to-stream module with uniform input and output interface. It contains some parts and their function list followed:

- Control logic: Status machine control, registers operation.
- Peaking calculation unit: luma peaking, chroma bypassing.
- MUX: select processed data or input data (input data pass-through works without clock)



Figure 5-1. Luma peaking module block diagram



# 5.9.3 Register list

| Module name | Memory Range | Offset Address |
|-------------|--------------|----------------|
| PEAKING     | 8K           | 0xA6000        |

| Register Name        | Offset              | Description                           |
|----------------------|---------------------|---------------------------------------|
| LP_CTRL_REG          | 0x000               | LP module control register            |
| LP_SIZE_REG          | 0x004               | LP size setting register              |
| LP_WINO_REG          | 0x008               | LP window setting register0           |
| LP_WIN1_REG          | 0x00C               | LP window setting register1           |
| LP_FILTER_REG        | 0x010               | LP filter setting register            |
| LP_CSTM_FILTERO_REG  | 0x014               | LP custom filter setting register0    |
| LP_CSTM_FILTER1_REG  | 0x018               | LP custom filter setting register1    |
| LP_CSTM_FILTER2_REG  | 0x01C               | LP custom filter setting register2    |
| LP_GAIN_REG          | 0x020               | LP gain setting register              |
| LP_GAINCTRL_REG      | 0x024               | LP gain control setting register      |
| LP_SHOOTCTRL_REG     | 0x028               | LP shoot control setting register     |
| LP_CORING_REG        | 0x02C               | LP coring setting register            |
| LP_INCSC_BYPASS_REG  | 0x050               | Input CSC bypass setting register     |
| LP_INCSC_COEFFO_REG  | 0x060, 0x064, 0x068 | Input CSC CH0 coefficients registers  |
| LP_INCSC_CONSTO_REG  | 0x06C               | Input CSC CH0 constant register       |
| LP_INCSC_COEFF1_REG  | 0x070, 0x074, 0x078 | Input CSC CH1 coefficients registers  |
| LP_INCSC_CONST1_REG  | 0x07C               | Input CSC CH1 constant register       |
| LP_INCSC_COEFF2_REG  | 0x080, 0x084, 0x088 | Input CSC CH2 coefficients registers  |
| LP_INCSC_CONST2_REG  | 0x08C               | Input CSC CH2 constant register       |
| LP_OUTCSC_BYPASS_REG | 0x090               | Output CSC bypass setting register    |
| LP_OUTCSC_COEFF0_REG | 0x0A0, 0x0A4, 0x0A8 | Output CSC CHO coefficients registers |
| LP_OUTCSC_CONSTO_REG | 0x0AC               | Output CSC CH0 constant register      |
| LP_OUTCSC_COEFF1_REG | 0x0B0, 0x0B4, 0x0B8 | Output CSC CH1 coefficients registers |
| LP_OUTCSC_CONST1_REG | 0x0BC               | Output CSC CH1 constant register      |
| LP_OUTCSC_COEFF2_REG | 0x0C0, 0x0C4, 0x0C8 | Output CSC CH2 coefficients registers |
| LP_OUTCSC_CONST2_REG | 0x0CC               | Output CSC CH2 constant register      |

# **5.9.4 Register Description**

# **5.9.4.1 LP\_CTRL\_REG**

| Offset: 0x00 |            |             | Register name: LP_CTRL_REG    |
|--------------|------------|-------------|-------------------------------|
| Bit          | Read/Write | Default/Hex | Description                   |
| 31:9         | /          | /           | /                             |
|              |            |             | WIN_EN                        |
| 8            | R/W        | 0x0         | Output window function enable |
|              |            |             | 0: disable                    |



|     |      |      | 1: enable        |
|-----|------|------|------------------|
| 7:1 | /    | /    | /                |
| 0   |      |      | EN               |
|     | R/W  | 0.40 | LP Module enable |
|     | K/VV | 0x0  | 0: Disable       |
|     |      |      | 1: Enable        |

# **5.9.4.2 LP\_SIZE\_REG**

| Offset: ( | )x04       |             | Register name: LP_SIZE_REG                             |  |
|-----------|------------|-------------|--------------------------------------------------------|--|
| Bit       | Read/Write | Default/Hex | Description                                            |  |
| 31:28     | /          | /           | /                                                      |  |
|           |            |             | HEIGHT                                                 |  |
| 27:16     | R/W        | 0           | Processing height                                      |  |
|           |            |             | The real display height = The value of these bits + 1. |  |
| 15:12     | /          | /           |                                                        |  |
|           |            |             | WIDTH                                                  |  |
| 11:00     | R/W        | 0           | Processing width                                       |  |
|           |            |             | The real display width = The value of these bits + 1.  |  |

# 5.9.4.3 LP\_WINO\_REG

| Offset: ( | 0x08       |             | Register name: LP_WINO_REG                                            |  |
|-----------|------------|-------------|-----------------------------------------------------------------------|--|
| Bit       | Read/Write | Default/Hex | Description                                                           |  |
| 31:28     | /          | /           | /                                                                     |  |
|           |            |             | WIN_TOP                                                               |  |
| 27:16     | R/W        | 0           | Window Top position                                                   |  |
|           |            |             | Top position is the left-top y coordinate of display window in pixels |  |
| 15:12     | /          | /           |                                                                       |  |
|           |            |             | WIN_LEFT                                                              |  |
| 11:00     | R/W        | 0           | Window Left position                                                  |  |
|           |            |             | Left position is left-top x coordinate of display window in pixels    |  |

### 5.9.4.4 LP\_WIN1\_REG

| Offset: ( | 0x0C       |             | Register name: LP_WIN1_REG                                               |
|-----------|------------|-------------|--------------------------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                                              |
| 31:28     | /          | /           | /                                                                        |
|           |            |             | WIN_BOT                                                                  |
| 27:16     | R/W        | 0           | Window Bottom position                                                   |
|           |            |             | Bottom position is right-bottom y coordinate of display window in pixels |
| 15:12     | /          | /           | /                                                                        |
|           |            |             | WIN_RIGHT                                                                |
| 11:00     | R/W        | 0           | Window Right position                                                    |
|           |            |             | Right position is right-bottom x coordinate of display window in pixels  |



# 5.9.4.5 LP\_FILTER\_REG

| Offset: 0 | )x10       |             | Register Name: LP_FILTER_REG    |
|-----------|------------|-------------|---------------------------------|
| Bit       | Read/Write | Default/Hex | Description                     |
|           |            |             | FILTER_SEL                      |
| 31        | R/W        | 0x0         | Filter selection:               |
| 31        | r, vv      | UXU         | 0: Default filter.              |
|           |            |             | 1: Custom filter.               |
| 30:22     | /          | /           | /                               |
|           |            |             | HP_RATIO                        |
| 21:16     | R/W        | 0x0         | Default high-pass filter ratio  |
|           |            |             | Note: in two's complement.      |
| 15:14     | /          | /           | /                               |
|           |            |             | BPO_RATIO                       |
| 13:8      | R/W        | 0x0         | Default band-pass filter0 ratio |
|           |            |             | Note: in two's complement.      |
| 7:6       | /          | /           | /                               |
|           |            |             | BP1_RATIO                       |
| 5:0       | R/W        | R/W 0x0     | Default band-pass filter1 ratio |
|           |            |             | Note: in two's complement.      |

# 5.9.4.6 LP\_CSTM\_FILTERO\_REG

| Offset: ( | 0x14       |             | Register Name: LP_CSTM_FILTER0_REG |
|-----------|------------|-------------|------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                        |
| 31:25     | /          | /           | /                                  |
|           |            |             | C1                                 |
| 24:16     | R/W        | 0x0         | Custom filter coefficient C1.      |
|           |            |             | Note: in two's complement.         |
| 15:9      | /          | /           | 1                                  |
|           |            |             | СО                                 |
| 8:0       | R/W        | 0x0         | Custom filter coefficient CO.      |
|           |            |             | Note: in two's complement.         |

# 5.9.4.7 LP\_CSTM\_FILTER1\_REG

| Offset: 0x18 |            |             | Register Name: LP_CSTM_FILTER1_REG                       |
|--------------|------------|-------------|----------------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                              |
| 31:25        | /          | /           | /                                                        |
| 24:16        | R/W        | 0x0         | Custom filter coefficient C3. Note: in two's complement. |
| 15:9         | /          | /           | /                                                        |
| 8:0          | R/W        | 0x0         | C2                                                       |



|  | Custom filter coefficient C2. |
|--|-------------------------------|
|  | Note: in two's complement.    |

### 5.9.4.8 LP\_CSTM\_FILTER2\_REG

| Offset: 0x1C |            |             | Register Name: LP_CSTM_FILTER2_REG |
|--------------|------------|-------------|------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                        |
| 31:9         | /          | /           | /                                  |
|              |            |             | C4                                 |
| 8:0          | R/W        | 0x0         | Custom filter coefficient C4.      |
|              |            |             | Note: in two's complement.         |

### **5.9.4.9 LP\_GAIN\_REG**

| Offset: ( | )x20       |             | Register Name: LP_CSTM_FILTER0_REG |
|-----------|------------|-------------|------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                        |
| 31:8      | /          | /           | /                                  |
| 7.0       | R/W        | 0x0         | GAIN                               |
| 7:0       |            |             | Peaking gain setting.              |

### 5.9.4.10 LP\_GAINCTRL\_REG

| Offset: 0x24 |            |             | Register Name: LP_GAINCTRL_REG                                                      |
|--------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                                                         |
| 31:24        | /          | /           | /                                                                                   |
| 23:16        | R/W        | 0x0         | DIF_UP Gain control: limitation threshold. Note: use low 8bits for 8bit data width. |
| 15:8         | /          | /           | /                                                                                   |
| 4:0          | R/W        | 0x0         | BETA Gain control: large gain limitation. Note: in two's complement.                |

# 5.9.4.11 LP\_SHOOTCTRL\_REG

| Offset: 0x28 |            |             | Register Name: LP_SHOOTCTRL_REG   |
|--------------|------------|-------------|-----------------------------------|
| Bit          | Read/Write | Default/Hex | Description                       |
| 31:6         | /          | /           | /                                 |
| 5:0          | R/W        | 0x0         | NEG_GAIN Undershoot gain control. |

### 5.9.4.12 LP\_CORING\_REG

| Offset: ( | Offset: 0x2C               |  | Register Name: LP_CORING_REG |
|-----------|----------------------------|--|------------------------------|
| Bit       | Bit Read/Write Default/Hex |  | Description                  |



| 31:8 | /   | /   | /                                        |
|------|-----|-----|------------------------------------------|
|      |     |     | CORTHR                                   |
| 7:0  | R/W | 0x0 | Coring threshold.                        |
|      |     |     | Note: use low 8bits for 8bit data width. |

### 5.9.4.13 LP\_INCSC\_BYPASS\_REG

| Offset: 0x50 |            |             | Register Name: LP_INCSC_BYPASS_REG |
|--------------|------------|-------------|------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                        |
| 31:1         | /          | /           | 1                                  |
|              | R/W        | 0x0         | CSC_BYPASS                         |
| 0            |            |             | CSC bypass                         |
|              |            |             | 0: Bypass                          |
|              |            |             | 1: Not bypass                      |

# 5.9.4.14 LP\_INCSC\_COEFFO\_REG

| Offset: |               |             |                                                 |
|---------|---------------|-------------|-------------------------------------------------|
| C00 com | nponent: 0x60 |             | Register Name: LP_INCSC_COEFF0_REG              |
| C01 com | nponent: 0x64 |             |                                                 |
| C02 com | nponent: 0x68 |             |                                                 |
| Bit     | Read/Write    | Default/Hex | Description                                     |
| 31:13   | /             | /           | /                                               |
| 12:0    | R/W           | 0x0         | COEFF                                           |
|         |               |             | The value equals to coefficient*2 <sup>10</sup> |

### 5.9.4.15 LP\_INCSC\_CONSTO\_REG

| Offset: 0x6C |            |             | Register Name: LP_INCSC_CONST0_REG              |
|--------------|------------|-------------|-------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                     |
| 31:20        | /          | /           | 1                                               |
| 19:0         | R/W        | 0x0         | CONST                                           |
|              | K/VV       |             | The value equals to coefficient*2 <sup>10</sup> |

### 5.9.4.16 LP\_INCSC\_COEFF1\_REG

| Offset: |              |             |                                                 |
|---------|--------------|-------------|-------------------------------------------------|
| C10 com | ponent: 0x70 |             | Register Name: LP_INCSC_COEFF1_REG              |
| C11 com | ponent: 0x74 |             |                                                 |
| C12 com | ponent: 0x78 |             |                                                 |
| Bit     | Read/Write   | Default/Hex | Description                                     |
| 31:13   | /            | /           | /                                               |
| 12:0    | R/W          | R/W 0x0     | COEFF                                           |
|         |              |             | The value equals to coefficient*2 <sup>10</sup> |



### 5.9.4.17 LP\_INCSC\_CONST1\_REG

| Offset: 0x7C |            |             | Register Name: LP_INCSC_CONST1_REG              |
|--------------|------------|-------------|-------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                     |
| 31:20        | /          | /           | 1                                               |
| 19:0         | R/W        | 0x0         | CONST                                           |
|              | ,          |             | The value equals to coefficient*2 <sup>10</sup> |

### 5.9.4.18 LP\_INCSC\_COEFF2\_REG

| Offset:             |               |             |                                                 |
|---------------------|---------------|-------------|-------------------------------------------------|
| C20 component: 0x80 |               |             | Pagistar Names ID INCSC COFFE3 DEC              |
| C21 com             | nponent: 0x84 |             | Register Name: LP_INCSC_COEFF2_REG              |
| C22 com             | nponent: 0x88 |             |                                                 |
| Bit                 | Read/Write    | Default/Hex | Description                                     |
| 31:13               | /             | /           | /                                               |
| 12.0                | 12:0 R/W      | R/W 0x0     | COEFF                                           |
| 12:0                |               |             | The value equals to coefficient*2 <sup>10</sup> |

#### 5.9.4.19 LP\_INCSC\_CONST2\_REG

| Offset: ( | )x8C       |             | Register Name: LP_INCSC_CONST2_REG              |
|-----------|------------|-------------|-------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                     |
| 31:20     | /          | /           | 1                                               |
| 10.0      | R/W        | 0x0         | CONST                                           |
| 19:0      |            |             | The value equals to coefficient*2 <sup>10</sup> |

### 5.9.4.20 LP\_OUTCSC\_BYPASS\_REG

| Offset: 0x90 |            |             | Register Name: LP_OUTCSC_BYPASS_REG |
|--------------|------------|-------------|-------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                         |
| 31:1         | /          | /           | 1                                   |
|              | R/W        | 0x0         | CSC_BYPASS                          |
| 0            |            |             | CSC bypass                          |
|              |            |             | 0: Bypass                           |
|              |            |             | 1: Not bypass                       |

# 5.9.4.21 LP\_OUTCSC\_COEFFO\_REG

| Offset: |               |             |                                                 |
|---------|---------------|-------------|-------------------------------------------------|
| C00 com | nponent: 0xA0 |             | Register Name: LP_OUTCSC_COEFF0_REG             |
| C01 com | nponent: 0xA4 |             |                                                 |
| C02 com | nponent: 0xA8 |             |                                                 |
| Bit     | Read/Write    | Default/Hex | Description                                     |
| 31:13   | /             | /           | /                                               |
| 12.0    | 12:0 R/W      | 0x0         | COEFF                                           |
| 12:0    |               |             | The value equals to coefficient*2 <sup>10</sup> |



# 5.9.4.22 LP\_OUTCSC\_CONSTO\_REG

| Offset: 0xAC |            |             | Register Name: LP_OUTCSC_CONSTO_REG             |
|--------------|------------|-------------|-------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                     |
| 31:20        | /          | /           | 1                                               |
| 10.0         | R/W        | 0x0         | CONST                                           |
| 19:0         |            |             | The value equals to coefficient*2 <sup>10</sup> |

### 5.9.4.23 LP\_OUTCSC\_COEFF1\_REG

| Offset: |              |             | Register Name: LP_OUTCSC_COEFF1_REG             |
|---------|--------------|-------------|-------------------------------------------------|
| C10 com | ponent: 0xB0 |             |                                                 |
| C11 com | ponent: 0xB4 |             |                                                 |
| C12 com | ponent: 0xB8 |             |                                                 |
| Bit     | Read/Write   | Default/Hex | Description                                     |
| 31:13   | /            | /           | 1                                               |
| 12:0    | D /\A/       | /W 0x0      | COEFF                                           |
|         | K/VV         |             | The value equals to coefficient*2 <sup>10</sup> |

#### 5.9.4.24 LP\_OUTCSC\_CONST1\_REG

| Offset: ( | )xBC       |             | Register Name: LP_OUTCSC_CONST1_REG             |
|-----------|------------|-------------|-------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                     |
| 31:20     | /          | /           | /                                               |
| 10.0      | D /\A/     | 0.40        | CONST                                           |
| 19:0      | R/W        | 0x0         | The value equals to coefficient*2 <sup>10</sup> |

#### 5.9.4.25 LP\_OUTCSC\_COEFF2\_REG

| Offset: |               |             |                                                 |
|---------|---------------|-------------|-------------------------------------------------|
| C20 com | ponent: 0xC0  |             | Register Name: LP_OUTCSC_COEFF2_REG             |
| C21 com | nponent: 0xC4 |             |                                                 |
| C22 com | nponent: 0xC8 |             |                                                 |
| Bit     | Read/Write    | Default/Hex | Description                                     |
| 31:13   | /             | /           | /                                               |
| 12:0    | R/W           | 0x0         | COEFF                                           |
|         |               |             | The value equals to coefficient*2 <sup>10</sup> |

#### 5.9.4.26 LP\_OUTCSC\_CONST2\_REG

| Offset: 0xCC |            |             | Register Name: LP_OUTCSC_CONST2_REG             |
|--------------|------------|-------------|-------------------------------------------------|
| Bit          | Read/Write | Default/Hex | Description                                     |
| 31:20        | /          | /           | /                                               |
| 19:0         | R/W        | 0x0         | CONST                                           |
|              |            |             | The value equals to coefficient*2 <sup>10</sup> |



# **5.10 DE RT-MIXER Specification**

#### 5.10.1 Overview

The RT-mixer Core consist of dma, overlay, scaler and blender block. It supports 4 layers overlay in one pipe, and its result can scaler up or down to blender in the next processing. There's the feature description as follows:

- Support layer size up to 2048x204 pixels
- Support pre-multiply alpha image data
- Support four layers overlay in every pipe and four pipes alpha blending
- Support color key
- Support Porter-Duff alpha blending
- Support input format YUV422/YUV420/YUV411/ARGB8888/XRGB8888/RGB8888/ARGB4444/ ARGB1555 and RGB565
- Support 3D format image data

#### 5.10.2 Block Diagram



Figure 5-2. RT-Mixer General Diagram



### **5.10.3 DE RT-Mixer Description**

#### 5.10.3.1 Input Data Memory Layout



Figure 5-3. Input data pixel sequence

#### 5.10.3.2 Overlay

Figure 5-4 is the overlay processing include layer memory data access and overlay relationship, the detail as following.





Figure 5-4. Layers memory access and overlay processing

Note: the layer priority is layer3>layer2>layer1>layer0

#### 5.10.3.3 Scaling

UI scaler: Please refer to << Display\_Engine2.0\_UI\_Scaler\_SPEC>>

Video scaler: Please refer to << Display\_Engine2.0\_Video\_Scaler\_SPEC>>

Routing: The routing connects N channels and N input of blending together. Any channel can connect to any pipe.

Programmer should make sure every pipe should connect one different channel only.



Figure 5-5. N Channel select pipe route processing



#### 5.10.3.4 Blender

#### Blender input data storing:

The following diagram is about overlay data remapping in the blender pipe.



Figure 5-6. Pipe memory access diagram

# 5.10.4 Memory Mapping List

| Module name       | Memory Range | Offset Address |
|-------------------|--------------|----------------|
| GLB               | 4K           | 0x00000        |
| BLD               | 4K           | 0x01000        |
| OVL_V(CH0)        | 4K           | 0x02000        |
| OVL_UI(CH1)       | 4K           | 0x03000        |
| OVL_UI(CH2)       | 4K           | 0x04000        |
| OVL_UI(CH3)       | 4K           | 0x05000        |
| VIDEO_SCALER(CH0) | 128K         | 0x20000        |
| UI_SCALER1(CH1)   | 64K          | 0x40000        |
| UI_SCALER2(CH2)   | 64K          | 0x50000        |
| UI_SCALER3(CH3)   | 64K          | 0x60000        |
| POST_PROC1        | 64K          | 0xA0000        |
| POST_PROC2        | 64K          | 0xB0000        |
| DMA               | 128K         | 0xC0000        |

# 5.10.5 Register List

| Register name | Offset | Description                           |
|---------------|--------|---------------------------------------|
| GLB_CTL       | 0x000  | Global control register               |
| GLB_STS       | 0x004  | Global status register                |
| GLB_DBUFFER   | 0x008  | Global double buffer control register |
| GLB_SIZE      | 0x00C  | Global size register                  |
|               |        |                                       |



|                   |                | T                                                                |
|-------------------|----------------|------------------------------------------------------------------|
| OVL_V_ATTCTL      | 0x000 + N*0x30 | OVL_V attribute control register(N=0,1,2,3)                      |
| OVL_V_MBSIZE      | 0x004 + N*0x30 | OVL_V memory block size register(N=0,1,2,3)                      |
| OVL_V_COOR        | 0x008 + N*0x30 | OVL_V memory block coordinate register(N=0,1,2,3)                |
| OVL_V_PITCH0      | 0x00C + N*0x30 | OVL_V memory pitch register0(N=0,1,2,3)                          |
| OVL_V_PITCH1      | 0x010 + N*0x30 | OVL_V memory pitch register1(N=0,1,2,3)                          |
| OVL_V_PITCH2      | 0x014 + N*0x30 | OVL_V memory pitch register2(N=0,1,2,3)                          |
| OVL_V_TOP_LADD0   | 0x018 + N*0x30 | OVL_V top field memory block low address register0(N=0,1,2,3)    |
| OVL_V_TOP_LADD1   | 0x01C + N*0x30 | OVL_V top field memory block low address register1(N=0,1,2,3)    |
| OVL_V_TOP_LADD2   | 0x020 + N*0x30 | OVL_V top field memory block low address register2(N=0,1,2,3)    |
| OVL_V_BOT_LADD0   | 0x024 + N*0x30 | OVL_V bottom field memory block low address register0(N=0,1,2,3) |
| OVL_V_BOT_LADD1   | 0x028 + N*0x30 | OVL_V bottom field memory block low address register1(N=0,1,2,3) |
| OVL_V_BOT_LADD2   | 0x02C + N*0x30 | OVL_V bottom field memory block low address register2(N=0,1,2,3) |
| OVL_V_FILL_COLOR  | 0x0C0 + N*0x4  | OVL_V fill color register(N=0,1,2,3)                             |
| OVL_V_TOP_HADD0   | 0x0D0          | OVL_V top field memory block high address register0              |
| OVL_V_TOP_HADD1   | 0x0D4          | OVL_V top field memory block high address register1              |
| OVL_V_TOP_HADD2   | 0x0D8          | OVL_V top field memory block high address register2              |
| OVL_V_BOT_HADD0   | 0x0DC          | OVL_V bottom field memory block high address register0           |
| OVL_V_BOT_HADD1   | 0x0E0          | OVL_V bottom field memory block high address register1           |
| OVL_V_BOT_HADD2   | 0x0E4          | OVL_V bottom field memory block high address register2           |
| OVL_V_SIZE        | 0x0E8          | OVL_V overlay window size register                               |
| OVL_V_HDS_CTL0    | 0x0F0          | OVL_V horizontal down sample control register0                   |
| OVL_V_HDS_CTL1    | 0x0F4          | OVL_V horizontal down sample control register1                   |
| OVL_V_VDS_CTL0    | 0x0F8          | OVL_V vertical down sample control register0                     |
| OVL_V_VDS_CTL1    | 0x0FC          | OVL_V vertical down sample control register1                     |
|                   | •              |                                                                  |
| OVL_UI_ATTCTL     | 0x000 + N*0x20 | OVL_UI attribute control register(N=0,1,2,3)                     |
| OVL_UI_MBSIZE     | 0x004 + N*0x20 | OVL_UI memory block size register(N=0,1,2,3)                     |
| OVL_UI_COOR       | 0x008 + N*0x20 | OVL_UI memory block coordinate register(N=0,1,2,3)               |
| OVL_UI_PITCH      | 0x00C + N*0x20 | OVL_UI memory pitch register(N=0,1,2,3)                          |
| OVL_UI_TOP_LADD   | 0x010 + N*0x20 | OVL_UI top field memory block low address register(N=0,1,2,3)    |
| OVL_UI_BOT_LADD   | 0x014 + N*0x20 | OVL_UI bottom field memory block low address register(N=0,1,2,3) |
| OVL_UI_FILL_COLOR | 0x018 + N*0x20 | OVL_UI fill color register(N=0,1,2,3)                            |
| OVL_UI_TOP_HADD   | 0x080          | OVL_UI top field memory block high address register              |
| OVL_UI_BOT_HADD   | 0x084          | OVL_UI bottom field memory block high address register           |
| OVL_UI_SIZE       | 0x088          | OVL_UI overlay window size register                              |
|                   | 1              | , = -                                                            |
| BLD_FILLCOLOR_CTL | 0x000          | BLD fill color control register                                  |
| BLD_FILL_COLOR    | 0x004 + N*0x14 | BLD fill color register(N=0,1,2,3,4)                             |
| BLD_CH_ISIZE      | 0x008 + N*0x14 | BLD input memory size register(N=0,1,2,3,4)                      |
| BLD_CH_OFFSET     | 0x00C + N*0x14 | BLD input memory offset register(N=0,1,2,3,4)                    |
| BLD_CH_RTCTL      | 0x080          | BLD routing control register                                     |
| BLD_PREMUL_CTL    | 0x084          | BLD pre-multiply control register                                |
| BLD_BK_COLOR      | 0x088          | BLD background color register                                    |
| BLD_SIZE          | 0x08C          | BLD output size setting register                                 |
| BLD_CTL           | 0x090 - 0x09C  | BLD control register                                             |
| DLD_C1L           | 0.000 0.000    | DED CONTROL LEGISTEE                                             |



| BLD_KEY_CTL   | 0x0B0         | BLD color key control register       |
|---------------|---------------|--------------------------------------|
| BLD_KEY_CON   | 0x0B4         | BLD color key configuration register |
| BLD_KEY_MAX   | 0x0C0 - 0x0CC | BLD color key max register           |
| BLD_KEY_MIN   | 0x0E0 – 0x0EC | BLD color key min register           |
| BLD_OUT_COLOR | 0x0FC         | BLD output color control register    |

# **5.10.6 GLB Register Description**

**Note:** all registers in GLB are not double buffer. **Note:** all registers in GLB are not double buffer.

### 5.10.6.1 Global control register

| Offset: 0x000 |            |             | Register Name: GLB_CTL             |
|---------------|------------|-------------|------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                        |
| 31:14         | /          | /           | /                                  |
|               |            |             | OUT_DATA_WB                        |
|               |            |             | Output data for RT-WB              |
| 13:12         | R/W        | 0x0         | 0:RT-WB fetch data after DEP port  |
|               |            |             | 1:RT-WB fetch data before DEP port |
|               |            |             | Other: Reserved                    |
| 11:10         | /          | /           | /                                  |
| 9             | R/W        | 0x0         | Icd flied in reverse               |
| 8             | R/W        | 0x0         | Icd sync in reverse                |
| 7:6           | /          | /           | /                                  |
|               |            |             | ERROR_IRQ_EN                       |
| 5             | R/W        | 0.40        | Hardware error IRQ enable          |
| 5             | K/VV       | 0x0         | 0:disable                          |
|               |            |             | 1:enable                           |
|               |            | 0x0         | FINISH_IRQ_EN                      |
| 4             | R/W        |             | Mission finish IRQ enable          |
| 4             | K/W        |             | 0:disable                          |
|               |            |             | 1:enable                           |
| 3:1           | /          | /           | /                                  |
|               | R/W        | 0x0         | EN                                 |
| 0             |            |             | RT enable/disable                  |
|               |            |             | 0: disable                         |
|               |            |             | 1: enable                          |

#### 5.10.6.2 Global status register

| Offset: 0x004 |            |             | Register Name: GLB_STS |
|---------------|------------|-------------|------------------------|
| Bit           | Read/Write | Default/Hex | Description            |
| 31:9          | /          | /           | /                      |
| 0             | R          | 0x0         | EVEN_ODD               |
| 0             | , r        | UXU         | 0: even field          |



|     |     |      | 1: odd field                                                                  |
|-----|-----|------|-------------------------------------------------------------------------------|
|     |     |      | This bit is the flag for output data in interlace mode                        |
| 7:6 | /   | /    | /                                                                             |
| _   | D   | 0.40 | ERROR                                                                         |
| 5   | R   | 0x0  | Hardware error status                                                         |
|     |     |      | BUSY                                                                          |
| 4   | R   | 0.0  | Module working status                                                         |
| 4   | K   | 0x0  | 0:idle                                                                        |
|     |     |      | 1:running busy                                                                |
| 3:2 | /   | /    | /                                                                             |
|     |     |      | ERROR_IRQ                                                                     |
| 1   | R/W | 0x0  | Hardware error IRQ                                                            |
|     |     |      | It will be set when hardware error occur, and cleared by writing 1.           |
|     |     |      | FINISH_IRQ                                                                    |
| 0   | R/W | 0x0  | Mission finish IRQ                                                            |
|     |     |      | It will be set when 1 frame operation accomplished, and cleared by writing 1. |

### 5.10.6.3 Global double buffer control register

| Offset: 0x008 |            |             | Register Name: GLB_DBUFFER                               |
|---------------|------------|-------------|----------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                              |
| 31:1          | /          | /           | /                                                        |
| 0             |            | 0x0         | DOUBLE_BUFFER_RDY                                        |
|               | R/W        |             | 0: no change                                             |
|               | K/ VV      |             | 1: register value be ready for update                    |
|               |            |             | Note:This bit is self-cleared by writing 1 after update. |

# 5.10.6.4 Global size register

| Offset: 0 | )x00C      |             | Register Name: GLB_SIZE                    |
|-----------|------------|-------------|--------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                |
| 31:29     | /          | /           | /                                          |
|           |            |             | HEIGHT                                     |
| 28:16     | R/W        | 0x0         | Height                                     |
|           |            |             | The Height = The value of these bits add 1 |
| 15:13     | /          | /           | /                                          |
|           |            |             | WIDTH                                      |
| 12:0      | R/W        | 0x0         | Width                                      |
|           |            |             | The Width = The value of these bits add 1  |

# **5.10.7 OVL\_V Register Description**

Note: all registers in OVL\_V are double buffer.



# 5.10.7.1 OVL\_V attribute control register

|       | Offset: 0x000+N*0x30<br>(N=0,1,2,3) |             | Register Name: OVL_V_ATTCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Read/Write                          | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:24 | /                                   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23    | R/W                                 | 0x0         | LAYO_TOP_BOTTOM_ADDR_EN  0: disable  1: enable  When this bit is disable the layer address use top field address in both top and bottom field, otherwise use the top and bottom field address separate in top and bottom field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 22:16 | /                                   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15    | R/W                                 | 0x0         | Video_UI_SEL Video Overlay or UI Overlay Select 0: Video Overlay(using Video Overlay Layer Input data format) 1: UI Overlay(using UI Overlay Layer Input data format)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 14:13 | /                                   | /           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12:8  | R/W                                 | 0x0         | LAY_FBFMT  Video Overlay Layer Input data format  0x00: Interleaved YUV422(V0Y1U0Y0)  0x01: Interleaved YUV422(Y1V0Y0U0)  0x02: Interleaved YUV422(U0Y1V0Y0)  0x03: Interleaved YUV422(Y1U0Y0V0)  0x03: Interleaved YUV422(Y1U0Y0V0)  0x04: Planar YUV422 UV combined(V1U1V0U0)  0x05: Planar YUV422 UV combined(U1V1U0V0)  0x06: Planar YUV422  0x07: Reserved  0x08: Planar YUV420 UV combined(V1U1V0U0)  0x09: Planar YUV420 UV combined(U1V1U0V0)  0x0A: Planar YUV420  0x0B: Reserved  0x0C: Planar YUV411 UV combined(V1U1V0U0)  0x0E: Planar YUV411 UV combined(U1V1U0V0)  0x0E: Planar YUV411  Other: Reserved  All video layers must be the same format, programmer should confirm it.  UI Overlay Layer Input data format  0x00: ARGB_8888  0x01: ABGR_8888  0x02: RGBA_8888  0x02: RGBA_8888  0x03: BGRA_8888  0x04: XRGB_8888  0x05: XBGR_8888  0x05: XBGR_8888  0x06: RGBX_8888 |



| 1   | ı     | 1     |                                                                               |
|-----|-------|-------|-------------------------------------------------------------------------------|
|     |       |       | 0x07: BGRX_8888                                                               |
|     |       |       | 0x08: RGB_888                                                                 |
|     |       |       | 0x09: BGR_888                                                                 |
|     |       |       | 0x0A: RGB_565                                                                 |
|     |       |       | 0x0B: BGR_565                                                                 |
|     |       |       | 0x0C: ARGB_4444                                                               |
|     |       |       | 0x0D: ABGR_4444                                                               |
|     |       |       | 0x0E: RGBA_4444                                                               |
|     |       |       | 0x0F: BGRA_4444                                                               |
|     |       |       | 0x10: ARGB_1555                                                               |
|     |       |       | 0x11: ABGR_1555                                                               |
|     |       |       | 0x12: RGBA_5551                                                               |
|     |       |       | 0x13: BGRA_5551                                                               |
|     |       |       | Other: Reserved                                                               |
|     |       |       | All ui layers' alpha is useless.                                              |
| 7:5 | /     | /     | /                                                                             |
|     |       |       | LAY_FILLCOLOR_EN                                                              |
|     | 5 /14 |       | 0: disable                                                                    |
| 4   | R/W   | 0x0   | 1:enable                                                                      |
|     |       |       | When the layer fill-color is enabled, the layer data will use the fill-color. |
| 3:1 | /     | /     | /                                                                             |
|     |       | V 0x0 | LAY0_EN                                                                       |
|     | - 6   |       | Layer0 enable/disable                                                         |
| 0   | R/W   |       | 0: disabled                                                                   |
|     |       |       | 1: enabled                                                                    |
|     |       |       | 1: enabled                                                                    |

Note: the layer priority is layer3>layer2>layer1>layer0

# 5.10.7.2 OVL\_V memory block size register

| Offset: 0x004+N*0x30<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_MBSIZE                                             |
|-------------------------------------|------------|-------------|-------------------------------------------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                                                             |
| 31:29                               | /          | /           | /                                                                       |
| 28:16                               | R/W        | 0x0         | LAY_HEIGHT Layer Height                                                 |
|                                     | ,          | ,           | The Layer Height = The value of these bits add 1                        |
| 15:13                               | /          | /           | 1                                                                       |
| 12:0                                | R/W        | 0x0         | LAY_WIDTH  Layer Width  The Layer Width = The value of these bits add 1 |

# 5.10.7.3 OVL\_V memory block coordinate register

| Offset: 0x008+N*0x30 | Register Name: OVL V COOR |
|----------------------|---------------------------|
| (N=0,1,2,3)          | Register Name: OVL_V_COOK |



| Bit   | Read/Write | Default/Hex | Description                                                         |
|-------|------------|-------------|---------------------------------------------------------------------|
|       |            |             | LAY_YCOOR                                                           |
| 31:16 | R/W        | 0x0         | Y coordinate                                                        |
|       |            |             | Y is the left-top y coordinate of layer on overlay window in pixels |
|       |            |             | LAY_XCOOR                                                           |
| 15:0  | R/W        | 0x0         | X coordinate                                                        |
|       |            |             | X is left-top x coordinate of the layer on overlay window in pixels |

Setting the layer0-layer3 the coordinate (left-top) on overlay window control information

#### 5.10.7.4 OVL\_V memory pitch register0

| Offset: 0x00C+N*0x30<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_PITCH0 |
|-------------------------------------|------------|-------------|-----------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                 |
| 31:0                                | R/W        | 0x0         | LAY_PITCH                   |
| 31.0                                | K/VV       | UXU         | Layer memory pitch in bytes |

Note: The setting of this register is Y channel.

### 5.10.7.5 OVL\_V memory pitch register1

| Offset: 0x010+N*0x30<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_PITCH1 |
|-------------------------------------|------------|-------------|-----------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                 |
| 31:0                                | R/W        | 0.40        | LAY_PITCH                   |
| 31.0                                | K/VV       | 0x0         | Layer memory pitch in bytes |

Note: The setting of this register is U/UV channel.

#### 5.10.7.6 OVL\_V memory pitch register2

|      | Offset: 0x014+N*0x30<br>(N=0,1,2,3) |             | Register Name: OVL_V_PITCH2 |
|------|-------------------------------------|-------------|-----------------------------|
| Bit  | Read/Write                          | Default/Hex | Description                 |
| 31:0 | R/W                                 | 0x0         | LAY_PITCH                   |
| 31.0 | I N/ VV                             | UXU         | Layer memory pitch in bytes |

Note: The setting of this register is V channel.

#### 5.10.7.7 OVL\_V top field memory block low address register0

| Offset: 0x018+N*0x30<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_TOP_LADD0      |
|-------------------------------------|------------|-------------|-------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                         |
|                                     |            |             | LAYMB_LADD                          |
| 31:0                                | R/W        | 0x0         | Memory Block Start Address          |
|                                     |            |             | Layer Memory Block Address in bytes |

Note: The setting of this register is Y channel address.



#### 5.10.7.8 OVL\_V top field memory block low address register1

| Offset: 0x01C+N*0x30<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_TOP_LADD1      |
|-------------------------------------|------------|-------------|-------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                         |
|                                     |            |             | LAYMB_LADD                          |
| 31:0                                | R/W        | 0x0         | Memory Block Start Address          |
|                                     |            |             | Layer Memory Block Address in bytes |

Note: The setting of this register is U/UV channel address.

#### 5.10.7.9 OVL\_V top field memory block low address register2

| Offset: 0x020+N*0x30<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_TOP_LADD2      |
|-------------------------------------|------------|-------------|-------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                         |
|                                     |            |             | LAYMB_LADD                          |
| 31:0                                | R/W        | 0x0         | Memory Block Start Address          |
|                                     |            |             | Layer Memory Block Address in bytes |

Note: The setting of this register is V channel address.

#### 5.10.7.10 OVL\_V bottom field memory block low address register0

| Offset: 0x024+N*0x30<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_BOT_LADD0      |
|-------------------------------------|------------|-------------|-------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                         |
|                                     |            |             | LAYMB_LADD                          |
| 31:0                                | R/W        | 0x0         | Memory Block Start Address          |
|                                     |            |             | Layer Memory Block Address in bytes |

Note: The setting of this register is Y channel address.

#### 5.10.7.11 OVL\_V bottom field memory block low address register1

| Offset: 0x028+N*0x30<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_BOT_LADD1      |
|-------------------------------------|------------|-------------|-------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                         |
|                                     |            |             | LAYMB_LADD                          |
| 31:0                                | R/W        | 0x0         | Memory Block Start Address          |
|                                     |            |             | Layer Memory Block Address in bytes |

Note: The setting of this register is U/UV channel address.

#### 5.10.7.12 OVL\_V bottom field memory block low address register2

| Offset: 0x02C+N*0x30 | Register Name: OVL_V_BOT_LADD2 |
|----------------------|--------------------------------|
| (N=0,1,2,3)          | Register Name: OVL_V_BOT_LADD2 |



| Bit  | Read/Write | Default/Hex | Description                         |
|------|------------|-------------|-------------------------------------|
|      |            |             | LAYMB_LADD                          |
| 31:0 | R/W        | 0x0         | Memory Block Start Address          |
|      |            |             | Layer Memory Block Address in bytes |

Note: The setting of this register is V channel address.

### 5.10.7.13 OVL\_V fill color register

| Offset: 0x0C0+N*0x4<br>(N=0,1,2,3) |            |             | Register Name: OVL_V_FILL_COLOR |
|------------------------------------|------------|-------------|---------------------------------|
| Bit                                | Read/Write | Default/Hex | Description                     |
| 31:24                              | /          | /           | /                               |
| 23:16                              | R/W        | 0x0         | Y/R                             |
| 25.10                              |            |             | Y/Red fill color value          |
| 15:8                               | D /\A/     | R/W 0x0     | U/G                             |
| 15.6                               | K/ VV      |             | U/Green fill color value        |
| 7:0                                | D /\A/     | 0v0         | V/B                             |
|                                    | R/W        | 0x0         | V/Blue fill color value         |

# 5.10.7.14 OVL\_V top field memory block high address register0

| Offset: 0 | Offset: 0x0D0 |             | Register Name: OVL_V_TOP_HADD0      |
|-----------|---------------|-------------|-------------------------------------|
| Bit       | Read/Write    | Default/Hex | Description                         |
|           |               |             | LAY3MB_HADD                         |
| 31:24     | R/W           | 0x0         | Layer3                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAY2MB_HADD                         |
| 23:16     | R/W           | 0x0         | Layer2                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAY1MB_HADD                         |
| 15:8      | R/W           | 0x0         | Layer1                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAYOMB_HADD                         |
| 7:0       | R/W           | 0x0         | Layer0                              |
|           |               |             | Layer Memory Block Address in bytes |

Note: The setting of this register is Y channel address.

# 5.10.7.15 OVL\_V top field memory block high address register1

| Offset: 0x0D4 |            |             | Register Name: OVL_V_TOP_HADD1      |
|---------------|------------|-------------|-------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                         |
|               |            |             | LAY3MB_HADD                         |
| 31:24         | R/W        | 0x0         | Layer3                              |
|               |            |             | Layer Memory Block Address in bytes |
| 23:16         | R/W        | 0x0         | LAY2MB_HADD                         |



|      |     |     | Layer2                              |
|------|-----|-----|-------------------------------------|
|      |     |     | Layer Memory Block Address in bytes |
|      |     |     | LAY1MB_HADD                         |
| 15:8 | R/W | 0x0 | Layer1                              |
|      |     |     | Layer Memory Block Address in bytes |
|      |     |     | LAY0MB_HADD                         |
| 7:0  | R/W | 0x0 | Layer0                              |
|      |     |     | Layer Memory Block Address in bytes |

Note: The setting of this register is U/UV channel address.

### 5.10.7.16 OVL\_V top field memory block high address register2

| Offset: 0 | Offset: 0x0D8 |             | Register Name: OVL_V_TOP_HADD2      |
|-----------|---------------|-------------|-------------------------------------|
| Bit       | Read/Write    | Default/Hex | Description                         |
|           |               |             | LAY3MB_HADD                         |
| 31:24     | R/W           | 0x0         | Layer3                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAY2MB_HADD                         |
| 23:16     | R/W           | 0x0         | Layer2                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAY1MB_HADD                         |
| 15:8      | R/W           | 0x0         | Layer1                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAYOMB_HADD                         |
| 7:0       | R/W           | 0x0         | Layer0                              |
|           |               |             | Layer Memory Block Address in bytes |

Note: The setting of this register is V channel address.

### 5.10.7.17 OVL\_V bottom field memory block high address register0

| Offset: 0 | Offset: 0x0DC |             | Register Name: OVL_V_BOT_HADD0      |
|-----------|---------------|-------------|-------------------------------------|
| Bit       | Read/Write    | Default/Hex | Description                         |
|           |               |             | LAY3MB_HADD                         |
| 31:24     | R/W           | 0x0         | Layer3                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAY2MB_HADD                         |
| 23:16     | R/W           | 0x0         | Layer2                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAY1MB_HADD                         |
| 15:8      | R/W           | 0x0         | Layer1                              |
|           |               |             | Layer Memory Block Address in bytes |
|           |               |             | LAYOMB_HADD                         |
| 7:0       | R/W           | 0x0         | Layer0                              |
|           |               |             | Layer Memory Block Address in bytes |

Note: The setting of this register is Y channel address.



### 5.10.7.18 OVL\_V bottom field memory block high address register1

| Offset: 0 | )x0E0      |             | Register Name: OVL_V_BOT_HADD1      |
|-----------|------------|-------------|-------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                         |
|           |            |             | LAY3MB_HADD                         |
| 31:24     | R/W        | 0x0         | Layer3                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAY2MB_HADD                         |
| 23:16     | R/W        | 0x0         | Layer2                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAY1MB_HADD                         |
| 15:8      | R/W        | 0x0         | Layer1                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAYOMB_HADD                         |
| 7:0       | R/W        | 0x0         | Layer0                              |
|           |            |             | Layer Memory Block Address in bytes |

Note: The setting of this register is U/UV channel address.

### 5.10.7.19 OVL\_V bottom field memory block high address register2

| Offset: 0 | x0E4       |             | Register Name: OVL_V_BOT_HADD2      |
|-----------|------------|-------------|-------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                         |
|           |            |             | LAY3MB_HADD                         |
| 31:24     | R/W        | 0x0         | Layer3                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAY2MB_HADD                         |
| 23:16     | R/W        | 0x0         | Layer2                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAY1MB_HADD                         |
| 15:8      | R/W        | 0x0         | Layer1                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAYOMB_HADD                         |
| 7:0       | R/W        | 0x0         | Layer0                              |
|           |            |             | Layer Memory Block Address in bytes |

Note: The setting of this register is V channel address.

### 5.10.7.20 OVL\_V overlay window size register

| Offset: 0x0E8 |            |             | Register Name: OVL_V_SIZE                          |
|---------------|------------|-------------|----------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                        |
| 31:29         | /          | /           | /                                                  |
|               |            |             | HEIGHT                                             |
| 28:16         | R/W        | 0x0         | Overlay Height                                     |
|               |            |             | The Overlay Height = The value of these bits add 1 |



| 15:13 | /   | /   | /                                                 |
|-------|-----|-----|---------------------------------------------------|
|       |     |     | WIDTH                                             |
| 12:0  | R/W | 0x0 | Overlay Width                                     |
|       |     |     | The Overlay Width = The value of these bits add 1 |

when all the layers are disable the overlay has no output data, and by pass.

#### 5.10.7.21 OVL\_V horizontal down sampling control register0

| Offset: 0 | Dx0F0      |             | Register Name: OVL_V_HDS_CTL0                           |
|-----------|------------|-------------|---------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                             |
| 31:30     | /          | /           | /                                                       |
|           |            |             | N                                                       |
| 29:16     | R/W        | 0x0         | The step size for overlay data fetch.                   |
|           |            |             | Note: Refer to "Figure 6 Video overlay data fetch rule" |
| 15:14     | /          | /           | 1                                                       |
|           |            |             | M                                                       |
| 13:0      | R/W        | 0x0         | The counter threshold for fetch data                    |
|           |            |             | Note: Refer to "Figure 6 Video overlay data fetch rule" |

The setting of this register is Y channel.

### 5.10.7.22 OVL\_V horizontal down sampling control register1

| Offset: 0 | 0x0F4      |             | Register Name: OVL_V_HDS_CTL1                           |
|-----------|------------|-------------|---------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                             |
| 31:30     | /          | /           | /                                                       |
|           |            |             | N                                                       |
| 29:16     | R/W        | 0x0         | The step size for overlay data fetch.                   |
|           |            |             | Note: Refer to "Figure 6 Video overlay data fetch rule" |
| 15:14     | /          | /           | /                                                       |
|           |            |             | М                                                       |
| 13:0      | R/W        | 0x0         | The counter threshold for fetch data                    |
|           |            |             | Note: Refer to "Figure 6 Video overlay data fetch rule" |

The setting of this register is UV channel.

#### 5.10.7.23 OVL\_V vertical down sampling control register0

| Offset: 0 | )x0F8      |             | Register Name: OVL_V_VDS_CTL0                           |
|-----------|------------|-------------|---------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                             |
| 31:30     | /          | /           | /                                                       |
|           |            |             | N                                                       |
| 29:16     | R/W        | 0x0         | The step size for overlay data fetch.                   |
|           |            |             | Note: Refer to "Figure 6 Video overlay data fetch rule" |
| 15:14     | /          | /           | /                                                       |
| 13:0      | R/W        | 0x0         | M                                                       |
|           |            |             | The counter threshold for fetch data                    |



Note: Refer to "Figure 6 Video overlay data fetch rule"

The setting of this register is Y channel.

### 5.10.7.24 OVL\_V vertical down sampling control register1

| Offset: 0 | Dx0FC      |             | Register Name: OVL_V_VDS_CTL1                           |
|-----------|------------|-------------|---------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                             |
| 31:30     | /          | /           | /                                                       |
|           |            |             | N                                                       |
| 29:16     | R/W        | 0x0         | The step size for overlay data fetch.                   |
|           |            |             | Note: Refer to "Figure 6 Video overlay data fetch rule" |
| 15:14     | /          | /           | /                                                       |
|           |            |             | М                                                       |
| 13:0      | R/W        | 0x0         | The counter threshold for fetch data                    |
|           |            |             | Note: Refer to "Figure 6 Video overlay data fetch rule" |

The setting of this register is UV channel.

# 5.10.8 OVL\_UI Register Description

Note: all registers in OVL\_UI are double buffer.

#### 5.10.8.1 OVL\_UI attribute control register

| Offset: 0x000+N*0x20<br>(N=0,1,2,3) |            |             | Register Name: OVL_UI_ATTR_CTL                                                   |
|-------------------------------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                                                                      |
|                                     |            |             | LAY_GLBALPHA                                                                     |
| 31:24                               | R/W        | 0x0         | Globe alpha value                                                                |
|                                     |            |             | Alpha value is used for this layer                                               |
|                                     |            |             | TOP_BOTTOM_ADDR_EN                                                               |
|                                     |            |             | 0: disable                                                                       |
| 23                                  | R/W        | 0x0         | 1: enable                                                                        |
| 23                                  | N/ VV      | OXO         | When this bit is disable the layer address use top field address in both top and |
|                                     |            |             | bottom field, otherwise use the top and bottom field address separate in top     |
|                                     |            |             | and bottom field.                                                                |
| 22:18                               | /          | /           | 1                                                                                |
|                                     |            |             | LAY_PREMUL_CTL                                                                   |
|                                     |            | 0x0         | Layer input pre-multiply alpha control                                           |
|                                     |            |             | 0x0: Input layer data is non-pre-multiply data and it needn't to unify           |
| 17:16                               | R/W        |             | pre-multiply data.                                                               |
| 17.10                               | K/ W       |             | 0x1: Input layer data is non-pre-multiply data and it need to unify pre-multiply |
|                                     |            |             | data.                                                                            |
|                                     |            |             | 0x2: pre-multiply input layer                                                    |
|                                     |            |             | Other: Reserved                                                                  |
| 15:13                               | /          | /           | 1                                                                                |



| ı    |       | 1   | 1                                                                               |
|------|-------|-----|---------------------------------------------------------------------------------|
|      |       |     | LAY_FBFMT                                                                       |
|      |       |     | Input data format                                                               |
|      |       |     | 0x00: ARGB_8888                                                                 |
|      |       |     | 0x01: ABGR_8888                                                                 |
|      |       |     | 0x02: RGBA_8888                                                                 |
|      |       |     | 0x03: BGRA_8888                                                                 |
|      |       |     | 0x04: XRGB_8888                                                                 |
|      |       |     | 0x05: XBGR_8888                                                                 |
|      |       |     | 0x06: RGBX_8888                                                                 |
|      |       |     | 0x07: BGRX_8888                                                                 |
|      |       |     | 0x08: RGB_888                                                                   |
| 12:8 | R/W   | 0x0 | 0x09: BGR_888                                                                   |
|      | 1,411 |     | 0x0A: RGB_565                                                                   |
|      |       |     | 0x0B: BGR_565                                                                   |
|      |       |     | 0x0C: ARGB_4444                                                                 |
|      |       |     | 0x0D: ABGR_4444                                                                 |
|      |       |     | 0x0E: RGBA_4444                                                                 |
|      |       |     | 0x0F: BGRA 4444                                                                 |
|      |       |     | 0x10: ARGB_1555                                                                 |
|      |       |     | 0x10: ARGB_1555<br>0x11: ABGR_1555                                              |
|      |       |     |                                                                                 |
|      |       |     | 0x12: RGBA_5551                                                                 |
|      |       |     | 0x13: BGRA_5551 Other: Reserved                                                 |
| 7.5  | ,     | ,   | Other. Reserved                                                                 |
| 7:5  | /     | /   | /                                                                               |
|      |       |     | LAY_FILLCOLOR_EN                                                                |
| 4    | R/W   | 0x0 | 0: disable                                                                      |
|      |       |     | 1:enable                                                                        |
|      |       |     | When the layer fill-color is enabled, the layer data will use the fill-color.   |
| 3    | /     | /   | 1                                                                               |
|      |       |     | LAY_ALPHA_MODE                                                                  |
|      |       |     | Layer input alpha mode                                                          |
|      |       |     | 0:Ignore                                                                        |
|      |       |     | Input alpha value = pixels alpha, if no pixel alpha, the alpha value equal 0xff |
|      |       |     |                                                                                 |
| 2:1  | R/W   | 0x0 | 1:Globe alpha enable                                                            |
|      |       |     | Ignore pixel alpha value                                                        |
|      |       |     | Input alpha value = globe alpha value                                           |
|      |       |     | 2: Globe alpha mix pixel alpha                                                  |
|      |       |     | Input alpha value = globe alpha value * pixels alpha value                      |
|      |       |     | 3:Reserved                                                                      |
|      |       |     | LAY_EN                                                                          |
|      |       | 1   |                                                                                 |
|      |       |     | L Laver enable/disable                                                          |
| 0    | R/W   | 0x0 | Layer enable/disable  O: disabled                                               |
| 0    | R/W   | 0x0 | 0: disabled 1: enabled                                                          |

Note: the layer priority is layer3>layer2>layer1>layer0



# 5.10.8.2 OVL\_UI memory block size register

| Offset: 0x004+N*0x20<br>(N=0,1,2,3) |            |             | Register Name: OVL_UI_MBSIZE                     |
|-------------------------------------|------------|-------------|--------------------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                                      |
| 31:29                               | /          | /           | /                                                |
|                                     |            |             | LAY_HEIGHT                                       |
| 28:16                               | R/W        | 0x0         | Layer Height                                     |
|                                     |            |             | The Layer Height = The value of these bits add 1 |
| 15:13                               | /          | /           | /                                                |
|                                     |            |             | LAY_WIDTH                                        |
| 12:0                                | R/W        | 0x0         | Layer Width                                      |
|                                     |            |             | The Layer Width = The value of these bits add 1  |

### 5.10.8.3 OVL\_UI memory block coordinate register

| Offset: 0x008+N*0x20<br>(N=0,1,2,3) |            |             | Register Name: OVL_UI_COOR                                          |
|-------------------------------------|------------|-------------|---------------------------------------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                                                         |
|                                     |            |             | LAY_YCOOR                                                           |
| 31:16                               | R/W        | 0x0         | Y coordinate                                                        |
|                                     |            |             | Y is the left-top y coordinate of layer on overlay window in pixels |
|                                     |            |             | LAY_XCOOR                                                           |
| 15:0                                | R/W        | 0x0         | X coordinate                                                        |
|                                     |            |             | X is left-top x coordinate of the layer on overlay window in pixels |

Setting the layer0-layer3 the coordinate (left-top) on overlay window control information

### 5.10.8.4 OVL\_UI memory pitch register

| Offset: 0x00C+N*0x20<br>(N=0,1,2,3) |            |             | Register Name: OVL_UI_PITCH |
|-------------------------------------|------------|-------------|-----------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                 |
| 31:0                                | R/W        | 0x0         | LAY_PITCH                   |
| 31.0                                | N/ VV      | UXU         | Layer memory pitch in bytes |

# 5.10.8.5 OVL\_UI top field memory block low address register

| Offset: 0x010+N*0x20<br>(N=0,1,2,3) |                            |     | Register Name: OVL_UI_TOP_LADD      |
|-------------------------------------|----------------------------|-----|-------------------------------------|
| Bit                                 | Bit Read/Write Default/Hex |     | Description                         |
|                                     |                            |     | LAYMB_LADD                          |
| 31:0                                | R/W                        | 0x0 | Memory Block Start Address          |
|                                     |                            |     | Layer Memory Block Address in bytes |



### 5.10.8.6 OVL\_UI bottom field memory block low address register

| Offset: 0x014+N*0x20<br>(N=0,1,2,3) |            |             | Register Name: OVL_UI_BOT_LADD      |
|-------------------------------------|------------|-------------|-------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                         |
|                                     |            |             | LAYMB_LADD                          |
| 31:0                                | R/W        | 0x0         | Memory Block Start Address          |
|                                     |            |             | Layer Memory Block Address in bytes |

### 5.10.8.7 OVL\_UI fill color register

| Offset: 0x018+N*0x20<br>(N=0,1,2,3) |            |             | Register Name: OVL_UI_FILL_COLOR |
|-------------------------------------|------------|-------------|----------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                      |
| 21.24                               | D/M        | 0.40        | Alpha                            |
| 31:24                               | R/W        | 0x0         | Alpha fill color value           |
| 22.16                               | R/W        | 0x0         | RED                              |
| 23:16                               |            |             | Red fill color value             |
| 15.0                                | D/M        | 0x0         | GREEN                            |
| 15:8                                | R/W        |             | Green fill color value           |
| 7.0                                 | R/W        | 00          | BLUE                             |
| 7:0                                 |            | 0x0         | Blue fill color value            |

### 5.10.8.8 OVL\_UI top field memory block high address register

| Offset: 0 | x080       |             | Register Name: OVL_UI_TOP_HADD      |
|-----------|------------|-------------|-------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                         |
|           |            |             | LAY3MB_HADD                         |
| 31:24     | R/W        | 0x0         | Layer3                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAY2MB_HADD                         |
| 23:16     | R/W        | 0x0         | Layer2                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAY1MB_HADD                         |
| 15:8      | R/W        | 0x0         | Layer1                              |
|           |            |             | Layer Memory Block Address in bytes |
|           |            |             | LAY0MB_HADD                         |
| 7:0       | R/W        | 0x0         | Layer0                              |
|           |            |             | Layer Memory Block Address in bytes |

### 5.10.8.9 OVL\_UI bottom field memory block high address register

| Offset: 0x084 |            |             | Register Name: OVL_UI_BOT_HADD |
|---------------|------------|-------------|--------------------------------|
| Bit           | Read/Write | Default/Hex | Description                    |
| 31:24         | R/W        | 0x0         | LAY3MB_HADD                    |
| 31.21         |            |             | Layer3                         |



|       |     |     | Layer Memory Block Address in bytes |
|-------|-----|-----|-------------------------------------|
|       |     |     | LAY2MB_HADD                         |
| 23:16 | R/W | 0x0 | Layer2                              |
|       |     |     | Layer Memory Block Address in bytes |
|       |     |     | LAY1MB_HADD                         |
| 15:8  | R/W | 0x0 | Layer1                              |
|       |     |     | Layer Memory Block Address in bytes |
|       |     |     | LAYOMB_HADD                         |
| 7:0   | R/W | 0x0 | Layer0                              |
|       |     |     | Layer Memory Block Address in bytes |

# 5.10.8.10 OVL\_UI overlay window size register

| Offset: 0 | 0x088      |             | Register Name: OVL_UI_SIZE                         |
|-----------|------------|-------------|----------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                        |
| 31:29     | /          | /           | /                                                  |
|           |            |             | HEIGHT                                             |
| 28:16     | R/W        | 0x0         | Overlay Height                                     |
|           |            |             | The Overlay Height = The value of these bits add 1 |
| 15:13     | /          | /           | /                                                  |
|           |            |             | WIDTH                                              |
| 12:0      | R/W        | 0x0         | Overlay Width                                      |
|           |            |             | The Overlay Width = The value of these bits add 1  |

Note: When all the layers are disable the overlay has no output data, and by pass.

Channel2~4 register definition is same as OVL\_UI's register definition.

# 5.10.9 BLD Register Description

Note: all registers in BLD are double buffer.

#### 5.10.9.1 BLD fill color control register

| Offset: 0x000 |            |             | Register Name: BLD_FILL_COLOR_CTL |
|---------------|------------|-------------|-----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                       |
| 31:13         | /          | /           | /                                 |
|               |            | 0x0         | P4_EN                             |
| 12            | R/W        |             | Pipe4 enable/disable              |
| 12            | K/VV       |             | 0: disabled                       |
|               |            |             | 1: enabled                        |
|               | R/W        | 0x0         | P3_EN                             |
| 11            |            |             | Pipe3 enable/disable              |
| **            |            |             | 0: disabled                       |
|               |            |             | 1: enabled                        |
| 10            | R/W        | 0x0         | P2_EN                             |
| 10            | 11/ VV     |             | Pipe2 enable/disable              |



|     |         |       | 0: disabled                     |
|-----|---------|-------|---------------------------------|
|     |         |       | 1: enabled                      |
|     |         |       | P1_EN                           |
|     | D ///   | 00    | Pipe1 enable/disable            |
| 9   | R/W     | 0x0   | 0: disabled                     |
|     |         |       | 1: enabled                      |
|     |         |       | PO_EN                           |
| 8   | R/W     | 0x0   | Pipe0 enable/disable            |
| 0   | K/VV    | UXU   | 0: disabled                     |
|     |         |       | 1: enabled                      |
| 7:5 | /       | /     | /                               |
|     |         |       | P4_FCEN                         |
| 4   | R/W     | 0x0   | Pipe4 fill color enable/disable |
| 4   | I Ny VV | 0.00  | 0: disabled                     |
|     |         |       | 1: enabled                      |
|     |         |       | P3_FCEN                         |
| 3   | R/W     | 0x0   | Pipe3 fill color enable/disable |
|     | 1,700   | l oxo | 0: disabled                     |
|     |         |       | 1: enabled                      |
|     |         | 0x0   | P2_FCEN                         |
| 2   | R/W     |       | Pipe2 fill color enable/disable |
| _   | ","     | OXO . | 0: disabled                     |
|     |         |       | 1: enabled                      |
|     |         |       | P1_FCEN                         |
| 1   | R/W     | 0x0   | Pipe1 fill color enable/disable |
| _   | 1,7,1,  |       | 0: disabled                     |
|     |         |       | 1: enabled                      |
|     |         |       | PO_FCEN                         |
| 0   | R/W     | 0x0   | Pipe0 fill color enable/disable |
|     | '', **  |       | 0: disabled                     |
|     |         |       | 1: enabled                      |

# 5.10.9.2 BLD fill color register

| Offset: 0x004+N*0x10<br>(N=0,1,2,3,4) |            |             | Register Name: BLD_FILL_COLOR |
|---------------------------------------|------------|-------------|-------------------------------|
| Bit                                   | Read/Write | Default/Hex | Description                   |
| 31:24                                 | D /\A/     | 0x0         | Alpha                         |
| 31.24                                 | R/W        |             | Alpha fill color value        |
| 23:16                                 | R/W        | 0x0         | RED                           |
| 23.10                                 |            |             | Red fill color value          |
| 15.0                                  | D /\A/     | 0x0         | GREEN                         |
| 15:8                                  | R/W        |             | Green fill color value        |
| 7:0                                   | R/W        | 0x0         | BLUE                          |
|                                       |            |             | Blue fill color value         |



# 5.10.9.3 BLD input memory size register

| Offset: 0x008+N*0x10<br>(N=0,1,2,3,4) |            |             | Register Name: BLD_CH_ISIZE                      |
|---------------------------------------|------------|-------------|--------------------------------------------------|
| Bit                                   | Read/Write | Default/Hex | Description                                      |
| 31:29                                 | /          | /           | /                                                |
|                                       |            |             | HEIGHT                                           |
| 28:16                                 | R/W        | 0x0         | Pipe input memory height                         |
|                                       |            |             | The input height = The value of these bits add 1 |
| 15:13                                 | /          | /           | /                                                |
|                                       |            |             | WIDTH                                            |
| 12:0                                  | R/W        | 0x0         | Pipe input memory width                          |
|                                       |            |             | The input width = The value of these bits add 1  |

# 5.10.9.4 BLD input memory offset register

| Offset: 0x00C+N*0x10<br>(N=0,1,2,3,4) |                            |     | Register Name: BLD_CH_OFFSET                                                  |
|---------------------------------------|----------------------------|-----|-------------------------------------------------------------------------------|
| Bit                                   | Bit Read/Write Default/Hex |     | Description                                                                   |
|                                       |                            |     | YCOOR                                                                         |
| 31:16                                 | R/W                        | 0x0 | Y coordinate                                                                  |
|                                       |                            |     | Y is the left-top y coordinate of the pipe on blender memory window in pixels |
|                                       |                            |     | XCOOR                                                                         |
| 15:0                                  | R/W                        | 0x0 | X coordinate                                                                  |
|                                       |                            |     | X is the left-top x coordinate of the pipe on blender memory window in pixels |

# **5.10.9.5 BLD routing control register**

| Offset: 0x080 |            |             | Register Name: BLD_CH_RTCTL  |
|---------------|------------|-------------|------------------------------|
| Bit           | Read/Write | Default/Hex | Description                  |
| 31:16         | /          | /           | /                            |
|               |            |             | P3_RTCTL                     |
|               |            |             | Pipe3 select channel control |
|               |            |             | 0:from channel0              |
| 15:12         | R/W        | 0x3         | 1:from channel1              |
|               |            |             | 2:from channel2              |
|               |            |             | 3:from channel3              |
|               |            |             | Other: reserved              |
|               |            |             | P2_RTCTL                     |
|               |            |             | Pipe2 select channel control |
|               |            |             | 0:from channel0              |
| 11:8          | R/W        | 0x2         | 1:from channel1              |
|               |            |             | 2:from channel2              |
|               |            |             | 3:from channel3              |
|               |            |             | Other: reserved              |
| 7:4           | R/W        | 0x1         | P1_RTCTL                     |



|     |     |     | Pipe1 select channel control |
|-----|-----|-----|------------------------------|
|     |     |     | 0:from channel0              |
|     |     |     | 1:from channel1              |
|     |     |     | 2:from channel2              |
|     |     |     | 3:from channel3              |
|     |     |     | Other: reserved              |
|     |     |     | PO_RTCTL                     |
|     |     |     | Pipe0 select channel control |
|     |     |     | 0:from channel0              |
| 3:0 | R/W | 0x0 | 1:from channel1              |
|     |     |     | 2:from channel2              |
|     |     |     | 3:from channel3              |
|     |     |     | Other: reserved              |

Note: Setting 2 or more channels in the same pipe is illegal, programmer should confirm it.

# 5.10.9.6 BLD pre-multiply control register

| Offset: 0 | 0x084      |             | Register Name: BLD_PREMUL_CTL             |
|-----------|------------|-------------|-------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                               |
| 31:4      | /          | /           | /                                         |
|           |            |             | P3_ALPHA_MODE                             |
| 3         | R/W        | 0x0         | Pipe3 input alpha mode                    |
| 3         | I N/ VV    | UXU         | 0:all alpha data is no-pre-multiply alpha |
|           |            |             | 1:all alpha data is pre-multiply alpha    |
|           | R/W        | 0x0         | P2_ALPHA_MODE                             |
| 2         |            |             | Pipe2 input alpha mode                    |
| 2         |            |             | 0:all alpha data is no-pre-multiply alpha |
|           |            |             | 1:all alpha data is pre-multiply alpha    |
|           |            |             | P1_ALPHA_MODE                             |
| 1         | R/W        | W 0x0       | Pipe1 input alpha mode                    |
| 1         | IN, VV     |             | 0:all alpha data is no-pre-multiply alpha |
|           |            |             | 1:all alpha data is pre-multiply alpha    |
|           |            |             | PO_ALPHA_MODE                             |
| 0         | R/W        | /W 0x0      | Pipe0 input alpha mode                    |
|           |            |             | 0:all alpha data is no-pre-multiply alpha |
|           |            |             | 1:all alpha data is pre-multiply alpha    |

## 5.10.9.7 BLD background color register

| Offset: 0x088 |            |             | Register Name: BLD_BK_COLOR    |
|---------------|------------|-------------|--------------------------------|
| Bit           | Read/Write | Default/Hex | Description                    |
| 31:24         | /          | /           | /                              |
| 23:16         | R/W        | 0x0         | RED Red background color value |
| 15:8          | R/W        | 0x0         | GREEN                          |



|     |     |     | Green background color value |
|-----|-----|-----|------------------------------|
| 7:0 | R/W | 0x0 | BLUE                         |
|     |     |     | Blue background color value  |

# 5.10.9.8 BLD output size setting register

| Offset: 0 | 0x08C      |             | Register Name: BLD_SIZE                                 |
|-----------|------------|-------------|---------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                             |
| 31:29     | /          | /           | /                                                       |
|           |            |             | BLD_HEIGHT                                              |
| 28:16     | R/W        | 0x0         | Blender height                                          |
|           |            |             | The real blender height = The value of these bits add 1 |
| 15:13     | /          | /           | /                                                       |
|           |            |             | BLD_WIDTH                                               |
| 12:0      | R/W        | 0x0         | Blender width                                           |
|           |            |             | The real blender width = The value of these bits add 1  |

# 5.10.9.9 BLD control register

| Offset: |            |             |                                                                        |
|---------|------------|-------------|------------------------------------------------------------------------|
| Blender | 0: 0x090   |             |                                                                        |
| Blender | 1: 0x094   |             | Register Name: BLD_CTL                                                 |
| Blender | 2: 0x098   |             |                                                                        |
| Blender | 3: 0x09C   |             |                                                                        |
| Bit     | Read/Write | Default/Hex | Description                                                            |
| 31:28   | /          | /           | 1                                                                      |
|         |            |             | BLEND_AFD                                                              |
|         |            |             | Specifies the coefficient that used in destination alpha data $Q_d$ .  |
|         |            |             | 0x0: 0                                                                 |
| 27:24   | R/W        | 0x3         | 0x1: 1                                                                 |
|         |            |             | 0x2: A <sub>s</sub>                                                    |
|         |            |             | 0x3: 1-A <sub>s</sub>                                                  |
|         |            |             | Other: Reserved                                                        |
| 23:20   | /          | /           | 1                                                                      |
|         |            |             | BLEND_AFS                                                              |
|         |            |             | Specifies the coefficient that used in source alpha data $Q_{\rm s}$ . |
|         |            |             | 0x0: 0                                                                 |
| 19:16   | R/W        | 0x1         | 0x1: 1                                                                 |
|         |            |             | 0x2: A <sub>d</sub>                                                    |
|         |            |             | 0x3: 1-A <sub>d</sub>                                                  |
|         |            |             | Other: Reserved                                                        |
| 15:12   | /          | /           | 1                                                                      |
|         |            |             | BLEND_PFD                                                              |
| 11:8    | R/W        | 0x3         | Specifies the coefficient that used in destination pixel data $F_d$ .  |
|         |            |             | 0x0: 0                                                                 |



|     |     |     | 0x1: 1                                                           |
|-----|-----|-----|------------------------------------------------------------------|
|     |     |     | 0x2: A <sub>s</sub>                                              |
|     |     |     | 0x3: 1-A <sub>s</sub>                                            |
|     |     |     | Other: Reserved                                                  |
| 7:4 | /   | /   | /                                                                |
|     |     |     | BLEND_PFS                                                        |
|     |     |     | Specifies the coefficient that used in source pixel data $F_s$ . |
|     |     |     | 0x0: 0                                                           |
| 3:0 | R/W | 0x1 | 0x1: 1                                                           |
|     |     |     | 0x2: A <sub>d</sub>                                              |
|     |     |     | 0x3: 1-A <sub>d</sub>                                            |
|     |     |     | Other: Reserved                                                  |

## 5.10.9.10 BLD color key control register

| Offset: 0 | Offset: 0x0B0 |             | Register Name: BLD_KEY_CTL                                                    |
|-----------|---------------|-------------|-------------------------------------------------------------------------------|
| Bit       | Read/Write    | Default/Hex | Description                                                                   |
| 31:15     | /             | /           |                                                                               |
|           |               |             | KEY3_MATCH_DIR                                                                |
|           |               |             | In Alpha Blender3                                                             |
|           |               |             | 0: when the pixel value matches destination image, it displays the pixel form |
| 14:13     | R/W           | 0x0         | source image.                                                                 |
|           |               |             | 1: when the pixel value matches source image, it displays the pixel form      |
|           |               |             | destination image.                                                            |
|           |               |             | 1x: Reserved                                                                  |
|           |               |             | KEY3_EN                                                                       |
| 12        | R/W           | 0x0         | Enable color key                                                              |
| 12        | I IV, VV      | 0.00        | 0: disabled color key                                                         |
|           |               |             | 1: enable color key in Alpha Blender3.                                        |
| 11        | 1             | /           | /                                                                             |
|           |               |             | KEY2_MATCH_DIR                                                                |
|           |               |             | In Alpha Blender2                                                             |
|           |               |             | 0: when the pixel value matches destination image, it displays the pixel form |
| 10:9      | R/W           | 0x0         | source image.                                                                 |
|           |               |             | 1: when the pixel value matches source image, it displays the pixel form      |
|           |               |             | destination image.                                                            |
|           |               |             | 1x: Reserved                                                                  |
|           |               |             | KEY2_EN                                                                       |
| 8         | R/W           | 0x0         | Enable color key                                                              |
|           | .,            |             | 0: disabled color key                                                         |
|           |               |             | 1: enable color key in Alpha Blender2.                                        |
| 7         | /             | /           |                                                                               |
|           |               |             | KEY1_MATCH_DIR                                                                |
| 6:5       | R/W           | 0x0         | In Alpha Blender1                                                             |
| 5.5       |               |             | 0: when the pixel value matches destination image, it displays the pixel form |
|           |               |             | source image.                                                                 |



|     |        |     | 1: when the pixel value matches source image, it displays the pixel form      |
|-----|--------|-----|-------------------------------------------------------------------------------|
|     |        |     | destination image.                                                            |
|     |        |     | 1x: Reserved                                                                  |
|     |        |     | KEY1_EN                                                                       |
| 4   | R/W    | 0x0 | Enable color key                                                              |
| 4   | K/ VV  | UXU | 0: disabled color key                                                         |
|     |        |     | 1: enable color key in Alpha Blender1.                                        |
| 3   | /      | /   |                                                                               |
|     |        | 0x0 | KEYO_MATCH_DIR                                                                |
|     |        |     | In Alpha Blender0                                                             |
|     |        |     | 0: when the pixel value matches destination image, it displays the pixel form |
| 2:1 | R/W    |     | source image.                                                                 |
|     |        |     | 1: when the pixel value matches source image, it displays the pixel form      |
|     |        |     | destination image.                                                            |
|     |        |     | 1x: Reserved                                                                  |
|     |        | 0x0 | KEYO_EN                                                                       |
| 0   | D ()A/ |     | Enable color key                                                              |
|     | R/W    |     | 0: disabled color key                                                         |
|     |        |     | 1: enable color key in Alpha Blender0.                                        |

# 5.10.9.11 BLD color key configuration register

| Offset: 0 | 0x0B4      |             | Register Name: BLD_KEY_CON                                                                                                      |
|-----------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                                                                                                     |
| 31:27     | /          | /           | /                                                                                                                               |
|           |            |             | KEY3R_MATCH                                                                                                                     |
|           |            |             | Red Match Rule                                                                                                                  |
| 26        | D /\A/     | 0x0         | 0: match if (Color Min= <color<=color condition="" else="" is="" max)="" red="" td="" the="" the<="" true,=""></color<=color>   |
| 20        | R/W        | UXU         | condition is false.                                                                                                             |
|           |            |             | 1: match if (Color>Color Max or Color <color condition="" else<="" is="" min)="" red="" td="" the="" true,=""></color>          |
|           |            |             | the condition is false.                                                                                                         |
|           |            |             | KEY3G_MATCH                                                                                                                     |
|           |            | 0x0         | Green Match Rule                                                                                                                |
| 25        | R/W        |             | 0: match if (Color Min= <color<=color condition="" else="" green="" is="" max)="" td="" the="" the<="" true,=""></color<=color> |
| 23        |            |             | condition is false.                                                                                                             |
|           |            |             | 1: match if (Color>Color Max or Color <color condition="" green="" is="" min)="" td="" the="" true,<=""></color>                |
|           |            |             | else the condition is false.                                                                                                    |
|           |            |             | KEY3B_MATCH                                                                                                                     |
|           |            | 0x0         | Blue Match Rule                                                                                                                 |
| 24        | R/W        |             | 0: match if (Color Min= <color<=color blue="" condition="" else="" is="" max)="" td="" the="" the<="" true,=""></color<=color>  |
| 24        | I N/ VV    | UXU         | condition is false.                                                                                                             |
|           |            |             | 1: match if (Color>Color Max or Color <color blue="" condition="" else<="" is="" min)="" td="" the="" true,=""></color>         |
|           |            |             | the condition is false.                                                                                                         |
| 23:19     | /          | /           | /                                                                                                                               |
| 10        | D /\A/     | 0v0         | KEY2R_MATCH                                                                                                                     |
| 18        | R/W        | 0x0         | Red Match Rule                                                                                                                  |



| I     | I      |      | Or match if (Color Min- Color Color May) the red condition is true also the                                                      |
|-------|--------|------|----------------------------------------------------------------------------------------------------------------------------------|
|       |        |      | 0: match if (Color Min= <color<=color condition="" else="" false.<="" is="" max)="" red="" td="" the="" true,=""></color<=color> |
|       |        |      |                                                                                                                                  |
|       |        |      | 1: match if (Color>Color Max or Color <color condition="" else<="" is="" min)="" red="" td="" the="" true,=""></color>           |
|       |        |      | the condition is false.                                                                                                          |
|       |        |      | KEY2G_MATCH                                                                                                                      |
|       |        |      | Green Match Rule                                                                                                                 |
| 17    | R/W    | 0x0  | 0: match if (Color Min= <color<=color condition="" else="" green="" is="" max)="" td="" the="" the<="" true,=""></color<=color>  |
|       |        |      | condition is false.                                                                                                              |
|       |        |      | 1: match if (Color>Color Max or Color <color condition="" green="" is="" min)="" td="" the="" true,<=""></color>                 |
|       |        |      | else the condition is false.                                                                                                     |
|       |        |      | KEY2B_MATCH                                                                                                                      |
|       |        |      | Blue Match Rule                                                                                                                  |
| 16    | R/W    | 0x0  | 0: match if (Color Min= <color<=color blue="" condition="" else="" is="" max)="" td="" the="" the<="" true,=""></color<=color>   |
|       | 1.,    |      | condition is false.                                                                                                              |
|       |        |      | 1: match if (Color>Color Max or Color <color blue="" condition="" else<="" is="" min)="" td="" the="" true,=""></color>          |
|       |        |      | the condition is false.                                                                                                          |
| 15:11 | /      | /    | /                                                                                                                                |
|       |        |      | KEY1R_MATCH                                                                                                                      |
|       |        |      | Red Match Rule                                                                                                                   |
| 10    | R/W    | 0x0  | 0: match if (Color Min= <color<=color condition="" else="" is="" max)="" red="" td="" the="" the<="" true,=""></color<=color>    |
| 10    | 11,700 | 0.00 | condition is false.                                                                                                              |
|       |        |      | 1: match if (Color>Color Max or Color <color condition="" else<="" is="" min)="" red="" td="" the="" true,=""></color>           |
|       |        |      | the condition is false.                                                                                                          |
|       |        |      | KEY1G_MATCH                                                                                                                      |
|       |        |      | Green Match Rule                                                                                                                 |
| 9     | R/W    | 0x0  | 0: match if (Color Min= <color<=color condition="" else="" green="" is="" max)="" td="" the="" the<="" true,=""></color<=color>  |
| 9     | N/ VV  | 000  | condition is false.                                                                                                              |
|       |        |      | 1: match if (Color>Color Max or Color <color condition="" green="" is="" min)="" td="" the="" true,<=""></color>                 |
|       |        |      | else the condition is false.                                                                                                     |
|       |        |      | KEY1B_MATCH                                                                                                                      |
|       |        |      | Blue Match Rule                                                                                                                  |
|       | D ///  | 0.0  | 0: match if (Color Min= <color<=color blue="" condition="" else="" is="" max)="" td="" the="" the<="" true,=""></color<=color>   |
| 8     | R/W    | 0x0  | condition is false.                                                                                                              |
|       |        |      | 1: match if (Color>Color Max or Color <color blue="" condition="" else<="" is="" min)="" td="" the="" true,=""></color>          |
|       |        |      | the condition is false.                                                                                                          |
| 7:3   | /      | /    | /                                                                                                                                |
|       |        |      | KEYOR_MATCH                                                                                                                      |
|       |        |      | Red Match Rule                                                                                                                   |
| ]     | D //4/ | 00   | 0: match if (Color Min= <color<=color condition="" else="" is="" max)="" red="" td="" the="" the<="" true,=""></color<=color>    |
| 2     | R/W    | 0x0  | condition is false.                                                                                                              |
|       |        |      | 1: match if (Color>Color Max or Color <color condition="" else<="" is="" min)="" red="" td="" the="" true,=""></color>           |
|       |        |      | the condition is false.                                                                                                          |
|       |        |      | KEYOG_MATCH                                                                                                                      |
|       |        | 0x0  | Green Match Rule                                                                                                                 |
| 1     | R/W    |      | 0: match if (Color Min= <color<=color condition="" else="" green="" is="" max)="" td="" the="" the<="" true,=""></color<=color>  |
|       |        |      | condition is false.                                                                                                              |
|       |        | 1    |                                                                                                                                  |



|   |     |     | 1: match if (Color>Color Max or Color <color condition="" else="" false.<="" green="" is="" min)="" th="" the="" true,=""></color> |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 0 | R/W | 0x0 | KEYOB_MATCH                                                                                                                        |
|   |     |     | Blue Match Rule                                                                                                                    |
|   |     |     | 0: match if (Color Min= <color<=color blue="" condition="" else="" is="" max)="" td="" the="" the<="" true,=""></color<=color>     |
|   |     |     | condition is false.                                                                                                                |
|   |     |     | 1: match if (Color>Color Max or Color <color blue="" condition="" else<="" is="" min)="" td="" the="" true,=""></color>            |
|   |     |     | the condition is false.                                                                                                            |

Note: when R/G/B channel condition is true the color pass through otherwise is false.

# 5.10.9.12 BLD color key max register

| Offset: CK0: 0x0C0 CK1: 0x0C4 CK2: 0x0C8 CK3: 0x0CC |     |             | Register Name: BLD_KEY_MAX      |
|-----------------------------------------------------|-----|-------------|---------------------------------|
| Bit Read/Write Default/Hex                          |     | Default/Hex | Description                     |
| 31:24                                               | /   | /           | /                               |
| 23:16                                               | R/W | 0x0         | MAX_R Red Red color key max     |
| 15:8                                                | R/W | 0x0         | MAX_G Green Green color key max |
| 7:0                                                 | R/W | 0x0         | MAX_B Blue Blue color key max   |

# 5.10.9.13 BLD color key min register

| Offset:    |            |             |                            |  |
|------------|------------|-------------|----------------------------|--|
| CK0: 0x0E0 |            |             |                            |  |
| CK1: 0x0   | DE4        |             | Register Name: BLD_KEY_MIN |  |
| CK2: 0x0   | DE8        |             |                            |  |
| CK3: 0x0   | DEC        |             |                            |  |
| Bit        | Read/Write | Default/Hex | Description                |  |
| 31:24      | /          | /           | /                          |  |
|            |            |             | MIN_R                      |  |
| 23:16      | R/W        | 0x0         | Red                        |  |
|            |            |             | Red color key min          |  |
|            |            |             | MIN_G                      |  |
| 15:8       | R/W        | 0x0         | Green                      |  |
|            |            |             | Green color key min        |  |
| 7:0        | R/W        | 0x0         | MIN_B                      |  |



|  | Blue               |
|--|--------------------|
|  | Blue color key min |

# 5.10.9.14 BLD output color control register

| Offset: | Offset: 0x0FC |             | Register Name: BLD_OUT_COLOR                                              |  |
|---------|---------------|-------------|---------------------------------------------------------------------------|--|
| Bit     | Read/Write    | Default/Hex | Description                                                               |  |
| 31:2    | /             | /           | /                                                                         |  |
|         |               |             | ITLMOD_EN                                                                 |  |
|         |               |             | Output interlace mode enable                                              |  |
| 1       | R/W           | 0x0         | 0:disable                                                                 |  |
| 1       |               |             | 1:enable                                                                  |  |
|         |               |             | When output interlace mode software programmer should confirm the blender |  |
|         |               |             | output height is even.                                                    |  |
|         |               | 0x0         | PREMUL_EN                                                                 |  |
| 0       | R/W           |             | Output color control                                                      |  |
| 0       | I N/ VV       |             | 0: output normal data(A ' will be A <sub>abcde</sub> ')                   |  |
|         |               |             | 1: output pre-multiply data(A ' = 1)                                      |  |



# 5.11 DE RT-WB Controller Specification

#### 5.11.1 Overview

The Real-time write-back controller (RT-WB) provides data capture function for display engine. It captures data from RT-mixer module, performs the image resizing function, and then write-back to SDRAM.

The RT-WB can receive RGB888 or YUV444 data format, and then converts to YV12/NV12/NV21 or interleaved RGB888/pRGB888/pBGR888 for write-back. Horizontal and vertical direction scaling-down are implemented independently.

The RT-WB features:

Parameter name

FINE SCALE EXIST

PORT NUM

M FRAC

Support RGB888 and YUV444 input data format

Default 2048

1

4 16

18

- Support input size from 8×4 to 4096×4096
- Support output size from 8×4 to W×4096 (W is RTL programmable)

16

18

- Support fine down scaling ratio from 1x to 1/2x, and the anti-aliasing filter is 16-phase 4-tap in horizontal, 16-phase 2-tap filter in vertical.
- Support coarse down scaling.

| Possible value | Description                      |  |
|----------------|----------------------------------|--|
| 1280/2048/4096 | 3 channels line buffer length    |  |
| 1/0            | Define fine scaler exist or not. |  |
| 2/4/8          | Input port number                |  |

Phase adder fraction part bit width

Phase number

Table 5-1. RTL programmable parameters table

## 5.11.2 Block Diagram



Figure 5-7. RT-WB Block Diagram

### 5.11.3 Operations and Function Descriptions

#### 5.11.3.1 Write-back flow

The main flow when new frame starts description in Figure 5-8.

The new frame starts with a positive edge of *START*, which is a input from RT-TOP. RT-WB module will check signals like BUSY, OVERFLOW, FINISH to determine the last frame is success to write-back or not. If BUSY is still 1, TIME\_OUT will be set, and users will know that the last frame did not write-back successfully. The OVERFLOW is also a error status signal.



It represents the module is too slow to write-back all the data to memory bus in last frame. These two errors will cause a local reset action to clear the whole scaler and some parts in DMA circuit.

A write-back address switch circuit can select the next write-back address automatically. The detail switch function description in Figure 5-9.

After local reset action or address switch, the circuit will check the WB\_START is set or not. When WB\_START is 1, the write-back function will be activated and this frame will be processed.



Figure 5-8. The main control flow of RT-WB





Figure 5-9. Write-back address switch function

# 5.11.3.2 Key signal and key register

| Signal       | Туре               | Description                               | Note                                                                                                                                              |
|--------------|--------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| BUSY         | Read only register | Scaler or DMA busy status                 | Becomes 1 when WB_START takes effect, becomes 0 when FIFO overflowed,write-back time-out or write-back finished, or local reset, or global reset. |
| WB_START     | R/W register       | Write-back enable register                | Set 1 to start a new frame write-back, becomes 0 when write-back started, or global reset.                                                        |
| SYNC         | Input signal       | New frame start signal from RT TOP module | Negative edge of SYNC represents a new display frame.                                                                                             |
| OVERFLOW     | R/W register       | FIFO overflowed flag                      | Becomes 1 when FIFO overflowed ( write-back too slow), becomes 0 when write 1 to it, or global reset.                                             |
| FINISH       | R/W register       | Write-back successful finish              | Becomes 1 when write-back finished successfully, becomes 0 when write 1 to it, or global reset.                                                   |
| TIME_OUT     | R/W register       | Write-back time out flag                  | When SYNC negative edge comes, write-back has not finished yet , this bit will set 1.  Becomes 0 when write 1 to it, or global reset.             |
| WRITED       | Internal<br>signal | One frame has been written-back           | Becomes 1 when WB_START takes effect, becomes 0 when next SYNC negative edge comes, or global reset.                                              |
| IRQ          | R/W register       | Write-back end flag                       | When WRITED negative edge comes, IRQ becomes 1, becomes 0 when write 1 to it, or global reset.                                                    |
| INTR         | Output signal      | Interrupt signal to GIC module            | INTR = IRQ & INT_EN                                                                                                                               |
| GLOBAL RESET | Input signal       | Global reset from RT TOP module           | Clear the whole scaler circuit, some parts of DMA circuit, and status register/WB_START.                                                          |



| AUTO SWITCH  | R/W register | Write-back address automatic switch enable | Set 1 to enable function, set 0 to disable.                                                                                                                                                       |
|--------------|--------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CUR_ADDRx    | Internal     | Channel x current write back               |                                                                                                                                                                                                   |
| (x=0,1,2)    | register     | start address                              |                                                                                                                                                                                                   |
| AUTO_GATE_EN | R/W register | Enable automatic gating clock.             | Set 1 to enable function, set 0 to disable. If AUTO_GATE_EN==1, when module idle, the clock to scaler and DMA will be gated. And when a write-back frame starts, the clock gate will be released. |
| CLK_GATE     | R/W register | Clock gate of scaler and DMA module        | If AUTO_GATE_EN==0, set 1 to release clock, set 0 to gating clock. No use when AUTO_GATE_EN==1.                                                                                                   |

# **5.11.4** RT-WB Register List

| Module name | Memory Range | Offset Address |
|-------------|--------------|----------------|
| RT-WB       | 64K          | 0x01010000     |

| Register name      | Offset | Description                                   |
|--------------------|--------|-----------------------------------------------|
| WB_GCTRL_REG       | 0x000  | Module general control register               |
| WB_SIZE_REG        | 0x004  | Input size register                           |
| WB_CROP_COORD_REG  | 0x008  | Cropping coordinate register                  |
| WB_CROP_SIZE_REG   | 0x00c  | Cropping size register                        |
| WB_A_CH0_ADDR_REG  | 0x010  | Write-back Group A channel 0 address register |
| WB_A_CH1_ADDR_REG  | 0x014  | Write-back Group A channel 1 address register |
| WB_A_CH2_ADDR_REG  | 0x018  | Write-back Group A channel 2 address register |
| WB_A_HIGH_ADDR_REG | 0x01c  | Write-back Group A address high bit register  |
| WB_B_CH0_ADDR_REG  | 0x020  | Write-back Group B channel 0 address register |
| WB_B_CH1_ADDR_REG  | 0x024  | Write-back Group B channel 1 address register |
| WB_B_CH2_ADDR_REG  | 0x028  | Write-back Group B channel 2 address register |
| WB_B_HIGH_ADDR_REG | 0x02c  | Write-back Group B address high bit register  |
| WB_CH0_PITCH_REG   | 0x030  | Write-back channel 0 pitch register           |
| WB_CH12_PITCH_REG  | 0x034  | Write-back channel 1/2 pitch register         |
| WB_ADDR_SWITCH_REG | 0x040  | Write-back address switch setting register    |
| WB_FORMAT_REG      | 0x044  | Output format register                        |
| WB_INT_REG         | 0x048  | Interrupt control register                    |
| WB_STATUS_REG      | 0x04c  | Module status register                        |
|                    |        |                                               |
| WB_BYPASS_REG      | 0x054  | Bypass control register                       |
| WB_CS_HORZ_REG     | 0x070  | Coarse scaling horizontal setting register    |
| WB_CS_VERT_REG     | 0x074  | Coarse scaling vertical setting register      |
| WB_FS_INSIZE_REG   | 0x080  | Fine scaling input size register              |
| WB_FS_OUTSIZE_REG  | 0x084  | Fine scaling output size register             |
| WB_FS_HSTEP_REG    | 0x088  | Fine scaling horizontal step register         |



| WB_FS_VSTEP_REG   | 0x08C       | Fine scaling vertical step register                 |
|-------------------|-------------|-----------------------------------------------------|
| WB_DEBUG_REG      | 0x0FC       | Debug register                                      |
|                   |             |                                                     |
| WB_CH0_HCOEF_REGN | 0x200 + N*4 | Channel 0 horizontal coefficient register N ( N =   |
|                   |             | 0,1,2,,15)                                          |
| WB_CH1_HCOEF_REGN | 0x280 + N*4 | Channel 1/2 horizontal coefficient register N ( N = |
|                   |             | 0,1,2,,15)                                          |

Note: None of these registers is double-buffer.

# **5.11.5 RT-WB Register Description**

## **5.11.5.1 WB\_GCTRL\_REG**

| Offset: 0X000 |            |             | Register name: WB_GCTRL_REG         |
|---------------|------------|-------------|-------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                         |
|               |            |             | BIST_EN                             |
| 24            | D (M)      | 00          | Enable BIST mode                    |
| 31            | R/W        | 0x0         | 0: Disable                          |
|               |            |             | 1: Enable                           |
| 30:           | /          | /           | /                                   |
|               |            |             | CLK_GATE                            |
| 20            | D (M)      | 0.0         | Clock gate of scaler and DMA module |
| 29            | R/W        | 0x0         | 0: Gate                             |
|               |            |             | 1: Release                          |
|               |            |             | AUTO_GATE_EN                        |
| 20            | D (M)      | 00          | Enable automatic clock gating       |
| 28            | R/W        | 0x0         | 0: Disable                          |
|               |            |             | 1: Enable                           |
| 27:18         | /          | /           | /                                   |
|               |            |             | IN_PORT_SEL                         |
|               |            |             | Input port selection                |
| 17:16         | D (M)      | 0x0         | 0: port 0                           |
| 17.10         | R/W        | UXU         | 1: port 1                           |
|               |            |             | 2: port 2                           |
|               |            |             | 3: port 3                           |
| 15:5          | /          | /           | /                                   |
|               |            |             | SOFT_RESET                          |
| 4             | R/W        | 0x0         | Reset the whole scaler and DMA.     |
| 4             | K/ VV      | UXU         | 0:Reset release.                    |
|               |            |             | 1:Reset hold.                       |
| 3:1           | /          | /           | /                                   |
|               |            | 0x0         | WB_START                            |
| 0             | R/W        |             | Start write-back process.           |
| 0             |            |             | 0: Do nothing.                      |
|               |            |             | 1: Start.                           |



# **5.11.5.2 WB\_SIZE\_REG**

| Offset: 0X004 |            |             | Register name: WB_SIZE_REG                           |  |
|---------------|------------|-------------|------------------------------------------------------|--|
| Bit           | Read/Write | Default/Hex | Description                                          |  |
| 31:29         | /          | /           | /                                                    |  |
|               |            |             | HEIGHT                                               |  |
| 28:16         | R/W        | 0x0         | Input height                                         |  |
|               |            |             | The real input height = The value of these bits + 1. |  |
| 15:13         | /          | /           | /                                                    |  |
|               |            |             | WIDTH                                                |  |
| 12:0          | R/W        | 0x0         | Input width                                          |  |
|               |            |             | The real input width = The value of these bits + 1.  |  |

# 5.11.5.3 WB\_CROP\_COORD\_REG

| Offset: 0X008 |            |             | Register name: WB_CROP_COORD_REG                                    |
|---------------|------------|-------------|---------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                         |
| 31:29         | /          | /           | /                                                                   |
|               |            |             | CROP_TOP                                                            |
| 28:16         | R/W        | 0x0         | Cropping top position                                               |
|               |            |             | Top position is the left-top y coordinate of input window in pixels |
| 15:13         | /          | /           | /                                                                   |
|               |            |             | CROP_LEFT                                                           |
| 12:0          | R/W        | 0x0         | Cropping left position                                              |
|               |            |             | Left position is left-top x coordinate of input window in pixels    |

## 5.11.5.4 WB\_CROP\_SIZE\_REG

| Offset: 0X00C |            |             | Register name: WB_CROP_SIZE_REG                                |
|---------------|------------|-------------|----------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                    |
| 31:29         | /          | /           | /                                                              |
|               |            |             | CROP_HEIGHT                                                    |
| 28:16         | R/W        | 0x0         | Cropping region height                                         |
|               |            |             | The real cropping region height = the value of these bits + 1. |
| 15:13         | /          | /           | /                                                              |
|               |            |             | CROP_WIDTH                                                     |
| 12:0          | R/W        | 0x0         | Cropping region width                                          |
|               |            |             | The real cropping region width = the value of these bits + 1.  |

## 5.11.5.5 WB\_A\_CH0\_ADDR\_REG

| Offset: 0X010 |            |             | Register name: WB_A_CH0_ADDR_REG |
|---------------|------------|-------------|----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                      |
| 31:0          | R/W        | 0x0         | ADDR                             |



|  | Note: In BYTE.                                         |
|--|--------------------------------------------------------|
|  | When output format is RGB, ADDR must 4 bytes aligning. |

## 5.11.5.6 WB\_A\_CH1\_ADDR\_REG

| Offset: 0X014 |            |             | Register name: WB_A_CH1_ADDR_REG |
|---------------|------------|-------------|----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                      |
| 31:0          | R/W        | 0x0         | ADDR                             |
| 31.0          | r/ vv      | UXU         | Note: In BYTE.                   |

## 5.11.5.7 WB\_A\_CH2\_ADDR\_REG

| Offset: 0X018 |            |             | Register name: WB_A_CH2_ADDR_REG |
|---------------|------------|-------------|----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                      |
| 31:0          | R/W        | 0           | ADDR                             |
| 31.0          | r/ vv      | U           | Note: In BYTE.                   |

## 5.11.5.8 WB\_A\_HIGH\_ADDR\_REG

| Offset: 0X01C |            |             | Register name: WB_A_HIGH_ADDR_REG |
|---------------|------------|-------------|-----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                       |
| 31:24         | /          | /           | 1                                 |
| 23:16         | R/W        | 0x0         | CH2_H_ADDR                        |
| 15:8          | R/W        | 0x0         | CH1_H_ADDR                        |
| 7:0           | R/W        | 0x0         | CH0_H_ADDR                        |

### 5.11.5.9 WB\_B\_CH0\_ADDR\_REG

| Offset: 0X020 |            |             | Register name: WB_B_CH0_ADDR_REG                       |
|---------------|------------|-------------|--------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                            |
|               |            |             | ADDR                                                   |
| 31:00         | R/W        | 0x0         | Note: In BYTE.                                         |
|               |            |             | When output format is RGB, ADDR must 4 bytes aligning. |

## 5.11.5.10 WB\_B\_CH1\_ADDR\_REG

| Offset: 0X024 |            |             | Register name: WB_B_CH1_ADDR_REG |
|---------------|------------|-------------|----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                      |
| 31:0          | R/W        | 0x0         | ADDR                             |
| 31:0          |            |             | Note: In BYTE.                   |

## 5.11.5.11 WB\_B\_CH2\_ADDR\_REG

| Offset: 0X028 |            |             | Register name: WB_B_CH2_ADDR_REG |
|---------------|------------|-------------|----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                      |
| 21.0          | R/W        | 0.40        | ADDR                             |
| 31:0          | K/VV       | 0x0         | Note: In BYTE.                   |



## 5.11.5.12 WB\_B\_HIGH\_ADDR\_REG

| Offset: 0 | X02C       |             | Register name: WB_B_HIGH_ADDR_REG |
|-----------|------------|-------------|-----------------------------------|
| Bit       | Read/Write | Default/Hex | Description                       |
| 31:24     | /          | /           | 1                                 |
| 23:16     | R/W        | 0x0         | CH2_H_ADDR                        |
| 15:8      | R/W        | 0x0         | CH1_H_ADDR                        |
| 7:0       | R/W        | 0x0         | CH0_H_ADDR                        |

## 5.11.5.13 WB\_CH0\_PITCH\_REG

| Offset: | 0X030      |             | Register name: WB_CH0_PITCH_REG     |
|---------|------------|-------------|-------------------------------------|
| Bit     | Read/Write | Default/Hex | Description                         |
| 21.0    | R/W        | 0x0         | PITCH                               |
| 31:0    |            |             | Write-back channel 0 pitch in BYTE. |

## 5.11.5.14 WB\_CH12\_PITCH\_REG

| Offset: 0X034 |            |             | Register name: WBC_CH12_PITCH_REG     |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
| 24.0          | D /\A/     | 00          | PITCH                                 |
| 31:0          | R/W        | 0x0         | Write-back channel 1/2 pitch in BYTE. |

## 5.11.5.15 WB\_ADDR\_SWITCH\_REG

| Offset: 0 | X040       |             | Register name: WB_ADDR_SWITCH_REG                                   |
|-----------|------------|-------------|---------------------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                                         |
| 31:21     | /          | /           | /                                                                   |
|           |            |             | MANUAL_GROUP                                                        |
| 20        | D /\A/     | 0x0         | When AUTO_SWITCH is 0, set this bit will switch the group.          |
| 20        | R/W        | UXU         | 0: Group A                                                          |
|           |            |             | 1: Group B                                                          |
| 19:17     | /          | /           | /                                                                   |
|           |            | 0x0         | AUTO_SWITCH                                                         |
| 16        | D /\A/     |             | Write-back address automatic switch enable                          |
| 10        | R/W        |             | 0: Disable                                                          |
|           |            |             | 1: Enable                                                           |
| 15:01     | /          | /           | /                                                                   |
|           |            |             | CUR_GROUP                                                           |
| 0         | R          | 0x0         | When AUTO_SWITCH is 1, this bit will show the index of group using. |
| 0         |            |             | 0: Group A                                                          |
|           |            |             | 1: Group B                                                          |

## **5.11.5.16 WB\_FORMAT\_REG**

| Offset: 0X044 |            |             | Register name: WB_FORMAT_REG |
|---------------|------------|-------------|------------------------------|
| Bit           | Read/Write | Default/Hex | Description                  |



| 31:04 | /      | /   | /                                                              |
|-------|--------|-----|----------------------------------------------------------------|
|       |        |     | FORMAT                                                         |
|       |        |     | Output format selection                                        |
|       |        |     | 0000: RGB888 (R in high address)                               |
|       |        |     | 0001: BGR888 (B in high address)                               |
|       |        |     | 0010: Reserved                                                 |
|       |        |     | 0011: Reserved                                                 |
|       |        |     | 0100: pRGB888(pad equal to 0xff)(p in high address)            |
|       |        | 0x0 | 0101: pBGR888(pad equal to 0xff)(p in high address)            |
| 03:0  | R/W    |     | 0110: BGRp888(pad equal to 0xff)(B in high address)            |
| 03.0  | IN/ VV |     | 0111: RGBp888(pad equal to 0xff)(R in high address)            |
|       |        |     | 1000:Planar YUV420                                             |
|       |        |     | 1001:Reserved                                                  |
|       |        |     | 1010:Reserved                                                  |
|       |        |     | 1011:Reserved                                                  |
|       |        |     | 1100:Planar YUV420 UV combined ( V1U1V0U0, V1 in high address) |
|       |        |     | 1101:Planar YUV420 UV combined ( U1V1U0V0, U1 in high address) |
|       |        |     | 1110:Reserved                                                  |
|       |        |     | 1111:Reserved                                                  |

## 5.11.5.17 WB\_INT\_REG

| Offset: 0X048 |            |             | Register name: WB_INT_REG   |
|---------------|------------|-------------|-----------------------------|
| Bit           | Read/Write | Default/Hex | Description                 |
| 31:1          | /          | /           | /                           |
| 0             | R/W        | 0x0         | INT_EN                      |
|               |            |             | Write-back interrupt enable |
|               |            |             | 0: Disable                  |
|               |            |             | 1: Enable                   |

# **5.11.5.18 WB\_STATUS\_REG**

| Offset: 0 | X04C       |             | Register name: WB_STATUS_REG            |
|-----------|------------|-------------|-----------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                             |
| 31:09     | /          | /           | /                                       |
|           |            |             | BUSY                                    |
| 8         | R          | 0x0         | Write-back process status               |
| 0         | K          | UXU         | 0: write-back end or write-back disable |
|           |            |             | 1: write-back in process                |
| 7         | /          | /           | /                                       |
|           |            | 0x0         | TIME_OUT                                |
| 6         | R/W        |             | Write-back TIME_OUT error flag          |
| 0         | IV VV      |             | 0: No error                             |
|           |            |             | 1: Error                                |
| 5         | R/W        | 0x0         | OVERFLOW                                |
| J         | n/ vv      |             | Write-back FIFO overflow error flag     |



|     |       |     | 0: No error                         |
|-----|-------|-----|-------------------------------------|
|     |       |     | 1: Error                            |
|     |       |     | FINISH                              |
| 4   | R/W   | 0x0 | Write-back process finish flag      |
| 4   | K/ VV |     | 0: write-back not finish or fail    |
|     |       |     | 1: write-back finished successfully |
| 3:1 | /     | /   | /                                   |
|     |       |     | IRQ                                 |
| 0   | R/W   | 0x0 | Write-back process end flag         |
|     |       |     | 0: write-back not end               |
|     |       |     | 1: write-back end                   |

# **5.11.5.19 WB\_BYPASS\_REG**

| Offset: | 0x054      |             | Register Name: WB_BYPASS_REG               |
|---------|------------|-------------|--------------------------------------------|
| Bit     | Read/Write | Default/Hex | Description                                |
| 31:3    | /          | /           | /                                          |
|         |            |             | FS_EN                                      |
| 2       | R/W        | 0.40        | Enable Fine Scaling function               |
| 2       | K/ W       | 0x0         | 0: Bypass Fine scaling                     |
|         |            |             | 1: Enable Fine scaling                     |
|         |            | 0x0         | CS_EN                                      |
| 1       | R/W        |             | Enable Coarse Scaling function             |
| 1       | K/ W       |             | 0: Bypass Coarse scaling                   |
|         |            |             | 1: Enable Coarse scaling                   |
|         |            | 0x0         | CSC_EN                                     |
| 0       | R/W        |             | Enable RGB to YPbPr color space conversion |
| U       | r/vv       |             | 0: Bypass CSC                              |
|         |            |             | 1: Enable CSC                              |

# **5.11.5.20 WB\_CS\_HORZ\_REG**

| Offset: 0x070 |            |             | Register Name: WB_CS_HORZ_REG |
|---------------|------------|-------------|-------------------------------|
| Bit           | Read/Write | Default/Hex | Description                   |
| 31:29         | /          | /           | /                             |
| 28:16         | R/W        | 0x0         | N                             |
| 15:13         | /          | /           | /                             |
| 12:0          | R/W        | 0x0         | М                             |

# **5.11.5.21 WB\_CS\_VERT\_REG**

| Offset: 0x074 |            |             | Register Name: WB_CS_VERT_REG |
|---------------|------------|-------------|-------------------------------|
| Bit           | Read/Write | Default/Hex | Description                   |
| 31:29         | /          | /           | /                             |
| 28:16         | R/W        | 0x0         | N                             |



| 15:13 | /   | /   | / |
|-------|-----|-----|---|
| 12:0  | R/W | 0x0 | M |

# 5.11.5.22 WB\_FS\_INSIZE\_REG

| Offset: 0x080 |            |             | Register Name: WB_FS_INSIZE_REG         |
|---------------|------------|-------------|-----------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                             |
| 31:29         | /          | /           | /                                       |
|               |            |             | IN_HEIGHT                               |
| 28:16         | R/W        | 0x0         | Channel 0 input height                  |
|               |            |             | The actual height is register value + 1 |
| 15:13         | /          | /           | 1                                       |
|               |            |             | IN_WIDTH                                |
| 12:0          | R/W        | 0x0         | Channel 0 input width                   |
|               |            |             | The actual width is register value + 1  |

## 5.11.5.23 WB\_FS\_OUTSIZE\_REG

| Offset: 0 | x084       |             | Register Name: WB_FS_OUTSIZE_REG        |  |  |
|-----------|------------|-------------|-----------------------------------------|--|--|
| Bit       | Read/Write | Default/Hex | Description                             |  |  |
| 31:29     | /          | /           | /                                       |  |  |
|           |            |             | OUT_HEIGHT                              |  |  |
| 28:16     | R/W        | 0x0         | Channel 0 output height                 |  |  |
|           |            |             | The actual height is register value + 1 |  |  |
| 15:13     | /          | /           | /                                       |  |  |
|           |            |             | OUT_WIDTH                               |  |  |
| 12:0      | R/W        | 0x0         | Channel 0 output width                  |  |  |
|           |            |             | The actual width is register value + 1  |  |  |

## **5.11.5.24 WB\_FS\_HSTEP\_REG**

| Offset: 0x088 |            |             | Register Name: WB_FS_HSTEP_REG                        |
|---------------|------------|-------------|-------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                           |
| 31:22         | /          | /           | 1                                                     |
| 24.20         | R/W        | 0x0         | HSTEP_INT                                             |
| 21:20         |            |             | The integer part of channel 0 horizontal scale ratio  |
| 10.2          | D //A/     | R/W 0x0     | HSTEP_FRAC                                            |
| 19:2          | K/W        |             | The fraction part of channel 0 horizontal scale ratio |
| 1:0           | /          | /           | /                                                     |

## **5.11.5.25 WB\_FS\_VSTEP\_REG**

| Offset: 0x08C |                            |   | Register Name: WB_FS_VSTEP_REG |
|---------------|----------------------------|---|--------------------------------|
| Bit           | Bit Read/Write Default/Hex |   | Description                    |
| 31:22         | /                          | / | 1                              |



| 21:20 | R/W | 0x0 | VSTEP_INT  The integer part of channel 0 vertical scale ratio   |
|-------|-----|-----|-----------------------------------------------------------------|
| 19:2  | R/W | 0x0 | VSTEP_FRAC  The fraction part of channel 0 vertical scale ratio |
| 1:0   | /   | /   | /                                                               |

### **5.11.5.26 WB\_DEBUG\_REG**

| Offset: 0x0FC              |   |             | Register Name: WB_DEBUG_REG |
|----------------------------|---|-------------|-----------------------------|
| Bit Read/Write Default/Hex |   | Default/Hex | Description                 |
| 31:13                      | / | /           | /                           |
| 12.0                       | D | 0x0         | INPUT_LINE_CNT              |
| 12:0                       | R |             | Input line counter          |

## 5.11.5.27 WB\_CHO\_HCOEF\_REGN (N = 0:15)

| Offset: 0x200 + N*4 |            |             | Register Name: WB_CH0_HCOEF_REGN           |
|---------------------|------------|-------------|--------------------------------------------|
| Bit                 | Read/Write | Default/Hex | Description                                |
| 31:24               | 14/        | LIDE        | COEF3                                      |
| 31:24               | W          | UDF         | The most right hand-side pixel coefficient |
| 22.16               | w          | UDF         | COEF2                                      |
| 23:16               |            |             | The right hand-side pixel coefficient      |
| 15.0                | 147        | W UDF       | COEF1                                      |
| 15:8                | , vv       |             | The left hand-side pixel coefficient       |
| 7:0                 | W          |             | COEF0                                      |
|                     |            | VV          | W UDF                                      |

Note: This coefficients are signed. The coefficient value equals to coefficient\*26. N represents the phase.

### 5.11.5.28 WB\_CH1\_HCOEF\_REGN (N = 0:15)

| Offset: 0x280 + N*4 |             |             | Register Name: WB_CH1_HCOEF_REGN           |
|---------------------|-------------|-------------|--------------------------------------------|
| Bit                 | Read/Write  | Default/Hex | Description                                |
| 21.24               | <b>NA</b> / | UDF         | COEF3                                      |
| 31:24               | W           |             | The most right hand-side pixel coefficient |
| 23:16               | W           | UDF         | COEF2                                      |
| 23:16               |             |             | The right hand-side pixel coefficient      |
| 15.0                | <b>\</b> \\ | LIDE        | COEF1                                      |
| 15:8                | W           | UDF         | The left hand-side pixel coefficient       |
| 7:0                 | W           | UDF         | COEF0                                      |
|                     |             |             | The most left hand-side pixel coefficient  |

Note: This coefficients are signed. The coefficient value equals to coefficient\*26. N represents the phase.



# 5.12 DE VSU Specification

#### 5.12.1 Overview

The Video Scaler (VS) provides YUV format image resizing function for display engine. It receives data from overlay module, performs the image resizing function, and outputs to video post-processing modules.

The VS can receive YUV420/YUV422/YUV411 data format, and then converts to YUV444 for display. Horizontal and vertical direction scaling are implemented independently.

#### The VS features:

- Support YUV420/YUV422/YUV411 data format with 8-bit pre channel
- Support input and output size from 8×4 to 4096×4096
- Support 1/16x to 32x resize ratio
- Support M-phase 8-tap horizontal anti-alias filter, M-phase 4-tap vertical anti-alias filter (M = 16/32 etc)
- Point-to-point display size up to **W** pixels/line. (**W** is RTL programmable)

| Table 5-2. KTE programmable parameters table |         |                |                                                              |  |
|----------------------------------------------|---------|----------------|--------------------------------------------------------------|--|
| Parameter name                               | Default | Possible value | Description                                                  |  |
| M                                            | 32      | 16/32          | Phase number                                                 |  |
| W                                            | 2048    | 1280/2048/4096 | Y channel line buffer length, U/V channel should divide by 2 |  |
| FRAC                                         | 19      | 18/19          | Phase adder fraction part bit width                          |  |
| VCLIP                                        | 6       | 0~6 integer    | Vertical filtering right shift bit width                     |  |

Table 5-2. RTL programmable parameters table

## 5.12.2 Block Diagram

Figure 5-10 shows the block diagram of Video Scaler. It is a stream-to-stream module. The input interface which contains independent F/Y/U/V channel, receives data separately from up-stream module. The four channels also have independent resizing path for U/V format conversion. Together with the Y channel, the F channel is a 1-bit data channel that scales using the nearest neighborhood method which data represents the valid data flag generated by overlay module. After resizing to FYUV1444, data outputs in pixel mode to down-stream module. It contains some parts and their function list followed:

- Control logic: status machine control, registers operation, VPHASE selection.
- Resizing: three independent channels line buffer control, horizontal resize, vertical resize.





Figure 5-10. VS block diagram

# **5.12.3 Video Scaler Register List**

| Register name     | Offset    | Description                                                     |
|-------------------|-----------|-----------------------------------------------------------------|
| VS_CTRL_REG       | 0x000     | Control register                                                |
| VS_STATUS_REG     | 0x008     | Status register                                                 |
| VS_FIELD_CTRL_REG | 0x00C     | Field control register                                          |
| VS_OUT_SIZE_REG   | 0x040     | Output size register                                            |
| VS_Y_SIZE_REG     | 0x080     | Y channel size register                                         |
| VS_Y_HSTEP_REG    | 0x088     | Y channel horizontal step register                              |
| VS_Y_VSTEP_REG    | 0x08C     | Y channel vertical step register                                |
| VS_Y_HPHASE_REG   | 0x090     | Y channel horizontal initial phase register                     |
| VS_Y_VPHASEO_REG  | 0x098     | Y channel vertical initial phase 0 register                     |
| VS_Y_VPHASE1_REG  | 0x09C     | Y channel vertical initial phase 1 register                     |
| VS_C_SIZE_REG     | 0x0C0     | C channel size register                                         |
| VS_C_HSTEP_REG    | 0x0C8     | C channel horizontal step register                              |
| VS_C_VSTEP_REG    | 0x0CC     | C channel vertical step register                                |
| VS_C_HPHASE_REG   | 0x0D0     | C channel horizontal initial phase register                     |
| VS_C_VPHASEO_REG  | 0x0D8     | C channel vertical initial phase 0 register                     |
| VS_C_VPHASE1_REG  | 0x0DC     | C channel vertical initial phase 1 register                     |
| VS_Y_HCOEF0_REGN  | 0x200+N*4 | Y channel horizontal filter coefficient0 register N (N=0:(M-1)) |
| VS_Y_HCOEF1_REGN  | 0x300+N*4 | Y channel horizontal filter coefficient1 register N (N=0:(M-1)) |
| VS_Y_VCOEF_REGN   | 0x400+N*4 | Y channel vertical filter coefficient register N (N=0:(M-1))    |
| VS_C_HCOEF0_REGN  | 0x600+N*4 | C channel horizontal filter coefficient0 register N (N=0:(M-1)) |
| VS_C_HCOEF1_REGN  | 0x700+N*4 | C channel horizontal filter coefficient1 register N (N=0:(M-1)) |
| VS_C_VCOEF_REGN   | 0x800+N*4 | C channel vertical filter coefficient register N (N=0:(M-1))    |

**Note:** All registers except some bits in **VS\_CTRL\_REG**, **VS\_FIELD\_CTRL\_REG**, **VS\_STATUS\_REG** are double-buffered refreshed by **REG\_RDY**.



# **5.12.4 Video Scaler Register Description**

## **5.12.4.1 VS\_CTRL\_REG**

Note: Only bit EN is double-buffered.

| Offset: | Offset: 0x000 |             | Register Name: VS_CTRL_REG                                                             |
|---------|---------------|-------------|----------------------------------------------------------------------------------------|
| Bit     | Read/Write    | Default/Hex | Description                                                                            |
|         |               |             | BIST_EN                                                                                |
| 31      | R/W           | 0x0         | BIST enable                                                                            |
| 31      | K/ VV         | UXU         | 0: Disable                                                                             |
|         |               |             | 1: Enable                                                                              |
|         |               |             | CORE_RST                                                                               |
| 30      | R/W           | 0x0         | Core circuit reset                                                                     |
| 30      | IN, VV        | 0.00        | 0: Do noting                                                                           |
|         |               |             | 1: reset core circuit                                                                  |
| 29:5    | /             | /           |                                                                                        |
|         |               | N 0x0       | COEF_SWITCH_EN                                                                         |
|         |               |             | Coefficients RAM switch                                                                |
|         |               |             | 0: DONOT switch                                                                        |
| 4       | R/W           |             | 1: Switch RAM use <b>REG_RDY</b>                                                       |
|         |               |             | Note: When <b>LCD SYNC</b> go low and <b>COEF_SWITCH_EN</b> is 1, coefficient RAM will |
|         |               |             | switch to the latest updated RAM if <b>REG_RDY</b> is 1, and then the bit will also be |
|         |               |             | self-cleared if switch action successes.                                               |
| 3:1     | /             | /           | /                                                                                      |
|         |               |             | EN                                                                                     |
|         |               |             | Video Scaler enable                                                                    |
| 0       | R/W           | 0x0         | 0: Disable                                                                             |
|         |               |             | 1: Enable                                                                              |
|         |               |             | Note: When module disabled, the core clock to the core circuit will be gated.          |

## **5.12.4.2 VS\_STATUS\_REG**

Note: Whole WORD is non-double-buffered.

| Offset: 0 | 0x008      |                                                                      | Register Name: VS_STATUS_REG       |
|-----------|------------|----------------------------------------------------------------------|------------------------------------|
| Bit       | Read/Write | Default/Hex                                                          | Description                        |
| 31:28     | /          | /                                                                    | /                                  |
| 27:16     | D          | 0.40                                                                 | LINE_CNT                           |
| 27:16     | R          | 0x0                                                                  | Output line number                 |
| 15:5      | /          | /                                                                    | /                                  |
|           |            |                                                                      | BUSY                               |
| 4         | ь          | 0.40                                                                 | Core circuit status                |
| 4         | R 0x0      | 0: idle (finish, module disable, waiting for LCD SYNC negative edge) |                                    |
|           |            |                                                                      | 1: busy (core circuit calculating) |
| 3:0       | /          | /                                                                    | 1                                  |



## 5.12.4.3 VS\_FIELD\_CTRL\_REG

Note: Only bit  $FIELD\_SEL\_VPHASE\_EN$  is double-buffered.

| Offset: 0 | 0x00C      |             | Register Name: VS_FIELD_CTRL_REG                                                                |  |  |
|-----------|------------|-------------|-------------------------------------------------------------------------------------------------|--|--|
| Bit       | Read/Write | Default/Hex | Description                                                                                     |  |  |
| 31:6      | /          | /           | /                                                                                               |  |  |
|           |            |             | LCD_SYNC_REVERSE                                                                                |  |  |
| 5         | R/W        | 0.40        | Reverse LCD SYNC                                                                                |  |  |
| 5         | K/ VV      | 0x0         | 0: DONOT reverse                                                                                |  |  |
|           |            |             | 1: Reverse                                                                                      |  |  |
|           | R/W        | 0x0         | LCD_FILED_REVERSE                                                                               |  |  |
| 4         |            |             | Reverse LCD FILED                                                                               |  |  |
| 4         |            |             | 0: DONOT reverse                                                                                |  |  |
|           |            |             | 1: Reverse                                                                                      |  |  |
| 3:1       | /          | /           |                                                                                                 |  |  |
|           |            |             | FIELD_SEL_VPHASE_EN                                                                             |  |  |
|           |            | R/W 0x0     | Vertical initial phase switch control                                                           |  |  |
| 0         | R/W        |             | 0: Vertical initial phase fix to phase0                                                         |  |  |
|           |            |             | 1: Switch Vertical initial phase by <b>LCD FIELD</b> (Switch to phase0 when <b>LCD FILED</b> is |  |  |
|           |            |             | 1, and switch to phase1 when LCD FIELD is 0)                                                    |  |  |

## 5.12.4.4 VS\_OUT\_SIZE\_REG

| Offset: 0 | )x040      |             | Register Name: VS_OUT_SIZE_REG          |
|-----------|------------|-------------|-----------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                             |
| 31:29     | /          | /           | /                                       |
|           |            |             | OUT_HEIGHT                              |
| 28:16     | R/W        | 0x0         | Output height                           |
|           |            |             | The actual height is register value + 1 |
| 15:13     | /          | /           | /                                       |
|           |            |             | OUT_WIDTH                               |
| 12:0      | R/W        | 0x0         | Output width                            |
|           |            |             | The actual width is register value + 1  |

## **5.12.4.5 VS\_Y\_SIZE\_REG**

| Offset: 0 | 0x080      |             | Register Name: VS_Y_SIZE_REG            |
|-----------|------------|-------------|-----------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                             |
| 31:29     | /          | /           | /                                       |
|           |            |             | Y_HEIGHT                                |
| 28:16     | R/W        | 0x0         | Y channel input height                  |
|           |            |             | The actual height is register value + 1 |
| 15:13     | /          | /           | /                                       |
|           |            |             | Y_WIDTH                                 |
| 12:0      | R/W        | 0x0         | Y channel input width                   |
|           |            |             | The actual width is register value + 1  |



# **5.12.4.6 VS\_Y\_HSTEP\_REG**

| Offset: 0 | )x088      |             | Register Name: VS_Y_HSTEP_REG                         |
|-----------|------------|-------------|-------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                           |
| 31:24     | /          | /           | 1                                                     |
| 22.20     | R/W        | 0x0         | Y_HSTEP_INT                                           |
| 23:20     |            |             | The integer part of Y channel horizontal scale ratio  |
| 10.1      | D/M        | ./          | Y_HSTEP_FRAC                                          |
| 19:1      | R/W        | 0x0         | The fraction part of Y channel horizontal scale ratio |
| 0         | /          | /           | /                                                     |

# **5.12.4.7 VS\_Y\_VSTEP\_REG**

| Offset: 0 | )x08C      |             | Register Name: VS_Y_VSTEP_REG                       |
|-----------|------------|-------------|-----------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                         |
| 31:24     | /          | /           | /                                                   |
| 23:20     | R/W        | 0x0         | Y_VSTEP_INT                                         |
| 23:20     |            |             | The integer part of Y channel vertical scale ratio  |
| 19:1      | 5/14/      | 0.0         | Y_VSTEP_FRAC                                        |
| 19:1      | R/W        | 0x0         | The fraction part of Y channel vertical scale ratio |
| 0         | /          | /           | 1                                                   |

# 5.12.4.8 VS\_Y\_HPHASE\_REG

| Offset: 0 | 0x090      |             | Register Name: VS_Y_HPHASE_REG                          |
|-----------|------------|-------------|---------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                             |
| 31:24     | /          | /           | /                                                       |
| 23:20     | R/W        | 0x0         | Y_HPHASE_INT                                            |
| 23.20     |            |             | The integer part of Y channel horizontal initial phase  |
| 10.1      | D ()A/     | . 0.0       | Y_HPHASE_FRAC                                           |
| 19:1      | R/W        | 0x0         | The fraction part of Y channel horizontal initial phase |
| 0         | /          | /           | /                                                       |

## **5.12.4.9 VS\_Y\_VPHASE0\_REG**

| Offset: 0 | )x098      |             | Register Name: VS_Y_VPHASE0_REG                        |
|-----------|------------|-------------|--------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                            |
| 31:24     | /          | /           | 1                                                      |
| 23:20     | R/W        | 0x0         | Y_VPHASEO_INT                                          |
| 23.20     |            |             | The integer part of Y channel vertical initial phase0  |
| 19:1      | D ()A/     | 0,40        | Y_VPHASEO_FRAC                                         |
| 19.1      | R/W        | 0x0         | The fraction part of Y channel vertical initial phase0 |
| 0         | /          | /           |                                                        |



## **5.12.4.10 VS\_Y\_VPHASE1\_REG**

| Offset: 0x09C |            |             | Register Name: VS_Y_VPHASE1_REG                        |
|---------------|------------|-------------|--------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                            |
| 31:24         | /          | /           | /                                                      |
| 22.20         | R/W        | 0x0         | Y_VPHASE1_INT                                          |
| 23:20         |            |             | The integer part of Y channel vertical initial phase1  |
| 10.1          | D /\A/     | 0x0         | Y_VPHASE1_FRAC                                         |
| 19:1          | R/W        |             | The fraction part of Y channel vertical initial phase1 |
| 0             | /          | /           | /                                                      |

# 5.12.4.11 VS\_C\_SIZE\_REG

| Offset: 0 | )x0C0      |             | Register Name: VS_C_SIZE_REG            |
|-----------|------------|-------------|-----------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                             |
| 31:29     | /          | /           | /                                       |
|           |            |             | C_HEIGHT                                |
| 28:16     | R/W        | 0x0         | C channel input height                  |
|           |            |             | The actual height is register value + 1 |
| 15:13     | /          | /           | /                                       |
|           |            |             | C_WIDTH                                 |
| 12:0      | R/W        | 0x0         | C channel input width                   |
|           |            |             | The actual width is register value + 1  |

## **5.12.4.12 VS\_C\_HSTEP\_REG**

| Offset: 0 | 0x0C8      |             | Register Name: VS_C_HSTEP_REG                         |
|-----------|------------|-------------|-------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                           |
| 31:24     | /          | /           | /                                                     |
| 22.20     | R/W        | 0x0         | C_HSTEP_INT                                           |
| 23:20     |            |             | The integer part of C channel horizontal scale ratio  |
| 10.1      | R/W        | /W 0x0      | C_HSTEP_FRAC                                          |
| 19:1      |            |             | The fraction part of C channel horizontal scale ratio |
| 0         | /          | /           | /                                                     |

# 5.12.4.13 VS\_C\_VSTEP\_REG

| Offset: 0 | Dx0CC      |             | Register Name: VS_C_VSTEP_REG                       |
|-----------|------------|-------------|-----------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                         |
| 31:24     | /          | /           | /                                                   |
| 22.20     | R/W        | 0x0         | C_VSTEP_INT                                         |
| 23:20     |            |             | The integer part of C channel vertical scale ratio  |
| 19:1      | D ()A/     | 00          | C_VSTEP_FRAC                                        |
| 19:1      | R/W        | 0x0         | The fraction part of C channel vertical scale ratio |
| 0         | /          | /           | /                                                   |



# **5.12.4.14 VS\_C\_HPHASE\_REG**

| Offset: 0x0D0 |            |             | Register Name: VS_C_HPHASE_REG                          |
|---------------|------------|-------------|---------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                             |
| 31:24         | /          | /           | /                                                       |
| 23:20         | R/W        | 0x0         | C_HPHASE_INT                                            |
|               |            |             | The integer part of C channel horizontal initial phase  |
| 10.1          | D /\A/     | 00          | C_HPHASE_FRAC                                           |
| 19:1          | R/W        | 0x0         | The fraction part of C channel horizontal initial phase |
| 0             | /          | /           | /                                                       |

## **5.12.4.15 VS\_Y\_VPHASE0\_REG**

| Offset: 0 | 0x0D8      |             | Register Name: VS_Y_VPHASE0_REG                        |
|-----------|------------|-------------|--------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                            |
| 31:24     | /          | /           | /                                                      |
| 22.20     | R/W        | 0x0         | C_VPHASEO_INT                                          |
| 23:20     |            |             | The integer part of C channel vertical initial phase0  |
| 10.1      | R/W        | 0x0         | C_VPHASEO_FRAC                                         |
| 19:1      |            |             | The fraction part of C channel vertical initial phase0 |
| 0         | /          | /           | /                                                      |

## **5.12.4.16 VS\_C\_VPHASE1\_REG**

| Offset: 0 | Dx0DC      |             | Register Name: VS_C_VPHASE1_REG                        |
|-----------|------------|-------------|--------------------------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                                            |
| 31:24     | /          | /           | 1                                                      |
| 23:20     | R/W        | 0x0         | C_VPHASE1_INT                                          |
| 23.20     |            |             | The integer part of C channel vertical initial phase1  |
| 10.1      | D /\A/     | R/W 0x0     | C_VPHASE1_FRAC                                         |
| 19:1      | K/W        |             | The fraction part of C channel vertical initial phase1 |
| 0         | /          | /           | 1                                                      |

## 5.12.4.17 VS\_Y\_HCOEF0\_REGN (N = 0:(M-1))

| Offset: 0                  | 0x200 + N*4 |             | Register Name: VS_Y_HCOEF0_REGN |
|----------------------------|-------------|-------------|---------------------------------|
| Bit Read/Write Default/Hex |             | Default/Hex | Description                     |
| 31:24                      | R/W         | UDF         | COEF3                           |
| 23:16                      | R/W         | UDF         | COEF2                           |
| 15:8                       | R/W         | UDF         | COEF1                           |
| 7:0                        | R/W         | UDF         | COEF0                           |

Note: HCOEFF0 is a two's complement. The register value equals to coefficient\*26. N represents the phase.

### 5.12.4.18 VS\_Y\_HCOEF1\_REGN (N = 0:(M-1))

| Offset: 0x300 + N*4 | Register Name: VS_Y_HCOEF1_REGN |
|---------------------|---------------------------------|
|---------------------|---------------------------------|



| Bit   | Read/Write | Default/Hex | Description |
|-------|------------|-------------|-------------|
| 31:24 | R/W        | UDF         | COEF7       |
| 23:16 | R/W        | UDF         | COEF6       |
| 15:8  | R/W        | UDF         | COEF5       |
| 7:0   | R/W        | UDF         | COEF4       |

Note: HCOEFF1 is a two's complement. The register value equals to coefficient\*26. N represents the phase.

## 5.12.4.19 VS\_Y\_VCOEF\_REGN (N = 0:(M-1))

| Offset: 0 | 0x400 + N*4 |             | Register Name: VS_Y_VCOEF_REGN |  |
|-----------|-------------|-------------|--------------------------------|--|
| Bit       | Read/Write  | Default/Hex | Description                    |  |
| 31:24     | R/W         | UDF         | COEF3                          |  |
| 23:16     | R/W         | UDF         | COEF2                          |  |
| 15:8      | R/W         | UDF         | COEF1                          |  |
| 7:0       | R/W         | UDF         | COEF0                          |  |

Note: VCOEFF is a two's complement. The register value equals to coefficient\*26. N represents the phase.

### 5.12.4.20 VS\_C\_HCOEF0\_REGN (N = 0:(M-1))

| Offset: 0x600 + N*4        |     |             | Register Name: VS_C_HCOEF0_REGN |
|----------------------------|-----|-------------|---------------------------------|
| Bit Read/Write Default/Hex |     | Default/Hex | Description                     |
| 31:24                      | R/W | UDF         | COEF3                           |
| 23:16                      | R/W | UDF         | COEF2                           |
| 15:8                       | R/W | UDF         | COEF1                           |
| 7:0                        | R/W | UDF         | COEF0                           |

Note: HCOEFF0 is a two's complement. The register value equals to coefficient\*2<sup>6</sup>. N represents the phase.

## 5.12.4.21 VS\_C\_HCOEF1\_REGN (N = 0:(M-1))

| Offset: 0 | 0x700 + N*4                |     | Register Name: VS_C_HCOEF1_REGN |
|-----------|----------------------------|-----|---------------------------------|
| Bit       | Bit Read/Write Default/Hex |     | Description                     |
| 31:24     | R/W                        | UDF | COEF7                           |
| 23:16     | R/W                        | UDF | COEF6                           |
| 15:8      | R/W                        | UDF | COEF5                           |
| 7:0       | R/W                        | UDF | COEF4                           |

Note: HCOEFF1 is a two's complement. The register value equals to coefficient\*26. N represents the phase.

## 5.12.4.22 VS\_C\_VCOEF\_REGN (N = 0:(M-1))

| Offset: 0x800 + N*4 |                                        |     | Register Name: VS_C_VCOEF_REGN |
|---------------------|----------------------------------------|-----|--------------------------------|
| Bit                 | Bit Read/Write Default/Hex Description |     | Description                    |
| 31:24               | R/W                                    | UDF | COEF3                          |
| 23:16               | R/W                                    | UDF | COEF2                          |
| 15:8                | R/W                                    | UDF | COEF1                          |
| 7:0                 | R/W                                    | UDF | COEF0                          |



Note: VCOEFF is a two's complement. The register value equals to coefficient\*26. N represents the phase.



# **5.13 DE Rotation Specification**

### 5.13.1 Overview

- Support 1/2/3 address data copy
- Support input and output size from 8x8 to 2048x2048
- Support horizontal and vertical flip, clockwise 0/90/180/270 degree rotate
- Support input/output format YUV422/YUV420/ARGB8888/XRGB8888

## 5.13.2 Block Diagram



Figure 5-11. CSR Block Diagram

## 5.13.3 Description

## 5.13.4 Copy & Rotation

There are several types of rotation: clockwise 0/90/180/270 degree Rotation and H-Flip/V-Flip. Operation of Copy is the same as a 0 degree rotation.

Copy & Rotation will not change RGB color format. But for YUV422/YUV420 input, all output will be in YUV 420 planer.





Figure 5-12. Rotation Diagram

## Speed requirement:

For ARGB : 1pixel/1cycle
For RGB565 : 2pixel/1cycle
For YUV420 : 4pixel/1cycle

| Test Format    | Rotation Angle        | Test Resolution    | <b>Boundary Condition</b> |                          |
|----------------|-----------------------|--------------------|---------------------------|--------------------------|
| ARGB8888       | 0,90,180,270          | 4x4,               | In/Out Pitch:             | 16byte Align             |
|                | 0+HFlip;              | 4096x4,4x4096      | In/Out Width/Height:      | 1pixel Align             |
|                | 90+HFlip;             | 2048x1536          | Input Address:            | 16byte Align             |
|                | 0+VFlip;<br>90+VFlip; | Typical Resolution | Output Address:           | 4byte Align              |
| YUV420 /YUV422 | ]                     | 8x8,               | In/Out Pitch:             | 16byte Align             |
| Semi-Planar    |                       | 4096x8, 8x4096     | U Pitch = V Pitch         |                          |
|                |                       | 2048x1536          | In/Out Width/Height:      | 2pixel Align             |
| YUV420         |                       | Typical Resolution | Input Address:            | 16byte Align             |
| /YUV422        |                       |                    | Y Output Address:         | 2byte Align              |
| Planar         |                       |                    | UV Output Address:        | 1byte Align              |
|                |                       |                    |                           | When the format is       |
|                |                       |                    |                           | Planar, the remainder of |
|                |                       |                    |                           | U and V base address     |
|                |                       |                    |                           | divided by 32byte must   |
|                |                       |                    |                           | be equal.                |
| RGB888         |                       | 4x4,               | In/Out Pitch:             | 16byte Align             |
|                |                       | 4096x4,4x4096      | In/Out Width/Height:      | 1pixel Align             |
|                |                       | 2048x1536          | Input Address:            | 16byte Align             |
|                |                       | Typical Resolution | Output Address:           | (4*N + 3)byte            |
|                |                       |                    |                           | (4*N + 6)byte            |
|                |                       |                    |                           | (4*N + 9)byte            |
|                |                       |                    |                           | (4*N + 12)byte           |

# 5.13.5 Register List

| Register name | Offset | Description             |
|---------------|--------|-------------------------|
| GLB_CTL       | 0x000  | Global control register |



| INT              | 0x004 | Interrupt register                         |
|------------------|-------|--------------------------------------------|
| IFMT             | 0x020 | Input data attribute register              |
| IDATA_SIZE       | 0x024 | Input data size register                   |
| IDATA_MEN_PITCH0 | 0x030 | Input Y/RGB/ARGB memory pitch register     |
| IDATA_MEN_PITCH1 | 0x034 | Input U/UV memory pitch register           |
| IDATA_MEN_PITCH2 | 0x038 | Input V memory pitch register              |
| IMEN_LADD0       | 0x040 | Input Y/RGB/ARGB memory address register0  |
| IMEN_HADD0       | 0x044 | Input Y/RGB/ARGB memory address register1  |
| IMEN_LADD1       | 0x048 | Input U/UV memory address register0        |
| IMEN_HADD1       | 0x04C | Input U/UV memory address register1        |
| IMEN_LADD2       | 0x050 | Input V memory address register0           |
| IMEN_HADD2       | 0x054 | Input V memory address register1           |
| ODATA_SIZE       | 0x084 | Output data size register                  |
| ODATA_MEN_PITCH0 | 0x090 | Output Y/RGB/ARGB memory pitch register    |
| ODATA_MEN_PITCH1 | 0x094 | Output U/UV memory pitch register          |
| ODATA_MEN_PITCH2 | 0x098 | Output V memory pitch register             |
| OMEN_LADD0       | 0x0A0 | Output Y/RGB/ARGB memory address register0 |
| OMEN_HADD0       | 0x0A4 | Output Y/RGB/ARGB memory address register1 |
| OMEN_LADD1       | 0x0A8 | Output U/UV memory address register0       |
| OMEN_HADD1       | 0x0AC | Output U/UV memory address register1       |
| OMEN_LADD2       | 0x0B0 | Output V memory address register0          |
| OMEN_HADD2       | 0x0B4 | Output V memory address register1          |

# **5.13.6 Register Description**

## 5.13.6.1 Global control register

| Offset: | Offset: 0x000 |             | Register Name: CSR_CTL                                                             |  |
|---------|---------------|-------------|------------------------------------------------------------------------------------|--|
| Bit     | Read/Write    | Default/Hex | Description                                                                        |  |
|         |               |             | START                                                                              |  |
|         |               |             | 0: idle                                                                            |  |
| 31      | R/W           | 0x0         | 1:start                                                                            |  |
|         |               |             | Write 1 to this register bit will start the CSR, when finish, it's self-cleaned by |  |
|         |               |             | hardware.                                                                          |  |
|         |               |             | RESET                                                                              |  |
| 30      | R/W           | 0x0         | 0: normal                                                                          |  |
|         |               |             | 1: assert reset                                                                    |  |
| 29:22   | /             | /           | reserved                                                                           |  |
|         |               |             | Burst length                                                                       |  |
|         |               |             | 0x07:burst8                                                                        |  |
| 21:16   | R/W           | 0x3f        | 0x0f:burst16                                                                       |  |
|         |               |             | 0x1f:burst32                                                                       |  |
|         |               |             | 0x3f:burst64                                                                       |  |
| 15:8    | 1             | /           | 1                                                                                  |  |
| 7       | R/W           | 0x0         | H-FLIP                                                                             |  |



| 1   | 1   | i   |                          |
|-----|-----|-----|--------------------------|
|     |     |     | 0: disable               |
|     |     |     | 1:enable                 |
|     |     |     | V-FLIP                   |
| 6   | R/W | 0x0 | 0: disable               |
|     |     |     | 1: enable                |
|     |     |     | Rotation function        |
|     |     |     | 00: clockwise 0 degree   |
| 5:4 | R/W | 0x0 | 01: clockwise 90 degree  |
|     |     |     | 10: clockwise 180 degree |
|     |     |     | 11: clockwise 270 degree |
| 3:2 | /   | /   | reserved                 |
|     |     |     | MODE_SEL                 |
|     |     |     | CSR mode select          |
| 1:0 | R/W | 0x0 | 00: disable              |
|     |     |     | 01: copy& rotation       |
|     |     |     | other:reserved           |

## 5.13.6.2 Interrupt register

| Offset: 0x004 |            |             | Register Name: INT                                             |
|---------------|------------|-------------|----------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                    |
| 31:17         | /          | /           | /                                                              |
|               |            |             | FINISH_IRQ_EN                                                  |
| 16            | R/W        | 0x0         | 0: disable FINISH IRQ                                          |
|               |            |             | 1: enable FINISH IRQ                                           |
| 15:2          | /          | /           | /                                                              |
|               |            |             | FINISH                                                         |
| 0             | R/W        | 0x0         | Mission finish flag                                            |
|               |            |             | It will be set when job is finished, and cleared by writing 1. |

# 5.13.6.3 Input data attribute register

| Offset: 0 | Offset: 0x020 |             | Register Name: IFMT |
|-----------|---------------|-------------|---------------------|
| Bit       | Read/Write    | Default/Hex | Description         |
| 31:6      | /             | /           | /                   |
|           |               |             | IFMT                |
|           |               |             | Input data format   |
|           | R/W           | 0x0         | 0x00: ARGB_8888     |
|           |               |             | 0x01: ABGR_8888     |
| 5:0       |               |             | 0x02: RGBA_8888     |
| 3.0       |               |             | 0x03: BGRA_8888     |
|           |               |             | 0x04: XRGB_8888     |
|           |               |             | 0x05: XBGR_8888     |
|           |               |             | 0x06: RGBX_8888     |
|           |               |             | 0x07: BGRX_8888     |



|  | 0x08~0x23: Reserved                       |
|--|-------------------------------------------|
|  | 0x24: Planar YUV422 UV combined(V1U1V0U0) |
|  | 0x25: Planar YUV422 UV combined(U1V1U0V0) |
|  | 0x26: Planar YUV422                       |
|  | 0x27: Reserved                            |
|  | 0x28: Planar YUV420 UV combined(V1U1V0U0) |
|  | 0x29: Planar YUV420 UV combined(U1V1U0V0) |
|  | 0x2A: Planar YUV420                       |
|  | Other: Reserved                           |

## 5.13.6.4 Input data size register

| Offset: 0x024 |            |             | Register Name: IDATA_SIZE                  |
|---------------|------------|-------------|--------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                |
| 31:29         | /          | /           | /                                          |
| 20.16         | R/W        | 0x0         | HEIGHT                                     |
| 28:16         |            |             | The Height = The value of these bits add 1 |
| 15:13         | /          | /           | /                                          |
| 12:0          | R/W        | 0x0         | WIDTH                                      |
|               |            |             | The Width = The value of these bits add 1  |

### 5.13.6.5 Input Y/RGB/ARGB memory pitch register

| Offset: 0x030 |            |             | Register Name: IDATA_MEN_PITCH0        |
|---------------|------------|-------------|----------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                            |
|               |            |             | PITCH0                                 |
| 31:0          | R/W        | 0x0         | Input Y/RGB data memory pitch in bytes |
|               |            |             | Should be 128bit aligned.              |

Note: The setting of this register is Y/RGB channel address.

### 5.13.6.6 Input U/UV memory pitch register

| Offset: 0x034 |            |             | Register Name: IDATA_MEN_PITCH 1      |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
|               |            |             | PITCH1                                |
| 31:0          | R/W        | 0x0         | Input U/UV data memory pitch in bytes |
|               |            |             | Should be 128bit aligned.             |

Note: The setting of this register is U/UV channel address.

## 5.13.6.7 Input V memory pitch register

| Offset: 0 | Offset: 0x038          |     | Register Name: IDATA_MEN_PITCH2     |
|-----------|------------------------|-----|-------------------------------------|
| Bit       | Read/Write Default/Hex |     | Description                         |
| 31:0      | R/W                    | 0x0 | PITCH2                              |
| 31.0      | TV VV                  |     | Input V data memory pitch in bytes. |



|  | Should be 128bit aligned.          |
|--|------------------------------------|
|  | Must be equal to input U/UV pitch. |

Note: The setting of this register is V channel address.

### 5.13.6.8 Input Y/RGB/ARGB memory address register0

| Offset: 0x040 |            |             | Register Name: IMEN_LADD0            |
|---------------|------------|-------------|--------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                          |
|               |            |             | LADD                                 |
| 31:0          | R/W        | 0x0         | Memory Block Start Address bit[31:0] |
|               |            |             | Should be 128bit aligned.            |

Note: The setting of this register is Y/RGB channel address.

### 5.13.6.9 Input Y/RGB/ARGB memory address register1

| Offset: 0 | x044       |             | Register Name: IMEN_HADD0             |
|-----------|------------|-------------|---------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                           |
| 31:8      | /          | /           | /                                     |
|           |            |             | HADD                                  |
| 7:0       | R/W        | 0x0         | Memory Block Start Address bit[39:32] |
|           |            |             | Layer Memory Block Address in bytes   |

Note: The setting of this register is Y/RGB channel address.

### 5.13.6.10 Input U/UV memory address register0

| Offset: 0x048 |            |             | Register Name: IMEN_LADD1            |
|---------------|------------|-------------|--------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                          |
|               |            |             | LADD                                 |
| 31:0          | R/W        | 0x0         | Memory Block Start Address bit[31:0] |
|               |            |             | Should be 128bit aligned.            |

Note: The setting of this register is U/UV channel address.

### 5.13.6.11 Input U/UV memory address register1

| Offset: 0x04c |            |             | Register Name: IMEN_HADD1             |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
| 31:8          | /          | /           | /                                     |
|               |            |             | HADD                                  |
| 7:0           | R/W        | 0x0         | Memory Block Start Address bit[39:32] |
|               |            |             | Layer Memory Block Address in bytes   |

Note: The setting of this register is U/UV channel address.

### 5.13.6.12 Input V memory address register0

| Offset: 0x050 | Register Name: IMEN_LADD2 |
|---------------|---------------------------|
|---------------|---------------------------|



| Bit  | Read/Write | Default/Hex | Description                          |
|------|------------|-------------|--------------------------------------|
|      |            |             | LADD                                 |
| 31:0 | R/W        | 0x0         | Memory Block Start Address bit[31:0] |
|      |            |             | Should be 128bit aligned.            |

Note: The setting of this register is V channel address.

### 5.13.6.13 Input V memory address register1

| Offset: 0x054 |            |             | Register Name: IMEN_HADD2             |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
| 31:8          | /          | /           | /                                     |
|               |            |             | HADD                                  |
| 7:0           | R/W        | 0x0         | Memory Block Start Address bit[39:32] |
|               |            |             | Layer Memory Block Address in bytes   |

Note: The setting of this register is V channel address.

### 5.13.6.14 Output data size register

| Offset: 0x084 |            |             | Register Name: ODATA_SIZE                  |
|---------------|------------|-------------|--------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                |
| 31:29         | /          | /           | /                                          |
| 20.16         | R/W 0      | 0.40        | HEIGHT                                     |
| 28:16         |            | 0x0         | The Height = The value of these bits add 1 |
| 15:13         | /          | /           | /                                          |
| 12.0          | D /\A/     | 0x0         | WIDTH                                      |
| 12:0          | R/W        |             | The Width = The value of these bits add 1  |

### 5.13.6.15 Output Y/RGB/ARGB memory pitch register

| Offset: 0x090 |            |             | Register Name: ODATA_MEN_PITCH0         |
|---------------|------------|-------------|-----------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                             |
|               |            |             | PITCH0                                  |
| 31:0          | R/W        | 0x0         | output Y/RGB data memory pitch in bytes |
|               |            |             | Should be 128bit aligned.               |

Note: The setting of this register is Y/RGB channel address.

## 5.13.6.16 Output U/UV memory pitch register

| Offset: 0 | x094       |             | Register Name: ODATA_MEN_PITCH 1 |
|-----------|------------|-------------|----------------------------------|
| Bit       | Read/Write | Default/Hex | Description                      |
|           |            |             | PITCH1                           |
| 31:0      | R/W        | 0x0         | U/UV data memory pitch in bytes  |
|           |            |             | Should be 128bit aligned.        |

Note: The setting of this register is U/UV channel address.



### 5.13.6.17 Output V memory pitch register

| Offset: 0x098 |            |             | Register Name: ODATA_MEN_PITCH2     |
|---------------|------------|-------------|-------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                         |
|               |            |             | PITCH2                              |
| 21.0          | D /\A/     |             | Output V data memory pitch in bytes |
| 31:0          | R/W        | 0x0         | Should be 128bit aligned.           |
|               |            |             | Must be equal to output U/UV pitch. |

Note: The setting of this register is V channel address.

### 5.13.6.18 Output Y/RGB/ARGB memory address register0

| Offset: 0x0a0 |            |             | Register Name: OMEN_LADD0            |
|---------------|------------|-------------|--------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                          |
| 31:0          | D /\A/     | 0.0         | LADD                                 |
| 31.0          | R/W        | 0x0         | Memory Block Start Address bit[31:0] |

Note: The setting of this register is Y/RGB channel address.

#### 5.13.6.19 Output Y/RGB/ARGB memory address register1

| Offset: 0 | x0a4       |             | Register Name: OMEN_HADD0             |
|-----------|------------|-------------|---------------------------------------|
| Bit       | Read/Write | Default/Hex | Description                           |
| 31:8      | /          | /           | /                                     |
|           |            |             | HADD                                  |
| 7:0       | R/W        | 0x0         | Memory Block Start Address bit[39:32] |
|           |            |             | Layer Memory Block Address in bytes   |

Note: The setting of this register is Y/RGB channel address.

### 5.13.6.20 Output U/UV memory address register0

| Offset: 0x0a8 |            |             | Register Name: OMEN_LADD1            |
|---------------|------------|-------------|--------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                          |
| 21.0          | D/M        | 00          | LADD                                 |
| 31:0          | R/W        | 0x0         | Memory Block Start Address bit[31:0] |

Note: The setting of this register is U/UV channel address.

## 5.13.6.21 Output U/UV memory address register1

| Offset: 0x0ac |            |             | Register Name: OMEN_HADD1             |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
| 31:8          | /          | /           | /                                     |
|               |            |             | HADD                                  |
| 7:0           | R/W        | 0x0         | Memory Block Start Address bit[39:32] |
|               |            |             | Layer Memory Block Address in bytes   |

Note: The setting of this register is U/UV channel address.



## 5.13.6.22 Output V memory address register0

| Offset: 0x0b0 |            |             | Register Name: OMEN_LADD2            |
|---------------|------------|-------------|--------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                          |
| 31:0          | R/W        | 0x0         | LADD                                 |
|               |            |             | Memory Block Start Address bit[31:0] |

Note: The setting of this register is V channel address.

## 5.13.6.23 Output V memory address register1

| Offset: 0x0b4 |            |             | Register Name: OMEN_HADD2             |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
| 31:8          | /          | /           | /                                     |
|               |            |             | HADD                                  |
| 7:0           | R/W        | 0x0         | Memory Block Start Address bit[39:32] |
|               |            |             | Layer Memory Block Address in bytes   |

Note: The setting of this register is V channel address.