xref: /rockchip-linux_mpp/mpp/hal/rkenc/h264e/hal_h264e_vepu580_reg.h (revision 437bfbeb9567cca9cd9080e3f6954aa9d6a94f18)
1*437bfbebSnyanmisaka /*
2*437bfbebSnyanmisaka  * Copyright 2021 Rockchip Electronics Co. LTD
3*437bfbebSnyanmisaka  *
4*437bfbebSnyanmisaka  * Licensed under the Apache License, Version 2.0 (the "License");
5*437bfbebSnyanmisaka  * you may not use this file except in compliance with the License.
6*437bfbebSnyanmisaka  * You may obtain a copy of the License at
7*437bfbebSnyanmisaka  *
8*437bfbebSnyanmisaka  *      http://www.apache.org/licenses/LICENSE-2.0
9*437bfbebSnyanmisaka  *
10*437bfbebSnyanmisaka  * Unless required by applicable law or agreed to in writing, software
11*437bfbebSnyanmisaka  * distributed under the License is distributed on an "AS IS" BASIS,
12*437bfbebSnyanmisaka  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*437bfbebSnyanmisaka  * See the License for the specific language governing permissions and
14*437bfbebSnyanmisaka  * limitations under the License.
15*437bfbebSnyanmisaka  */
16*437bfbebSnyanmisaka 
17*437bfbebSnyanmisaka #ifndef __HAL_H264E_VEPU580_REG_H__
18*437bfbebSnyanmisaka #define __HAL_H264E_VEPU580_REG_H__
19*437bfbebSnyanmisaka 
20*437bfbebSnyanmisaka #include "rk_type.h"
21*437bfbebSnyanmisaka 
22*437bfbebSnyanmisaka #define VEPU580_CONTROL_CFG_OFFSET  (0 * sizeof(RK_U32))
23*437bfbebSnyanmisaka #define VEPU580_BASE_CFG_OFFSET     (160 * sizeof(RK_U32))
24*437bfbebSnyanmisaka #define VEPU580_RC_KLUT_CFG_OFFSET  (1024 * sizeof(RK_U32))
25*437bfbebSnyanmisaka #define VEPU580_SECTION_3_OFFSET    (1472 * sizeof(RK_U32))
26*437bfbebSnyanmisaka #define VEPU580_RDO_CFG_OFFSET      (2048 * sizeof(RK_U32))
27*437bfbebSnyanmisaka #define VEPU580_SCL_CFG_OFFSET      (2176 * sizeof(RK_U32))
28*437bfbebSnyanmisaka #define VEPU580_OSD_OFFSET          (3072 * sizeof(RK_U32))
29*437bfbebSnyanmisaka #define VEPU580_STATUS_OFFSET       (4096 * sizeof(RK_U32))
30*437bfbebSnyanmisaka #define VEPU580_DBG_OFFSET          (5120 * sizeof(RK_U32))
31*437bfbebSnyanmisaka #define VEPU580_REG_BASE_HW_STATUS  0x2c
32*437bfbebSnyanmisaka 
33*437bfbebSnyanmisaka typedef struct {
34*437bfbebSnyanmisaka     RK_U32 lt_pos_x : 10;
35*437bfbebSnyanmisaka     RK_U32 reserved0 : 6;
36*437bfbebSnyanmisaka     RK_U32 lt_pos_y : 10;
37*437bfbebSnyanmisaka     RK_U32 reserved1 : 6;
38*437bfbebSnyanmisaka } OsdLtPos;
39*437bfbebSnyanmisaka 
40*437bfbebSnyanmisaka typedef struct {
41*437bfbebSnyanmisaka     RK_U32 rb_pos_x : 10;
42*437bfbebSnyanmisaka     RK_U32 reserved0 : 6;
43*437bfbebSnyanmisaka     RK_U32 rb_pos_y : 10;
44*437bfbebSnyanmisaka     RK_U32 reserved1 : 6;
45*437bfbebSnyanmisaka } OsdRbPos;
46*437bfbebSnyanmisaka 
47*437bfbebSnyanmisaka typedef struct OSD_POS_NEW {
48*437bfbebSnyanmisaka     OsdLtPos lt; /* left-top */
49*437bfbebSnyanmisaka     OsdRbPos rb; /* right-bottom */
50*437bfbebSnyanmisaka } OSD_POS_NEW;
51*437bfbebSnyanmisaka 
52*437bfbebSnyanmisaka /* class: control/link */
53*437bfbebSnyanmisaka /* 0x00000000 reg0 - 0x00000120 reg72 */
54*437bfbebSnyanmisaka typedef struct Vepu580ControlCfg_t {
55*437bfbebSnyanmisaka     /* 0x00000000 reg0 */
56*437bfbebSnyanmisaka     struct {
57*437bfbebSnyanmisaka         RK_U32 sub_ver      : 8;
58*437bfbebSnyanmisaka         RK_U32 cap     : 1;
59*437bfbebSnyanmisaka         RK_U32 hevc_cap     : 1;
60*437bfbebSnyanmisaka         RK_U32 reserved     : 2;
61*437bfbebSnyanmisaka         RK_U32 res_cap      : 4;
62*437bfbebSnyanmisaka         RK_U32 osd_cap      : 2;
63*437bfbebSnyanmisaka         RK_U32 filtr_cap    : 2;
64*437bfbebSnyanmisaka         RK_U32 bfrm_cap     : 1;
65*437bfbebSnyanmisaka         RK_U32 fbc_cap      : 2;
66*437bfbebSnyanmisaka         RK_U32 reserved1    : 1;
67*437bfbebSnyanmisaka         RK_U32 ip_id        : 8;
68*437bfbebSnyanmisaka     } version;
69*437bfbebSnyanmisaka 
70*437bfbebSnyanmisaka     /* 0x4 - 0xc */
71*437bfbebSnyanmisaka     RK_U32 reserved1_3[3];
72*437bfbebSnyanmisaka 
73*437bfbebSnyanmisaka     /* 0x00000010 reg4 */
74*437bfbebSnyanmisaka     struct {
75*437bfbebSnyanmisaka         RK_U32 lkt_num     : 8;
76*437bfbebSnyanmisaka         RK_U32 vepu_cmd    : 2;
77*437bfbebSnyanmisaka         RK_U32 reserved    : 22;
78*437bfbebSnyanmisaka     } enc_strt;
79*437bfbebSnyanmisaka 
80*437bfbebSnyanmisaka     /* 0x00000014 reg5 */
81*437bfbebSnyanmisaka     struct {
82*437bfbebSnyanmisaka         RK_U32 safe_clr     : 1;
83*437bfbebSnyanmisaka         RK_U32 force_clr    : 1;
84*437bfbebSnyanmisaka         RK_U32 reserved     : 30;
85*437bfbebSnyanmisaka     } enc_clr;
86*437bfbebSnyanmisaka 
87*437bfbebSnyanmisaka     /* 0x18 - 0x1c */
88*437bfbebSnyanmisaka     RK_U32 reserved6_7[2];
89*437bfbebSnyanmisaka 
90*437bfbebSnyanmisaka     /* 0x00000020 reg8 */
91*437bfbebSnyanmisaka     struct {
92*437bfbebSnyanmisaka         RK_U32 enc_done_en         : 1;
93*437bfbebSnyanmisaka         RK_U32 lkt_node_done_en    : 1;
94*437bfbebSnyanmisaka         RK_U32 sclr_done_en        : 1;
95*437bfbebSnyanmisaka         RK_U32 slc_done_en         : 1;
96*437bfbebSnyanmisaka         RK_U32 bsf_oflw_en         : 1;
97*437bfbebSnyanmisaka         RK_U32 brsp_otsd_en        : 1;
98*437bfbebSnyanmisaka         RK_U32 wbus_err_en         : 1;
99*437bfbebSnyanmisaka         RK_U32 rbus_err_en         : 1;
100*437bfbebSnyanmisaka         RK_U32 wdg_en              : 1;
101*437bfbebSnyanmisaka         RK_U32 lkt_err_int_en      : 1;
102*437bfbebSnyanmisaka         RK_U32 reserved            : 22;
103*437bfbebSnyanmisaka     } int_en;
104*437bfbebSnyanmisaka 
105*437bfbebSnyanmisaka     /* 0x00000024 reg9 */
106*437bfbebSnyanmisaka     struct {
107*437bfbebSnyanmisaka         RK_U32 enc_done_msk         : 1;
108*437bfbebSnyanmisaka         RK_U32 lkt_node_done_msk    : 1;
109*437bfbebSnyanmisaka         RK_U32 sclr_done_msk        : 1;
110*437bfbebSnyanmisaka         RK_U32 slc_done_msk         : 1;
111*437bfbebSnyanmisaka         RK_U32 bsf_oflw_msk         : 1;
112*437bfbebSnyanmisaka         RK_U32 brsp_otsd_msk        : 1;
113*437bfbebSnyanmisaka         RK_U32 wbus_err_msk         : 1;
114*437bfbebSnyanmisaka         RK_U32 rbus_err_msk         : 1;
115*437bfbebSnyanmisaka         RK_U32 wdg_msk              : 1;
116*437bfbebSnyanmisaka         RK_U32 lkt_err_msk          : 1;
117*437bfbebSnyanmisaka         RK_U32 reserved             : 22;
118*437bfbebSnyanmisaka     } int_msk;
119*437bfbebSnyanmisaka 
120*437bfbebSnyanmisaka     /* 0x00000028 reg10 */
121*437bfbebSnyanmisaka     struct {
122*437bfbebSnyanmisaka         RK_U32 enc_done_clr         : 1;
123*437bfbebSnyanmisaka         RK_U32 lkt_node_done_clr    : 1;
124*437bfbebSnyanmisaka         RK_U32 sclr_done_clr        : 1;
125*437bfbebSnyanmisaka         RK_U32 slc_done_clr         : 1;
126*437bfbebSnyanmisaka         RK_U32 bsf_oflw_clr         : 1;
127*437bfbebSnyanmisaka         RK_U32 brsp_otsd_clr        : 1;
128*437bfbebSnyanmisaka         RK_U32 wbus_err_clr         : 1;
129*437bfbebSnyanmisaka         RK_U32 rbus_err_clr         : 1;
130*437bfbebSnyanmisaka         RK_U32 wdg_clr              : 1;
131*437bfbebSnyanmisaka         RK_U32 lkt_err_clr          : 1;
132*437bfbebSnyanmisaka         RK_U32 reserved             : 22;
133*437bfbebSnyanmisaka     } int_clr;
134*437bfbebSnyanmisaka 
135*437bfbebSnyanmisaka     /* 0x0000002c reg11 */
136*437bfbebSnyanmisaka     struct {
137*437bfbebSnyanmisaka         RK_U32 enc_done_sta         : 1;
138*437bfbebSnyanmisaka         RK_U32 lkt_node_done_sta    : 1;
139*437bfbebSnyanmisaka         RK_U32 sclr_done_sta        : 1;
140*437bfbebSnyanmisaka         RK_U32 slc_done_sta         : 1;
141*437bfbebSnyanmisaka 
142*437bfbebSnyanmisaka         RK_U32 bsf_oflw_sta         : 1;
143*437bfbebSnyanmisaka         RK_U32 brsp_otsd_sta        : 1;
144*437bfbebSnyanmisaka         RK_U32 wbus_err_sta         : 1;
145*437bfbebSnyanmisaka         RK_U32 rbus_err_sta         : 1;
146*437bfbebSnyanmisaka 
147*437bfbebSnyanmisaka         RK_U32 wdg_sta              : 1;
148*437bfbebSnyanmisaka         RK_U32 lkt_err_sta          : 1;
149*437bfbebSnyanmisaka         RK_U32 reserved             : 22;
150*437bfbebSnyanmisaka     } int_sta;
151*437bfbebSnyanmisaka 
152*437bfbebSnyanmisaka     /* 0x00000030 reg12 */
153*437bfbebSnyanmisaka     struct {
154*437bfbebSnyanmisaka         RK_U32 lpfw_bus_ordr        : 1;
155*437bfbebSnyanmisaka         RK_U32 cmvw_bus_ordr        : 1;
156*437bfbebSnyanmisaka         RK_U32 dspw_bus_ordr        : 1;
157*437bfbebSnyanmisaka         RK_U32 rfpw_bus_ordr        : 1;
158*437bfbebSnyanmisaka         RK_U32 src_bus_edin         : 4;
159*437bfbebSnyanmisaka         RK_U32 meiw_bus_edin        : 4;
160*437bfbebSnyanmisaka         RK_U32 bsw_bus_edin         : 3;
161*437bfbebSnyanmisaka         RK_U32 lktr_bus_edin        : 4;
162*437bfbebSnyanmisaka         RK_U32 roir_bus_edin        : 4;
163*437bfbebSnyanmisaka         RK_U32 lktw_bus_edin        : 4;
164*437bfbebSnyanmisaka         RK_U32 afbc_bsize           : 1;
165*437bfbebSnyanmisaka         RK_U32 ebufw_bus_ordr       : 1;
166*437bfbebSnyanmisaka         RK_U32 rec_nfbc_bus_edin    : 3;
167*437bfbebSnyanmisaka     } dtrns_map;
168*437bfbebSnyanmisaka 
169*437bfbebSnyanmisaka     /* 0x00000034 reg13 */
170*437bfbebSnyanmisaka     struct {
171*437bfbebSnyanmisaka         RK_U32 reserved        : 7;
172*437bfbebSnyanmisaka         RK_U32 dspr_otsd       : 1;
173*437bfbebSnyanmisaka         RK_U32 reserved1       : 8;
174*437bfbebSnyanmisaka         RK_U32 axi_brsp_cke    : 8;
175*437bfbebSnyanmisaka         RK_U32 reserved2       : 8;
176*437bfbebSnyanmisaka     } dtrns_cfg;
177*437bfbebSnyanmisaka 
178*437bfbebSnyanmisaka     /* 0x00000038 reg14 */
179*437bfbebSnyanmisaka     struct {
180*437bfbebSnyanmisaka         RK_U32 vs_load_thd     : 24;
181*437bfbebSnyanmisaka         RK_U32 rfp_load_thd    : 8;
182*437bfbebSnyanmisaka     } enc_wdg;
183*437bfbebSnyanmisaka 
184*437bfbebSnyanmisaka     /* 0x0000003c reg15 */
185*437bfbebSnyanmisaka     struct {
186*437bfbebSnyanmisaka         RK_U32 hurry_en      : 1;
187*437bfbebSnyanmisaka         RK_U32 hurry_low     : 3;
188*437bfbebSnyanmisaka         RK_U32 hurry_mid     : 3;
189*437bfbebSnyanmisaka         RK_U32 hurry_high    : 3;
190*437bfbebSnyanmisaka         RK_U32 reserved      : 22;
191*437bfbebSnyanmisaka     } qos_cfg;
192*437bfbebSnyanmisaka 
193*437bfbebSnyanmisaka     /* 0x00000040 reg16 */
194*437bfbebSnyanmisaka     struct {
195*437bfbebSnyanmisaka         RK_U32 qos_period    : 16;
196*437bfbebSnyanmisaka         RK_U32 reserved      : 16;
197*437bfbebSnyanmisaka     } qos_perd;
198*437bfbebSnyanmisaka 
199*437bfbebSnyanmisaka     /* 0x00000044 reg17 */
200*437bfbebSnyanmisaka     RK_U32 hurry_thd_low;
201*437bfbebSnyanmisaka 
202*437bfbebSnyanmisaka     /* 0x00000048 reg18 */
203*437bfbebSnyanmisaka     RK_U32 hurry_thd_mid;
204*437bfbebSnyanmisaka 
205*437bfbebSnyanmisaka     /* 0x0000004c reg19 */
206*437bfbebSnyanmisaka     RK_U32 hurry_thd_high;
207*437bfbebSnyanmisaka 
208*437bfbebSnyanmisaka     /* 0x00000050 reg20 */
209*437bfbebSnyanmisaka     struct {
210*437bfbebSnyanmisaka         RK_U32 idle_en_core    : 1;
211*437bfbebSnyanmisaka         RK_U32 idle_en_axi     : 1;
212*437bfbebSnyanmisaka         RK_U32 idle_en_ahb     : 1;
213*437bfbebSnyanmisaka         RK_U32 reserved        : 29;
214*437bfbebSnyanmisaka     } enc_idle_en;
215*437bfbebSnyanmisaka 
216*437bfbebSnyanmisaka     /* 0x00000054 reg21 */
217*437bfbebSnyanmisaka     struct {
218*437bfbebSnyanmisaka         RK_U32 cke                 : 1;
219*437bfbebSnyanmisaka         RK_U32 resetn_hw_en        : 1;
220*437bfbebSnyanmisaka         RK_U32 enc_done_tmvp_en    : 1;
221*437bfbebSnyanmisaka         RK_U32 sram_ckg_en         : 1;
222*437bfbebSnyanmisaka         RK_U32 reserved            : 28;
223*437bfbebSnyanmisaka     } func_en;
224*437bfbebSnyanmisaka 
225*437bfbebSnyanmisaka     /* 0x00000058 reg22 */
226*437bfbebSnyanmisaka     struct {
227*437bfbebSnyanmisaka         RK_U32 tq8_ckg           : 1;
228*437bfbebSnyanmisaka         RK_U32 tq4_ckg           : 1;
229*437bfbebSnyanmisaka         RK_U32 bits_ckg_8x8      : 1;
230*437bfbebSnyanmisaka         RK_U32 bits_ckg_4x4_1    : 1;
231*437bfbebSnyanmisaka         RK_U32 bits_ckg_4x4_0    : 1;
232*437bfbebSnyanmisaka         RK_U32 inter_mode_ckg    : 1;
233*437bfbebSnyanmisaka         RK_U32 inter_ctrl_ckg    : 1;
234*437bfbebSnyanmisaka         RK_U32 inter_pred_ckg    : 1;
235*437bfbebSnyanmisaka         RK_U32 intra8_ckg        : 1;
236*437bfbebSnyanmisaka         RK_U32 intra4_ckg        : 1;
237*437bfbebSnyanmisaka         RK_U32 reserved          : 22;
238*437bfbebSnyanmisaka     } rdo_ckg;
239*437bfbebSnyanmisaka 
240*437bfbebSnyanmisaka     /* 0x0000005c reg23 */
241*437bfbebSnyanmisaka     struct {
242*437bfbebSnyanmisaka         RK_U32 core_id     : 2;
243*437bfbebSnyanmisaka         RK_U32 reserved    : 30;
244*437bfbebSnyanmisaka     } enc_id;
245*437bfbebSnyanmisaka } Vepu580ControlCfg;
246*437bfbebSnyanmisaka 
247*437bfbebSnyanmisaka /* class: buffer/video syntax */
248*437bfbebSnyanmisaka /* 0x00000280 reg160 - 0x000003f4 reg253*/
249*437bfbebSnyanmisaka typedef struct Vepu580BaseCfg_t {
250*437bfbebSnyanmisaka     /* 0x00000280 reg160 */
251*437bfbebSnyanmisaka     RK_U32 adr_src0;
252*437bfbebSnyanmisaka 
253*437bfbebSnyanmisaka     /* 0x00000284 reg161 */
254*437bfbebSnyanmisaka     RK_U32 adr_src1;
255*437bfbebSnyanmisaka 
256*437bfbebSnyanmisaka     /* 0x00000288 reg162 */
257*437bfbebSnyanmisaka     RK_U32 adr_src2;
258*437bfbebSnyanmisaka 
259*437bfbebSnyanmisaka     /* 0x0000028c reg163 */
260*437bfbebSnyanmisaka     RK_U32 rfpw_h_addr;
261*437bfbebSnyanmisaka 
262*437bfbebSnyanmisaka     /* 0x00000290 reg164 */
263*437bfbebSnyanmisaka     RK_U32 rfpw_b_addr;
264*437bfbebSnyanmisaka 
265*437bfbebSnyanmisaka     /* 0x00000294 reg165 */
266*437bfbebSnyanmisaka     RK_U32 rfpr_h_addr;
267*437bfbebSnyanmisaka 
268*437bfbebSnyanmisaka     /* 0x00000298 reg166 */
269*437bfbebSnyanmisaka     RK_U32 rfpr_b_addr;
270*437bfbebSnyanmisaka 
271*437bfbebSnyanmisaka     /* 0x0000029c reg167 */
272*437bfbebSnyanmisaka     RK_U32 cmvw_addr;
273*437bfbebSnyanmisaka 
274*437bfbebSnyanmisaka     /* 0x000002a0 reg168 */
275*437bfbebSnyanmisaka     RK_U32 cmvr_addr;
276*437bfbebSnyanmisaka 
277*437bfbebSnyanmisaka     /* 0x000002a4 reg169 */
278*437bfbebSnyanmisaka     RK_U32 dspw_addr;
279*437bfbebSnyanmisaka 
280*437bfbebSnyanmisaka     /* 0x000002a8 reg170 */
281*437bfbebSnyanmisaka     RK_U32 dspr_addr;
282*437bfbebSnyanmisaka 
283*437bfbebSnyanmisaka     /* 0x000002ac reg171 */
284*437bfbebSnyanmisaka     RK_U32 meiw_addr;
285*437bfbebSnyanmisaka 
286*437bfbebSnyanmisaka     /* 0x000002b0 reg172 */
287*437bfbebSnyanmisaka     RK_U32 bsbt_addr;
288*437bfbebSnyanmisaka 
289*437bfbebSnyanmisaka     /* 0x000002b4 reg173 */
290*437bfbebSnyanmisaka     RK_U32 bsbb_addr;
291*437bfbebSnyanmisaka 
292*437bfbebSnyanmisaka     /* 0x000002b8 reg174 */
293*437bfbebSnyanmisaka     RK_U32 bsbr_addr;
294*437bfbebSnyanmisaka 
295*437bfbebSnyanmisaka     /* 0x000002bc reg175 */
296*437bfbebSnyanmisaka     RK_U32 adr_bsbs;
297*437bfbebSnyanmisaka 
298*437bfbebSnyanmisaka     /* 0x000002c0 reg176 */
299*437bfbebSnyanmisaka     RK_U32 lpfw_addr;
300*437bfbebSnyanmisaka 
301*437bfbebSnyanmisaka     /* 0x000002c4 reg177 */
302*437bfbebSnyanmisaka     RK_U32 lpfr_addr;
303*437bfbebSnyanmisaka 
304*437bfbebSnyanmisaka     /* 0x000002c8 reg178 */
305*437bfbebSnyanmisaka     RK_U32 roi_addr;
306*437bfbebSnyanmisaka 
307*437bfbebSnyanmisaka     /* 0x000002cc reg179 */
308*437bfbebSnyanmisaka     RK_U32 roi_qp_addr;
309*437bfbebSnyanmisaka 
310*437bfbebSnyanmisaka     /* 0x000002d0 reg180 */
311*437bfbebSnyanmisaka     RK_U32 qoi_amv_addr;
312*437bfbebSnyanmisaka 
313*437bfbebSnyanmisaka     /* 0x000002d4 reg181 */
314*437bfbebSnyanmisaka     RK_U32 qoi_mv_addr;
315*437bfbebSnyanmisaka 
316*437bfbebSnyanmisaka     /* 0x000002d8 reg182 */
317*437bfbebSnyanmisaka     RK_U32 ebuft_addr;
318*437bfbebSnyanmisaka 
319*437bfbebSnyanmisaka     /* 0x000002dc reg183 */
320*437bfbebSnyanmisaka     RK_U32 ebufb_addr;
321*437bfbebSnyanmisaka 
322*437bfbebSnyanmisaka     /* 0x2e0 - 0x2fc */
323*437bfbebSnyanmisaka     RK_U32 reserved184_191[8];
324*437bfbebSnyanmisaka 
325*437bfbebSnyanmisaka     /* 0x00000300 reg192 */
326*437bfbebSnyanmisaka     struct {
327*437bfbebSnyanmisaka         RK_U32 enc_stnd           : 1;
328*437bfbebSnyanmisaka         RK_U32 roi_en             : 1;
329*437bfbebSnyanmisaka         RK_U32 cur_frm_ref        : 1;
330*437bfbebSnyanmisaka         RK_U32 mei_stor           : 1;
331*437bfbebSnyanmisaka         RK_U32 bs_scp             : 1;
332*437bfbebSnyanmisaka         RK_U32 reserved           : 3;
333*437bfbebSnyanmisaka         RK_U32 pic_qp             : 6;
334*437bfbebSnyanmisaka         RK_U32 num_pic_tot_cur    : 5;
335*437bfbebSnyanmisaka         RK_U32 log2_ctu_num       : 5;
336*437bfbebSnyanmisaka         RK_U32 reserved1          : 6;
337*437bfbebSnyanmisaka         RK_U32 slen_fifo          : 1;
338*437bfbebSnyanmisaka         RK_U32 rec_fbc_dis        : 1;
339*437bfbebSnyanmisaka     } enc_pic;
340*437bfbebSnyanmisaka 
341*437bfbebSnyanmisaka     /* 0x00000304 reg193 */
342*437bfbebSnyanmisaka     struct {
343*437bfbebSnyanmisaka         RK_U32 dchs_txid    : 2;
344*437bfbebSnyanmisaka         RK_U32 dchs_rxid    : 2;
345*437bfbebSnyanmisaka         RK_U32 dchs_txe     : 1;
346*437bfbebSnyanmisaka         RK_U32 dchs_rxe     : 1;
347*437bfbebSnyanmisaka         RK_U32 reserved     : 10;
348*437bfbebSnyanmisaka         RK_U32 dchs_ofst    : 11;
349*437bfbebSnyanmisaka         RK_U32 reserved1    : 5;
350*437bfbebSnyanmisaka     } dual_core;
351*437bfbebSnyanmisaka 
352*437bfbebSnyanmisaka     /* 0x308 - 0x30c */
353*437bfbebSnyanmisaka     RK_U32 reserved194_195[2];
354*437bfbebSnyanmisaka 
355*437bfbebSnyanmisaka     /* 0x00000310 reg196 */
356*437bfbebSnyanmisaka     struct {
357*437bfbebSnyanmisaka         RK_U32 pic_wd8_m1    : 11;
358*437bfbebSnyanmisaka         RK_U32 reserved      : 5;
359*437bfbebSnyanmisaka         RK_U32 pic_hd8_m1    : 11;
360*437bfbebSnyanmisaka         RK_U32 reserved1     : 5;
361*437bfbebSnyanmisaka     } enc_rsl;
362*437bfbebSnyanmisaka 
363*437bfbebSnyanmisaka     /* 0x00000314 reg197 */
364*437bfbebSnyanmisaka     struct {
365*437bfbebSnyanmisaka         RK_U32 pic_wfill    : 6;
366*437bfbebSnyanmisaka         RK_U32 reserved     : 10;
367*437bfbebSnyanmisaka         RK_U32 pic_hfill    : 6;
368*437bfbebSnyanmisaka         RK_U32 reserved1    : 10;
369*437bfbebSnyanmisaka     } src_fill;
370*437bfbebSnyanmisaka 
371*437bfbebSnyanmisaka     /* 0x00000318 reg198 */
372*437bfbebSnyanmisaka     struct {
373*437bfbebSnyanmisaka         RK_U32 alpha_swap    : 1;
374*437bfbebSnyanmisaka         RK_U32 rbuv_swap     : 1;
375*437bfbebSnyanmisaka         RK_U32 src_cfmt      : 4;
376*437bfbebSnyanmisaka         RK_U32 src_range     : 1;
377*437bfbebSnyanmisaka         RK_U32 out_fmt       : 1;
378*437bfbebSnyanmisaka         RK_U32 reserved      : 24;
379*437bfbebSnyanmisaka     } src_fmt;
380*437bfbebSnyanmisaka 
381*437bfbebSnyanmisaka     /* 0x0000031c reg199 */
382*437bfbebSnyanmisaka     struct {
383*437bfbebSnyanmisaka         RK_U32 csc_wgt_b2y    : 9;
384*437bfbebSnyanmisaka         RK_U32 csc_wgt_g2y    : 9;
385*437bfbebSnyanmisaka         RK_U32 csc_wgt_r2y    : 9;
386*437bfbebSnyanmisaka         RK_U32 reserved       : 5;
387*437bfbebSnyanmisaka     } src_udfy;
388*437bfbebSnyanmisaka 
389*437bfbebSnyanmisaka     /* 0x00000320 reg200 */
390*437bfbebSnyanmisaka     struct {
391*437bfbebSnyanmisaka         RK_U32 csc_wgt_b2u    : 9;
392*437bfbebSnyanmisaka         RK_U32 csc_wgt_g2u    : 9;
393*437bfbebSnyanmisaka         RK_U32 csc_wgt_r2u    : 9;
394*437bfbebSnyanmisaka         RK_U32 reserved       : 5;
395*437bfbebSnyanmisaka     } src_udfu;
396*437bfbebSnyanmisaka 
397*437bfbebSnyanmisaka     /* 0x00000324 reg201 */
398*437bfbebSnyanmisaka     struct {
399*437bfbebSnyanmisaka         RK_U32 csc_wgt_b2v    : 9;
400*437bfbebSnyanmisaka         RK_U32 csc_wgt_g2v    : 9;
401*437bfbebSnyanmisaka         RK_U32 csc_wgt_r2v    : 9;
402*437bfbebSnyanmisaka         RK_U32 reserved       : 5;
403*437bfbebSnyanmisaka     } src_udfv;
404*437bfbebSnyanmisaka 
405*437bfbebSnyanmisaka     /* 0x00000328 reg202 */
406*437bfbebSnyanmisaka     struct {
407*437bfbebSnyanmisaka         RK_U32 csc_ofst_v    : 8;
408*437bfbebSnyanmisaka         RK_U32 csc_ofst_u    : 8;
409*437bfbebSnyanmisaka         RK_U32 csc_ofst_y    : 5;
410*437bfbebSnyanmisaka         RK_U32 reserved      : 11;
411*437bfbebSnyanmisaka     } src_udfo;
412*437bfbebSnyanmisaka 
413*437bfbebSnyanmisaka     /* 0x0000032c reg203 */
414*437bfbebSnyanmisaka     struct {
415*437bfbebSnyanmisaka         RK_U32 reserved0   : 26;
416*437bfbebSnyanmisaka         RK_U32 src_mirr    : 1;
417*437bfbebSnyanmisaka         RK_U32 src_rot     : 2;
418*437bfbebSnyanmisaka         RK_U32 txa_en      : 1;
419*437bfbebSnyanmisaka         RK_U32 afbcd_en    : 1;
420*437bfbebSnyanmisaka         RK_U32 reserved1   : 1;
421*437bfbebSnyanmisaka     } src_proc;
422*437bfbebSnyanmisaka 
423*437bfbebSnyanmisaka     /* 0x00000330 reg204 */
424*437bfbebSnyanmisaka     struct {
425*437bfbebSnyanmisaka         RK_U32 pic_ofst_x    : 14;
426*437bfbebSnyanmisaka         RK_U32 reserved      : 2;
427*437bfbebSnyanmisaka         RK_U32 pic_ofst_y    : 14;
428*437bfbebSnyanmisaka         RK_U32 reserved1     : 2;
429*437bfbebSnyanmisaka     } pic_ofst;
430*437bfbebSnyanmisaka 
431*437bfbebSnyanmisaka     /* 0x00000334 reg205 */
432*437bfbebSnyanmisaka     struct {
433*437bfbebSnyanmisaka         RK_U32 src_strd0    : 17;
434*437bfbebSnyanmisaka         RK_U32 reserved     : 15;
435*437bfbebSnyanmisaka     } src_strd0;
436*437bfbebSnyanmisaka 
437*437bfbebSnyanmisaka     /* 0x00000338 reg206 */
438*437bfbebSnyanmisaka     struct {
439*437bfbebSnyanmisaka         RK_U32 src_strd1    : 16;
440*437bfbebSnyanmisaka         RK_U32 reserved     : 16;
441*437bfbebSnyanmisaka     } src_strd1;
442*437bfbebSnyanmisaka 
443*437bfbebSnyanmisaka     /* 0x33c - 0x34c */
444*437bfbebSnyanmisaka     RK_U32 reserved207_211[5];
445*437bfbebSnyanmisaka 
446*437bfbebSnyanmisaka     /* 0x00000350 reg212 */
447*437bfbebSnyanmisaka     struct {
448*437bfbebSnyanmisaka         RK_U32 rc_en         : 1;
449*437bfbebSnyanmisaka         RK_U32 aq_en         : 1;
450*437bfbebSnyanmisaka         RK_U32 aq_mode       : 1;
451*437bfbebSnyanmisaka         RK_U32 reserved      : 9;
452*437bfbebSnyanmisaka         RK_U32 rc_ctu_num    : 20;
453*437bfbebSnyanmisaka     } rc_cfg;
454*437bfbebSnyanmisaka 
455*437bfbebSnyanmisaka     /* 0x00000354 reg213 */
456*437bfbebSnyanmisaka     struct {
457*437bfbebSnyanmisaka         RK_U32 reserved       : 16;
458*437bfbebSnyanmisaka         RK_U32 rc_qp_range    : 4;
459*437bfbebSnyanmisaka         RK_U32 rc_max_qp      : 6;
460*437bfbebSnyanmisaka         RK_U32 rc_min_qp      : 6;
461*437bfbebSnyanmisaka     } rc_qp;
462*437bfbebSnyanmisaka 
463*437bfbebSnyanmisaka     /* 0x00000358 reg214 */
464*437bfbebSnyanmisaka     struct {
465*437bfbebSnyanmisaka         RK_U32 ctu_ebit    : 20;
466*437bfbebSnyanmisaka         RK_U32 reserved    : 12;
467*437bfbebSnyanmisaka     } rc_tgt;
468*437bfbebSnyanmisaka 
469*437bfbebSnyanmisaka     /* 0x35c */
470*437bfbebSnyanmisaka     RK_U32 reserved_215;
471*437bfbebSnyanmisaka 
472*437bfbebSnyanmisaka     /* 0x00000360 reg216 */
473*437bfbebSnyanmisaka     struct {
474*437bfbebSnyanmisaka         RK_U32 sli_splt          : 1;
475*437bfbebSnyanmisaka         RK_U32 sli_splt_mode     : 1;
476*437bfbebSnyanmisaka         RK_U32 sli_splt_cpst     : 1;
477*437bfbebSnyanmisaka         RK_U32 reserved          : 12;
478*437bfbebSnyanmisaka         RK_U32 sli_flsh          : 1;
479*437bfbebSnyanmisaka         RK_U32 sli_max_num_m1    : 15;
480*437bfbebSnyanmisaka         RK_U32 reserved1         : 1;
481*437bfbebSnyanmisaka     } sli_splt;
482*437bfbebSnyanmisaka 
483*437bfbebSnyanmisaka     /* 0x00000364 reg217 */
484*437bfbebSnyanmisaka     struct {
485*437bfbebSnyanmisaka         RK_U32 sli_splt_byte    : 20;
486*437bfbebSnyanmisaka         RK_U32 reserved         : 12;
487*437bfbebSnyanmisaka     } sli_byte;
488*437bfbebSnyanmisaka 
489*437bfbebSnyanmisaka     /* 0x00000368 reg218 */
490*437bfbebSnyanmisaka     struct {
491*437bfbebSnyanmisaka         RK_U32 sli_splt_cnum_m1    : 20;
492*437bfbebSnyanmisaka         RK_U32 reserved            : 12;
493*437bfbebSnyanmisaka     } sli_cnum;
494*437bfbebSnyanmisaka 
495*437bfbebSnyanmisaka     /* 0x36c */
496*437bfbebSnyanmisaka     RK_U32 reserved_219;
497*437bfbebSnyanmisaka 
498*437bfbebSnyanmisaka     /* 0x00000370 reg220 */
499*437bfbebSnyanmisaka     struct {
500*437bfbebSnyanmisaka         RK_U32 cme_srch_h     : 4;
501*437bfbebSnyanmisaka         RK_U32 cme_srch_v     : 4;
502*437bfbebSnyanmisaka         RK_U32 rme_srch_h     : 3;
503*437bfbebSnyanmisaka         RK_U32 rme_srch_v     : 3;
504*437bfbebSnyanmisaka         RK_U32 reserved       : 2;
505*437bfbebSnyanmisaka         RK_U32 dlt_frm_num    : 16;
506*437bfbebSnyanmisaka     } me_rnge;
507*437bfbebSnyanmisaka 
508*437bfbebSnyanmisaka     /* 0x00000374 reg221 */
509*437bfbebSnyanmisaka     struct {
510*437bfbebSnyanmisaka         RK_U32 pmv_mdst_h      : 8;
511*437bfbebSnyanmisaka         RK_U32 pmv_mdst_v      : 8;
512*437bfbebSnyanmisaka         RK_U32 mv_limit        : 2;
513*437bfbebSnyanmisaka         RK_U32 pmv_num         : 2;
514*437bfbebSnyanmisaka         RK_U32 colmv_stor      : 1;
515*437bfbebSnyanmisaka         RK_U32 colmv_load      : 1;
516*437bfbebSnyanmisaka         RK_U32 rme_dis         : 3;
517*437bfbebSnyanmisaka         RK_U32 reserved        : 2;
518*437bfbebSnyanmisaka         RK_U32 fme_dis         : 3;
519*437bfbebSnyanmisaka         RK_U32 reserved1       : 1;
520*437bfbebSnyanmisaka         RK_U32 lvl4_ovrd_en    : 1;
521*437bfbebSnyanmisaka     } me_cfg;
522*437bfbebSnyanmisaka 
523*437bfbebSnyanmisaka     /* 0x00000378 reg222 */
524*437bfbebSnyanmisaka     struct {
525*437bfbebSnyanmisaka         RK_U32 cme_rama_max      : 11;
526*437bfbebSnyanmisaka         RK_U32 cme_rama_h        : 5;
527*437bfbebSnyanmisaka         RK_U32 cach_l2_tag       : 2;
528*437bfbebSnyanmisaka         RK_U32 cme_linebuf_w     : 9;
529*437bfbebSnyanmisaka         RK_U32 reserved          : 5;
530*437bfbebSnyanmisaka     } me_cach;
531*437bfbebSnyanmisaka 
532*437bfbebSnyanmisaka     /* 0x37c */
533*437bfbebSnyanmisaka     RK_U32 reserved_223;
534*437bfbebSnyanmisaka 
535*437bfbebSnyanmisaka     /* 0x00000380 reg224 */
536*437bfbebSnyanmisaka     struct {
537*437bfbebSnyanmisaka         RK_U32 gmv_x        : 13;
538*437bfbebSnyanmisaka         RK_U32 reserved     : 3;
539*437bfbebSnyanmisaka         RK_U32 gmv_y        : 13;
540*437bfbebSnyanmisaka         RK_U32 reserved1    : 3;
541*437bfbebSnyanmisaka     } gmv;
542*437bfbebSnyanmisaka 
543*437bfbebSnyanmisaka     /* 0x384 - 0x38c */
544*437bfbebSnyanmisaka     RK_U32 reserved225_227[3];
545*437bfbebSnyanmisaka 
546*437bfbebSnyanmisaka     /* 0x00000390 reg228 */
547*437bfbebSnyanmisaka     struct {
548*437bfbebSnyanmisaka         RK_U32 roi_qp_en     : 1;
549*437bfbebSnyanmisaka         RK_U32 roi_amv_en    : 1;
550*437bfbebSnyanmisaka         RK_U32 roi_mv_en     : 1;
551*437bfbebSnyanmisaka         RK_U32 reserved      : 29;
552*437bfbebSnyanmisaka     } roi_en;
553*437bfbebSnyanmisaka 
554*437bfbebSnyanmisaka     /* 0x394 - 0x39c */
555*437bfbebSnyanmisaka     RK_U32 reserved229_231[3];
556*437bfbebSnyanmisaka 
557*437bfbebSnyanmisaka     /* 0x000003a0 reg232 */
558*437bfbebSnyanmisaka     struct {
559*437bfbebSnyanmisaka         RK_U32 rect_size      : 1;
560*437bfbebSnyanmisaka         RK_U32 inter_4x4      : 1;
561*437bfbebSnyanmisaka         RK_U32 arb_sel        : 1;
562*437bfbebSnyanmisaka         RK_U32 vlc_lmt        : 1;
563*437bfbebSnyanmisaka         RK_U32 chrm_spcl      : 1;
564*437bfbebSnyanmisaka         RK_U32 rdo_mask       : 8;
565*437bfbebSnyanmisaka         RK_U32 ccwa_e         : 1;
566*437bfbebSnyanmisaka         RK_U32 reserved       : 1;
567*437bfbebSnyanmisaka         RK_U32 atr_e          : 1;
568*437bfbebSnyanmisaka         RK_U32 reserved1      : 3;
569*437bfbebSnyanmisaka         RK_U32 atf_intra_e    : 1;
570*437bfbebSnyanmisaka         RK_U32 scl_lst_sel    : 2;
571*437bfbebSnyanmisaka         RK_U32 reserved2      : 10;
572*437bfbebSnyanmisaka     } rdo_cfg;
573*437bfbebSnyanmisaka 
574*437bfbebSnyanmisaka     /* 0x000003a4 reg233 */
575*437bfbebSnyanmisaka     struct {
576*437bfbebSnyanmisaka         RK_U32 vthd_y       : 12;
577*437bfbebSnyanmisaka         RK_U32 reserved     : 4;
578*437bfbebSnyanmisaka         RK_U32 vthd_c       : 12;
579*437bfbebSnyanmisaka         RK_U32 reserved1    : 4;
580*437bfbebSnyanmisaka     } iprd_csts;
581*437bfbebSnyanmisaka 
582*437bfbebSnyanmisaka     /* 0x3a8 - 0x3ac */
583*437bfbebSnyanmisaka     RK_U32 reserved234_235[2];
584*437bfbebSnyanmisaka 
585*437bfbebSnyanmisaka     /* 0x000003b0 reg236 */
586*437bfbebSnyanmisaka     struct {
587*437bfbebSnyanmisaka         RK_U32 nal_ref_idc      : 2;
588*437bfbebSnyanmisaka         RK_U32 nal_unit_type    : 5;
589*437bfbebSnyanmisaka         RK_U32 reserved         : 25;
590*437bfbebSnyanmisaka     } synt_nal;
591*437bfbebSnyanmisaka 
592*437bfbebSnyanmisaka     /* 0x000003b4 reg237 */
593*437bfbebSnyanmisaka     struct {
594*437bfbebSnyanmisaka         RK_U32 max_fnum    : 4;
595*437bfbebSnyanmisaka         RK_U32 drct_8x8    : 1;
596*437bfbebSnyanmisaka         RK_U32 mpoc_lm4    : 4;
597*437bfbebSnyanmisaka         RK_U32 reserved    : 23;
598*437bfbebSnyanmisaka     } synt_sps;
599*437bfbebSnyanmisaka 
600*437bfbebSnyanmisaka     /* 0x000003b8 reg238 */
601*437bfbebSnyanmisaka     struct {
602*437bfbebSnyanmisaka         RK_U32 etpy_mode       : 1;
603*437bfbebSnyanmisaka         RK_U32 trns_8x8        : 1;
604*437bfbebSnyanmisaka         RK_U32 csip_flag       : 1;
605*437bfbebSnyanmisaka         RK_U32 num_ref0_idx    : 2;
606*437bfbebSnyanmisaka         RK_U32 num_ref1_idx    : 2;
607*437bfbebSnyanmisaka         RK_U32 pic_init_qp     : 6;
608*437bfbebSnyanmisaka         RK_U32 cb_ofst         : 5;
609*437bfbebSnyanmisaka         RK_U32 cr_ofst         : 5;
610*437bfbebSnyanmisaka         RK_U32 wght_pred       : 1;
611*437bfbebSnyanmisaka         RK_U32 dbf_cp_flg      : 1;
612*437bfbebSnyanmisaka         RK_U32 reserved        : 7;
613*437bfbebSnyanmisaka     } synt_pps;
614*437bfbebSnyanmisaka 
615*437bfbebSnyanmisaka     /* 0x000003bc reg239 */
616*437bfbebSnyanmisaka     struct {
617*437bfbebSnyanmisaka         RK_U32 sli_type        : 2;
618*437bfbebSnyanmisaka         RK_U32 pps_id          : 8;
619*437bfbebSnyanmisaka         RK_U32 drct_smvp       : 1;
620*437bfbebSnyanmisaka         RK_U32 num_ref_ovrd    : 1;
621*437bfbebSnyanmisaka         RK_U32 cbc_init_idc    : 2;
622*437bfbebSnyanmisaka         RK_U32 reserved        : 2;
623*437bfbebSnyanmisaka         RK_U32 frm_num         : 16;
624*437bfbebSnyanmisaka     } synt_sli0;
625*437bfbebSnyanmisaka 
626*437bfbebSnyanmisaka     /* 0x000003c0 reg240 */
627*437bfbebSnyanmisaka     struct {
628*437bfbebSnyanmisaka         RK_U32 idr_pid    : 16;
629*437bfbebSnyanmisaka         RK_U32 poc_lsb    : 16;
630*437bfbebSnyanmisaka     } synt_sli1;
631*437bfbebSnyanmisaka 
632*437bfbebSnyanmisaka     /* 0x000003c4 reg241 */
633*437bfbebSnyanmisaka     struct {
634*437bfbebSnyanmisaka         RK_U32 rodr_pic_idx      : 2;
635*437bfbebSnyanmisaka         RK_U32 ref_list0_rodr    : 1;
636*437bfbebSnyanmisaka         RK_U32 sli_beta_ofst     : 4;
637*437bfbebSnyanmisaka         RK_U32 sli_alph_ofst     : 4;
638*437bfbebSnyanmisaka         RK_U32 dis_dblk_idc      : 2;
639*437bfbebSnyanmisaka         RK_U32 reserved          : 3;
640*437bfbebSnyanmisaka         RK_U32 rodr_pic_num      : 16;
641*437bfbebSnyanmisaka     } synt_sli2;
642*437bfbebSnyanmisaka 
643*437bfbebSnyanmisaka     /* 0x000003c8 reg242 */
644*437bfbebSnyanmisaka     struct {
645*437bfbebSnyanmisaka         RK_U32 nopp_flg      : 1;
646*437bfbebSnyanmisaka         RK_U32 ltrf_flg      : 1;
647*437bfbebSnyanmisaka         RK_U32 arpm_flg      : 1;
648*437bfbebSnyanmisaka         RK_U32 mmco4_pre     : 1;
649*437bfbebSnyanmisaka         RK_U32 mmco_type0    : 3;
650*437bfbebSnyanmisaka         RK_U32 mmco_parm0    : 16;
651*437bfbebSnyanmisaka         RK_U32 mmco_type1    : 3;
652*437bfbebSnyanmisaka         RK_U32 mmco_type2    : 3;
653*437bfbebSnyanmisaka         RK_U32 reserved      : 3;
654*437bfbebSnyanmisaka     } synt_refm0;
655*437bfbebSnyanmisaka 
656*437bfbebSnyanmisaka     /* 0x000003cc reg243 */
657*437bfbebSnyanmisaka     struct {
658*437bfbebSnyanmisaka         RK_U32 mmco_parm1    : 16;
659*437bfbebSnyanmisaka         RK_U32 mmco_parm2    : 16;
660*437bfbebSnyanmisaka     } synt_refm1;
661*437bfbebSnyanmisaka 
662*437bfbebSnyanmisaka     /* 0x000003d0 reg244 */
663*437bfbebSnyanmisaka     struct {
664*437bfbebSnyanmisaka         RK_U32 long_term_frame_idx0    : 4;
665*437bfbebSnyanmisaka         RK_U32 long_term_frame_idx1    : 4;
666*437bfbebSnyanmisaka         RK_U32 long_term_frame_idx2    : 4;
667*437bfbebSnyanmisaka         RK_U32 reserved                : 20;
668*437bfbebSnyanmisaka     } synt_refm2;
669*437bfbebSnyanmisaka 
670*437bfbebSnyanmisaka     /* 0x000003d4 reg245 */
671*437bfbebSnyanmisaka     struct {
672*437bfbebSnyanmisaka         RK_U32 dlt_poc_s0_m12    : 16;
673*437bfbebSnyanmisaka         RK_U32 dlt_poc_s0_m13    : 16;
674*437bfbebSnyanmisaka     } synt_refm3_hevc;
675*437bfbebSnyanmisaka 
676*437bfbebSnyanmisaka     /* 0x000003d8 reg246 */
677*437bfbebSnyanmisaka     struct {
678*437bfbebSnyanmisaka         RK_U32 poc_lsb_lt1    : 16;
679*437bfbebSnyanmisaka         RK_U32 poc_lsb_lt2    : 16;
680*437bfbebSnyanmisaka     } synt_long_refm0;
681*437bfbebSnyanmisaka 
682*437bfbebSnyanmisaka     /* 0x000003dc reg247 */
683*437bfbebSnyanmisaka     struct {
684*437bfbebSnyanmisaka         RK_U32 dlt_poc_msb_cycl1    : 16;
685*437bfbebSnyanmisaka         RK_U32 dlt_poc_msb_cycl2    : 16;
686*437bfbebSnyanmisaka     } synt_long_refm1;
687*437bfbebSnyanmisaka 
688*437bfbebSnyanmisaka     /* 0x3e0 - 0x3ec */
689*437bfbebSnyanmisaka     RK_U32 reserved248_251[4];
690*437bfbebSnyanmisaka 
691*437bfbebSnyanmisaka     /* 0x000003f0 reg252 */
692*437bfbebSnyanmisaka     struct {
693*437bfbebSnyanmisaka         RK_U32 mv_v_lmt_thd    : 14;
694*437bfbebSnyanmisaka         RK_U32 reserved        : 1;
695*437bfbebSnyanmisaka         RK_U32 mv_v_lmt_en     : 1;
696*437bfbebSnyanmisaka         RK_U32 reserved1       : 15;
697*437bfbebSnyanmisaka         RK_U32 sli_crs_en      : 1;
698*437bfbebSnyanmisaka     } sli_cfg;
699*437bfbebSnyanmisaka 
700*437bfbebSnyanmisaka     /* 0x000003f4 reg253 */
701*437bfbebSnyanmisaka     struct {
702*437bfbebSnyanmisaka         RK_U32 tile_x       : 8;
703*437bfbebSnyanmisaka         RK_U32 reserved     : 8;
704*437bfbebSnyanmisaka         RK_U32 tile_y       : 8;
705*437bfbebSnyanmisaka         RK_U32 reserved1    : 8;
706*437bfbebSnyanmisaka     } tile_pos;
707*437bfbebSnyanmisaka } Vepu580BaseCfg;
708*437bfbebSnyanmisaka 
709*437bfbebSnyanmisaka /* class: rc/roi/aq/klut */
710*437bfbebSnyanmisaka /* 0x00001000 reg1024 - 0x000010e0 reg1080 */
711*437bfbebSnyanmisaka typedef struct Vepu580RcKlutCfg_t {
712*437bfbebSnyanmisaka     /* 0x00001000 reg1024 */
713*437bfbebSnyanmisaka     struct {
714*437bfbebSnyanmisaka         RK_U32 qp_adj0     : 5;
715*437bfbebSnyanmisaka         RK_U32 qp_adj1     : 5;
716*437bfbebSnyanmisaka         RK_U32 qp_adj2     : 5;
717*437bfbebSnyanmisaka         RK_U32 qp_adj3     : 5;
718*437bfbebSnyanmisaka         RK_U32 qp_adj4     : 5;
719*437bfbebSnyanmisaka         RK_U32 reserved    : 7;
720*437bfbebSnyanmisaka     } rc_adj0;
721*437bfbebSnyanmisaka 
722*437bfbebSnyanmisaka     /* 0x00001004 reg1025 */
723*437bfbebSnyanmisaka     struct {
724*437bfbebSnyanmisaka         RK_U32 qp_adj5     : 5;
725*437bfbebSnyanmisaka         RK_U32 qp_adj6     : 5;
726*437bfbebSnyanmisaka         RK_U32 qp_adj7     : 5;
727*437bfbebSnyanmisaka         RK_U32 qp_adj8     : 5;
728*437bfbebSnyanmisaka         RK_U32 reserved    : 12;
729*437bfbebSnyanmisaka     } rc_adj1;
730*437bfbebSnyanmisaka 
731*437bfbebSnyanmisaka     /* 0x00001008 reg1026 - 0x00001028 reg1034 */
732*437bfbebSnyanmisaka     RK_U32 rc_dthd_0_8[9];
733*437bfbebSnyanmisaka 
734*437bfbebSnyanmisaka     /* 0x102c */
735*437bfbebSnyanmisaka     RK_U32 reserved_1035;
736*437bfbebSnyanmisaka 
737*437bfbebSnyanmisaka     /* 0x00001030 reg1036 */
738*437bfbebSnyanmisaka     struct {
739*437bfbebSnyanmisaka         RK_U32 qpmin_area0    : 6;
740*437bfbebSnyanmisaka         RK_U32 qpmax_area0    : 6;
741*437bfbebSnyanmisaka         RK_U32 qpmin_area1    : 6;
742*437bfbebSnyanmisaka         RK_U32 qpmax_area1    : 6;
743*437bfbebSnyanmisaka         RK_U32 qpmin_area2    : 6;
744*437bfbebSnyanmisaka         RK_U32 reserved       : 2;
745*437bfbebSnyanmisaka     } roi_qthd0;
746*437bfbebSnyanmisaka 
747*437bfbebSnyanmisaka     /* 0x00001034 reg1037 */
748*437bfbebSnyanmisaka     struct {
749*437bfbebSnyanmisaka         RK_U32 qpmax_area2    : 6;
750*437bfbebSnyanmisaka         RK_U32 qpmin_area3    : 6;
751*437bfbebSnyanmisaka         RK_U32 qpmax_area3    : 6;
752*437bfbebSnyanmisaka         RK_U32 qpmin_area4    : 6;
753*437bfbebSnyanmisaka         RK_U32 qpmax_area4    : 6;
754*437bfbebSnyanmisaka         RK_U32 reserved       : 2;
755*437bfbebSnyanmisaka     } roi_qthd1;
756*437bfbebSnyanmisaka 
757*437bfbebSnyanmisaka     /* 0x00001038 reg1038 */
758*437bfbebSnyanmisaka     struct {
759*437bfbebSnyanmisaka         RK_U32 qpmin_area5    : 6;
760*437bfbebSnyanmisaka         RK_U32 qpmax_area5    : 6;
761*437bfbebSnyanmisaka         RK_U32 qpmin_area6    : 6;
762*437bfbebSnyanmisaka         RK_U32 qpmax_area6    : 6;
763*437bfbebSnyanmisaka         RK_U32 qpmin_area7    : 6;
764*437bfbebSnyanmisaka         RK_U32 reserved       : 2;
765*437bfbebSnyanmisaka     } roi_qthd2;
766*437bfbebSnyanmisaka 
767*437bfbebSnyanmisaka     /* 0x0000103c reg1039 */
768*437bfbebSnyanmisaka     struct {
769*437bfbebSnyanmisaka         RK_U32 qpmax_area7    : 6;
770*437bfbebSnyanmisaka         RK_U32 reserved       : 24;
771*437bfbebSnyanmisaka         RK_U32 qpmap_mode     : 2;
772*437bfbebSnyanmisaka     } roi_qthd3;
773*437bfbebSnyanmisaka 
774*437bfbebSnyanmisaka     /* 0x00001040 reg1040 */
775*437bfbebSnyanmisaka     struct {
776*437bfbebSnyanmisaka         RK_U32 madi_mode    : 1;
777*437bfbebSnyanmisaka         RK_U32 reserved     : 15;
778*437bfbebSnyanmisaka         RK_U32 madi_thd     : 8;
779*437bfbebSnyanmisaka         RK_U32 reserved1    : 8;
780*437bfbebSnyanmisaka     } madi_cfg;
781*437bfbebSnyanmisaka 
782*437bfbebSnyanmisaka     /* 0x00001044 reg1041 - 0x00001050 reg1044 */
783*437bfbebSnyanmisaka     RK_U8 aq_tthd[16];
784*437bfbebSnyanmisaka 
785*437bfbebSnyanmisaka     /* 0x00001054 reg1045 */
786*437bfbebSnyanmisaka     /*
787*437bfbebSnyanmisaka      * 0x00001054 reg1045 - 0x00001060 reg1048
788*437bfbebSnyanmisaka      * only low 6 bits is valid for per step.
789*437bfbebSnyanmisaka      */
790*437bfbebSnyanmisaka     RK_U8 aq_step[16];
791*437bfbebSnyanmisaka 
792*437bfbebSnyanmisaka     /* 0x1064 - 0x106c */
793*437bfbebSnyanmisaka     RK_U32 reserved1049_1051[3];
794*437bfbebSnyanmisaka 
795*437bfbebSnyanmisaka     /* 0x00001070 reg1052 */
796*437bfbebSnyanmisaka     struct {
797*437bfbebSnyanmisaka         RK_U32 md_sad_thd0    : 8;
798*437bfbebSnyanmisaka         RK_U32 md_sad_thd1    : 8;
799*437bfbebSnyanmisaka         RK_U32 md_sad_thd2    : 8;
800*437bfbebSnyanmisaka         RK_U32 reserved       : 8;
801*437bfbebSnyanmisaka     } md_sad_thd;
802*437bfbebSnyanmisaka 
803*437bfbebSnyanmisaka     /* 0x00001074 reg1053 */
804*437bfbebSnyanmisaka     struct {
805*437bfbebSnyanmisaka         RK_U32 madi_thd0    : 8;
806*437bfbebSnyanmisaka         RK_U32 madi_thd1    : 8;
807*437bfbebSnyanmisaka         RK_U32 madi_thd2    : 8;
808*437bfbebSnyanmisaka         RK_U32 reserved     : 8;
809*437bfbebSnyanmisaka     } madi_thd;
810*437bfbebSnyanmisaka 
811*437bfbebSnyanmisaka     /* 0x1078 - 0x107c */
812*437bfbebSnyanmisaka     RK_U32 reserved1054_1055[2];
813*437bfbebSnyanmisaka 
814*437bfbebSnyanmisaka     /* 0x00001080 reg1056 */
815*437bfbebSnyanmisaka     struct {
816*437bfbebSnyanmisaka         RK_U32 chrm_klut_ofst    : 3;
817*437bfbebSnyanmisaka         RK_U32 reserved          : 29;
818*437bfbebSnyanmisaka     } klut_ofst;
819*437bfbebSnyanmisaka 
820*437bfbebSnyanmisaka     /* 0x00001084 reg1057 */
821*437bfbebSnyanmisaka     struct {
822*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt0       : 18;
823*437bfbebSnyanmisaka         RK_U32 reserved             : 5;
824*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt1_l9    : 9;
825*437bfbebSnyanmisaka     } klut_wgt0;
826*437bfbebSnyanmisaka 
827*437bfbebSnyanmisaka     /* 0x00001088 reg1058 */
828*437bfbebSnyanmisaka     struct {
829*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt1_h9    : 9;
830*437bfbebSnyanmisaka         RK_U32 reserved             : 5;
831*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt2       : 18;
832*437bfbebSnyanmisaka     } klut_wgt1;
833*437bfbebSnyanmisaka 
834*437bfbebSnyanmisaka     /* 0x0000108c reg1059 */
835*437bfbebSnyanmisaka     struct {
836*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt3       : 18;
837*437bfbebSnyanmisaka         RK_U32 reserved             : 5;
838*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt4_l9    : 9;
839*437bfbebSnyanmisaka     } klut_wgt2;
840*437bfbebSnyanmisaka 
841*437bfbebSnyanmisaka     /* 0x00001090 reg1060 */
842*437bfbebSnyanmisaka     struct {
843*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt4_h9    : 9;
844*437bfbebSnyanmisaka         RK_U32 reserved             : 5;
845*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt5       : 18;
846*437bfbebSnyanmisaka     } klut_wgt3;
847*437bfbebSnyanmisaka 
848*437bfbebSnyanmisaka     /* 0x00001094 reg1061 */
849*437bfbebSnyanmisaka     struct {
850*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt6       : 18;
851*437bfbebSnyanmisaka         RK_U32 reserved             : 5;
852*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt7_l9    : 9;
853*437bfbebSnyanmisaka     } klut_wgt4;
854*437bfbebSnyanmisaka 
855*437bfbebSnyanmisaka     /* 0x00001098 reg1062 */
856*437bfbebSnyanmisaka     struct {
857*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt7_h9    : 9;
858*437bfbebSnyanmisaka         RK_U32 reserved             : 5;
859*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt8       : 18;
860*437bfbebSnyanmisaka     } klut_wgt5;
861*437bfbebSnyanmisaka 
862*437bfbebSnyanmisaka     /* 0x0000109c reg1063 */
863*437bfbebSnyanmisaka     struct {
864*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt9        : 18;
865*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
866*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt10_l9    : 9;
867*437bfbebSnyanmisaka     } klut_wgt6;
868*437bfbebSnyanmisaka 
869*437bfbebSnyanmisaka     /* 0x000010a0 reg1064 */
870*437bfbebSnyanmisaka     struct {
871*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt10_h9    : 9;
872*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
873*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt11       : 18;
874*437bfbebSnyanmisaka     } klut_wgt7;
875*437bfbebSnyanmisaka 
876*437bfbebSnyanmisaka     /* 0x000010a4 reg1065 */
877*437bfbebSnyanmisaka     struct {
878*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt12       : 18;
879*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
880*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt13_l9    : 9;
881*437bfbebSnyanmisaka     } klut_wgt8;
882*437bfbebSnyanmisaka 
883*437bfbebSnyanmisaka     /* 0x000010a8 reg1066 */
884*437bfbebSnyanmisaka     struct {
885*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt13_h9    : 9;
886*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
887*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt14       : 18;
888*437bfbebSnyanmisaka     } klut_wgt9;
889*437bfbebSnyanmisaka 
890*437bfbebSnyanmisaka     /* 0x000010ac reg1067 */
891*437bfbebSnyanmisaka     struct {
892*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt15       : 18;
893*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
894*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt16_l9    : 9;
895*437bfbebSnyanmisaka     } klut_wgt10;
896*437bfbebSnyanmisaka 
897*437bfbebSnyanmisaka     /* 0x000010b0 reg1068 */
898*437bfbebSnyanmisaka     struct {
899*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt16_h9    : 9;
900*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
901*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt17       : 18;
902*437bfbebSnyanmisaka     } klut_wgt11;
903*437bfbebSnyanmisaka 
904*437bfbebSnyanmisaka     /* 0x000010b4 reg1069 */
905*437bfbebSnyanmisaka     struct {
906*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt18       : 18;
907*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
908*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt19_l9    : 9;
909*437bfbebSnyanmisaka     } klut_wgt12;
910*437bfbebSnyanmisaka 
911*437bfbebSnyanmisaka     /* 0x000010b8 reg1070 */
912*437bfbebSnyanmisaka     struct {
913*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt19_h9    : 9;
914*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
915*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt20       : 18;
916*437bfbebSnyanmisaka     } klut_wgt13;
917*437bfbebSnyanmisaka 
918*437bfbebSnyanmisaka     /* 0x000010bc reg1071 */
919*437bfbebSnyanmisaka     struct {
920*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt21       : 18;
921*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
922*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt22_l9    : 9;
923*437bfbebSnyanmisaka     } klut_wgt14;
924*437bfbebSnyanmisaka 
925*437bfbebSnyanmisaka     /* 0x000010c0 reg1072 */
926*437bfbebSnyanmisaka     struct {
927*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt22_h9    : 9;
928*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
929*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt23       : 18;
930*437bfbebSnyanmisaka     } klut_wgt15;
931*437bfbebSnyanmisaka 
932*437bfbebSnyanmisaka     /* 0x000010c4 reg1073 */
933*437bfbebSnyanmisaka     struct {
934*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt24       : 18;
935*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
936*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt25_l9    : 9;
937*437bfbebSnyanmisaka     } klut_wgt16;
938*437bfbebSnyanmisaka 
939*437bfbebSnyanmisaka     /* 0x000010c8 reg1074 */
940*437bfbebSnyanmisaka     struct {
941*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt25_h9    : 9;
942*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
943*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt26       : 18;
944*437bfbebSnyanmisaka     } klut_wgt17;
945*437bfbebSnyanmisaka 
946*437bfbebSnyanmisaka     /* 0x000010cc reg1075 */
947*437bfbebSnyanmisaka     struct {
948*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt27       : 18;
949*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
950*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt28_l9    : 9;
951*437bfbebSnyanmisaka     } klut_wgt18;
952*437bfbebSnyanmisaka 
953*437bfbebSnyanmisaka     /* 0x000010d0 reg1076 */
954*437bfbebSnyanmisaka     struct {
955*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt28_h9    : 9;
956*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
957*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt29       : 18;
958*437bfbebSnyanmisaka     } klut_wgt19;
959*437bfbebSnyanmisaka 
960*437bfbebSnyanmisaka     /* 0x000010d4 reg1077 */
961*437bfbebSnyanmisaka     struct {
962*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt30       : 18;
963*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
964*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt31_l9    : 9;
965*437bfbebSnyanmisaka     } klut_wgt20;
966*437bfbebSnyanmisaka 
967*437bfbebSnyanmisaka     /* 0x000010d8 reg1078 */
968*437bfbebSnyanmisaka     struct {
969*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt31_h9    : 9;
970*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
971*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt32       : 18;
972*437bfbebSnyanmisaka     } klut_wgt21;
973*437bfbebSnyanmisaka 
974*437bfbebSnyanmisaka     /* 0x000010dc reg1079 */
975*437bfbebSnyanmisaka     struct {
976*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt33       : 18;
977*437bfbebSnyanmisaka         RK_U32 reserved              : 5;
978*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt34_l9    : 9;
979*437bfbebSnyanmisaka     } klut_wgt22;
980*437bfbebSnyanmisaka 
981*437bfbebSnyanmisaka     /* 0x000010e0 reg1080 */
982*437bfbebSnyanmisaka     struct {
983*437bfbebSnyanmisaka         RK_U32 chrm_klut_wgt34_h9    : 9;
984*437bfbebSnyanmisaka         RK_U32 reserved              : 23;
985*437bfbebSnyanmisaka     } klut_wgt23;
986*437bfbebSnyanmisaka } Vepu580RcKlutCfg;
987*437bfbebSnyanmisaka 
988*437bfbebSnyanmisaka /* class: iprd/iprd_wgt/rdo_wgta/prei_dif/sobel */
989*437bfbebSnyanmisaka /* 0x00001700 reg1472 - 0x00001cd4 reg1845 */
990*437bfbebSnyanmisaka typedef struct Vepu580Section3_t {
991*437bfbebSnyanmisaka     /* 0x1700 */
992*437bfbebSnyanmisaka     struct {
993*437bfbebSnyanmisaka         RK_U32    lvl4_intra_cst_thd0 : 12;
994*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
995*437bfbebSnyanmisaka         RK_U32    lvl4_intra_cst_thd1 : 12;
996*437bfbebSnyanmisaka         RK_U32    reserve1 : 4;
997*437bfbebSnyanmisaka     } lvl32_intra_CST_THD0;
998*437bfbebSnyanmisaka 
999*437bfbebSnyanmisaka     /* 0x1704 */
1000*437bfbebSnyanmisaka     struct {
1001*437bfbebSnyanmisaka         RK_U32    lvl4_intra_cst_thd2 : 12;
1002*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
1003*437bfbebSnyanmisaka         RK_U32    lvl4_intra_cst_thd3 : 12;
1004*437bfbebSnyanmisaka         RK_U32    reserve1 : 4;
1005*437bfbebSnyanmisaka     } lvl32_intra_CST_THD1;
1006*437bfbebSnyanmisaka 
1007*437bfbebSnyanmisaka     /* 0x1708 */
1008*437bfbebSnyanmisaka     struct {
1009*437bfbebSnyanmisaka         RK_U32    lvl8_intra_chrm_cst_thd0 : 12;
1010*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
1011*437bfbebSnyanmisaka         RK_U32    lvl8_intra_chrm_cst_thd1 : 12;
1012*437bfbebSnyanmisaka         RK_U32    reserve1 : 4;
1013*437bfbebSnyanmisaka     } lvl16_intra_CST_THD0;
1014*437bfbebSnyanmisaka 
1015*437bfbebSnyanmisaka     /* 0x170c */
1016*437bfbebSnyanmisaka     struct {
1017*437bfbebSnyanmisaka         RK_U32    lvl8_intra_chrm_cst_thd2 : 12;
1018*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
1019*437bfbebSnyanmisaka         RK_U32    lvl8_intra_chrm_cst_thd3 : 12;
1020*437bfbebSnyanmisaka         RK_U32    reserve1 : 4;
1021*437bfbebSnyanmisaka     } lvl16_intra_CST_THD1;
1022*437bfbebSnyanmisaka 
1023*437bfbebSnyanmisaka     /* 0x1710 */
1024*437bfbebSnyanmisaka     struct {
1025*437bfbebSnyanmisaka         RK_U32    lvl8_intra_cst_thd0 : 12;
1026*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
1027*437bfbebSnyanmisaka         RK_U32    lvl8_intra_cst_thd1 : 12;
1028*437bfbebSnyanmisaka         RK_U32    reserve1 : 4;
1029*437bfbebSnyanmisaka     } lvl8_intra_CST_THD0; //     only 264
1030*437bfbebSnyanmisaka 
1031*437bfbebSnyanmisaka     /* 0x1714 */
1032*437bfbebSnyanmisaka     struct {
1033*437bfbebSnyanmisaka         RK_U32    lvl8_intra_cst_thd2 : 12;
1034*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
1035*437bfbebSnyanmisaka         RK_U32    lvl8_intra_cst_thd3 : 12;
1036*437bfbebSnyanmisaka         RK_U32    reserve1 : 4;
1037*437bfbebSnyanmisaka     } lvl8_intra_CST_THD1; //     only 264
1038*437bfbebSnyanmisaka 
1039*437bfbebSnyanmisaka     /* 0x1718 */
1040*437bfbebSnyanmisaka     struct {
1041*437bfbebSnyanmisaka         RK_U32    lvl16_intra_ul_cst_thld : 12;
1042*437bfbebSnyanmisaka         RK_U32    reserve0 : 20;
1043*437bfbebSnyanmisaka     } lvl16_intra_UL_CST_THD; //      only 264
1044*437bfbebSnyanmisaka 
1045*437bfbebSnyanmisaka     /* 0x171c */
1046*437bfbebSnyanmisaka     struct {
1047*437bfbebSnyanmisaka         RK_U32    lvl8_intra_cst_wgt0 : 8;
1048*437bfbebSnyanmisaka 
1049*437bfbebSnyanmisaka         RK_U32    lvl8_intra_cst_wgt1 : 8;
1050*437bfbebSnyanmisaka 
1051*437bfbebSnyanmisaka         RK_U32    lvl8_intra_cst_wgt2 : 8;
1052*437bfbebSnyanmisaka 
1053*437bfbebSnyanmisaka         RK_U32    lvl8_intra_cst_wgt3 : 8;
1054*437bfbebSnyanmisaka 
1055*437bfbebSnyanmisaka     } lvl32_intra_CST_WGT0;
1056*437bfbebSnyanmisaka 
1057*437bfbebSnyanmisaka     /* 0x1720 */
1058*437bfbebSnyanmisaka     struct {
1059*437bfbebSnyanmisaka         RK_U32    lvl4_intra_cst_wgt0 : 8;
1060*437bfbebSnyanmisaka 
1061*437bfbebSnyanmisaka         RK_U32    lvl4_intra_cst_wgt1 : 8;
1062*437bfbebSnyanmisaka 
1063*437bfbebSnyanmisaka         RK_U32    lvl4_intra_cst_wgt2 : 8;
1064*437bfbebSnyanmisaka 
1065*437bfbebSnyanmisaka         RK_U32    lvl4_intra_cst_wgt3 : 8;
1066*437bfbebSnyanmisaka 
1067*437bfbebSnyanmisaka     } lvl32_intra_CST_WGT1; //
1068*437bfbebSnyanmisaka 
1069*437bfbebSnyanmisaka     /* 0x1724 */
1070*437bfbebSnyanmisaka     struct {
1071*437bfbebSnyanmisaka         RK_U32    lvl16_intra_cst_wgt0 : 8;
1072*437bfbebSnyanmisaka 
1073*437bfbebSnyanmisaka         RK_U32    lvl16_intra_cst_wgt1 : 8;
1074*437bfbebSnyanmisaka 
1075*437bfbebSnyanmisaka         RK_U32    lvl16_intra_cst_wgt2 : 8;
1076*437bfbebSnyanmisaka 
1077*437bfbebSnyanmisaka         RK_U32    lvl16_intra_cst_wgt3 : 8;
1078*437bfbebSnyanmisaka 
1079*437bfbebSnyanmisaka     } lvl16_intra_CST_WGT0; //  7.10
1080*437bfbebSnyanmisaka 
1081*437bfbebSnyanmisaka     /* 0x1728 */
1082*437bfbebSnyanmisaka     struct {
1083*437bfbebSnyanmisaka         RK_U32    lvl8_intra_chrm_cst_wgt0 : 8;
1084*437bfbebSnyanmisaka 
1085*437bfbebSnyanmisaka         RK_U32    lvl8_intra_chrm_cst_wgt1 : 8;
1086*437bfbebSnyanmisaka 
1087*437bfbebSnyanmisaka         RK_U32    lvl8_intra_chrm_cst_wgt2 : 8;
1088*437bfbebSnyanmisaka 
1089*437bfbebSnyanmisaka         RK_U32    lvl8_intra_chrm_cst_wgt3 : 8;
1090*437bfbebSnyanmisaka 
1091*437bfbebSnyanmisaka     } lvl16_intra_CST_WGT1; //
1092*437bfbebSnyanmisaka 
1093*437bfbebSnyanmisaka     /* 0x172c */
1094*437bfbebSnyanmisaka     RK_U32 reserved_1483;
1095*437bfbebSnyanmisaka 
1096*437bfbebSnyanmisaka     /* 0x00001730 reg1484 */
1097*437bfbebSnyanmisaka     struct {
1098*437bfbebSnyanmisaka         RK_U32    quant_f_bias_I : 10;
1099*437bfbebSnyanmisaka         RK_U32    quant_f_bias_P : 10;
1100*437bfbebSnyanmisaka         RK_U32    reserve : 12;
1101*437bfbebSnyanmisaka     } RDO_QUANT;
1102*437bfbebSnyanmisaka 
1103*437bfbebSnyanmisaka     /* 0x1734 - 0x173c */
1104*437bfbebSnyanmisaka     RK_U32 reserved1485_1487[3];
1105*437bfbebSnyanmisaka 
1106*437bfbebSnyanmisaka     /* 0x00001740 reg1488 */
1107*437bfbebSnyanmisaka     // atr
1108*437bfbebSnyanmisaka     struct {
1109*437bfbebSnyanmisaka         RK_U32    atr_thd0 : 12;
1110*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
1111*437bfbebSnyanmisaka         RK_U32    atr_thd1 : 12;
1112*437bfbebSnyanmisaka         RK_U32    reserve1 : 4;
1113*437bfbebSnyanmisaka     } ATR_THD0; //       only 264
1114*437bfbebSnyanmisaka 
1115*437bfbebSnyanmisaka     /* 0x1744 */
1116*437bfbebSnyanmisaka     struct {
1117*437bfbebSnyanmisaka         RK_U32    atr_thd2 : 12;
1118*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
1119*437bfbebSnyanmisaka         RK_U32    atr_thdqp : 6;
1120*437bfbebSnyanmisaka         RK_U32    reserve1 : 10;
1121*437bfbebSnyanmisaka     } ATR_THD1; //       only 264
1122*437bfbebSnyanmisaka 
1123*437bfbebSnyanmisaka     /* 0x1748 */
1124*437bfbebSnyanmisaka     struct {
1125*437bfbebSnyanmisaka         RK_U32    atr1_thd0 : 12;
1126*437bfbebSnyanmisaka         RK_U32    reserve0 : 4;
1127*437bfbebSnyanmisaka         RK_U32    atr1_thd1 : 12;
1128*437bfbebSnyanmisaka         RK_U32    reserve1 : 4;
1129*437bfbebSnyanmisaka     } ATR_THD10; //       only 264
1130*437bfbebSnyanmisaka 
1131*437bfbebSnyanmisaka     /* 0x174c */
1132*437bfbebSnyanmisaka     struct {
1133*437bfbebSnyanmisaka         RK_U32    atr1_thd2 : 12;
1134*437bfbebSnyanmisaka         RK_U32    reserve1 : 20;
1135*437bfbebSnyanmisaka     } ATR_THD11; //       only 264
1136*437bfbebSnyanmisaka 
1137*437bfbebSnyanmisaka     // /* 0x1748 - 0x174c */
1138*437bfbebSnyanmisaka     // RK_U32 reserved1490_1491[2];
1139*437bfbebSnyanmisaka 
1140*437bfbebSnyanmisaka     /* 0x00001750 reg1492 */
1141*437bfbebSnyanmisaka     struct {
1142*437bfbebSnyanmisaka         RK_U32    lvl16_atr_wgt0 : 8;
1143*437bfbebSnyanmisaka         RK_U32    lvl16_atr_wgt1 : 8;
1144*437bfbebSnyanmisaka         RK_U32    lvl16_atr_wgt2 : 8;
1145*437bfbebSnyanmisaka         RK_U32    reserved       : 8;
1146*437bfbebSnyanmisaka     } Lvl16_ATR_WGT; //      only 264
1147*437bfbebSnyanmisaka 
1148*437bfbebSnyanmisaka     /* 0x1754 */
1149*437bfbebSnyanmisaka     struct {
1150*437bfbebSnyanmisaka         RK_U32    lvl8_atr_wgt0 : 8;
1151*437bfbebSnyanmisaka         RK_U32    lvl8_atr_wgt1 : 8;
1152*437bfbebSnyanmisaka         RK_U32    lvl8_atr_wgt2 : 8;
1153*437bfbebSnyanmisaka         RK_U32    reserved      : 8;
1154*437bfbebSnyanmisaka     } Lvl8_ATR_WGT; //      only 264
1155*437bfbebSnyanmisaka 
1156*437bfbebSnyanmisaka     /* 0x1758 */
1157*437bfbebSnyanmisaka     struct {
1158*437bfbebSnyanmisaka         RK_U32    lvl4_atr_wgt0 : 8;
1159*437bfbebSnyanmisaka         RK_U32    lvl4_atr_wgt1 : 8;
1160*437bfbebSnyanmisaka         RK_U32    lvl4_atr_wgt2 : 8;
1161*437bfbebSnyanmisaka         RK_U32    reserved      : 8;
1162*437bfbebSnyanmisaka     } Lvl4_ATR_WGT; //      only 264
1163*437bfbebSnyanmisaka 
1164*437bfbebSnyanmisaka     /* 0x175c */
1165*437bfbebSnyanmisaka     RK_U32 reserved_1495;
1166*437bfbebSnyanmisaka 
1167*437bfbebSnyanmisaka     /* 0x00001760 reg1496 */
1168*437bfbebSnyanmisaka     struct {
1169*437bfbebSnyanmisaka         RK_U32 cime_sad_mod_sel          : 1;
1170*437bfbebSnyanmisaka         RK_U32 cime_sad_use_big_block    : 1;
1171*437bfbebSnyanmisaka         RK_U32 cime_pmv_set_zero         : 1;
1172*437bfbebSnyanmisaka         RK_U32 reserved                  : 5;
1173*437bfbebSnyanmisaka         RK_U32 cime_pmv_num              : 2;
1174*437bfbebSnyanmisaka         RK_U32 reserved1                 : 22;
1175*437bfbebSnyanmisaka     } cime_sqi_cfg;
1176*437bfbebSnyanmisaka 
1177*437bfbebSnyanmisaka     /* 0x00001764 reg1497 */
1178*437bfbebSnyanmisaka     struct {
1179*437bfbebSnyanmisaka         RK_U32 cime_mvd_th0    : 9;
1180*437bfbebSnyanmisaka         RK_U32 reserved        : 1;
1181*437bfbebSnyanmisaka         RK_U32 cime_mvd_th1    : 9;
1182*437bfbebSnyanmisaka         RK_U32 reserved1       : 1;
1183*437bfbebSnyanmisaka         RK_U32 cime_mvd_th2    : 9;
1184*437bfbebSnyanmisaka         RK_U32 reserved2       : 3;
1185*437bfbebSnyanmisaka     } cime_sqi_thd;
1186*437bfbebSnyanmisaka 
1187*437bfbebSnyanmisaka     /* 0x00001768 reg1498 */
1188*437bfbebSnyanmisaka     struct {
1189*437bfbebSnyanmisaka         RK_U32 cime_multi0    : 10;
1190*437bfbebSnyanmisaka         RK_U32 reserved       : 6;
1191*437bfbebSnyanmisaka         RK_U32 cime_multi1    : 10;
1192*437bfbebSnyanmisaka         RK_U32 reserved1      : 6;
1193*437bfbebSnyanmisaka     } cime_sqi_multi0;
1194*437bfbebSnyanmisaka 
1195*437bfbebSnyanmisaka     /* 0x0000176c reg1499 */
1196*437bfbebSnyanmisaka     struct {
1197*437bfbebSnyanmisaka         RK_U32 cime_multi2    : 10;
1198*437bfbebSnyanmisaka         RK_U32 reserved       : 6;
1199*437bfbebSnyanmisaka         RK_U32 cime_multi3    : 10;
1200*437bfbebSnyanmisaka         RK_U32 reserved1      : 6;
1201*437bfbebSnyanmisaka     } cime_sqi_multi1;
1202*437bfbebSnyanmisaka 
1203*437bfbebSnyanmisaka     /* 0x00001770 reg1500 */
1204*437bfbebSnyanmisaka     struct {
1205*437bfbebSnyanmisaka         RK_U32 cime_sad_th0    : 12;
1206*437bfbebSnyanmisaka         RK_U32 reserved        : 4;
1207*437bfbebSnyanmisaka         RK_U32 rime_mvd_th0    : 4;
1208*437bfbebSnyanmisaka         RK_U32 reserved1       : 4;
1209*437bfbebSnyanmisaka         RK_U32 rime_mvd_th1    : 4;
1210*437bfbebSnyanmisaka         RK_U32 reserved2       : 4;
1211*437bfbebSnyanmisaka     } rime_sqi_thd;
1212*437bfbebSnyanmisaka 
1213*437bfbebSnyanmisaka     /* 0x00001774 reg1501 */
1214*437bfbebSnyanmisaka     struct {
1215*437bfbebSnyanmisaka         RK_U32 rime_multi0    : 10;
1216*437bfbebSnyanmisaka         RK_U32 rime_multi1    : 10;
1217*437bfbebSnyanmisaka         RK_U32 rime_multi2    : 10;
1218*437bfbebSnyanmisaka         RK_U32 reserved       : 2;
1219*437bfbebSnyanmisaka     } rime_sqi_multi;
1220*437bfbebSnyanmisaka 
1221*437bfbebSnyanmisaka     /* 0x00001778 reg1502 */
1222*437bfbebSnyanmisaka     struct {
1223*437bfbebSnyanmisaka         RK_U32 cime_sad_pu16_th    : 12;
1224*437bfbebSnyanmisaka         RK_U32 reserved            : 4;
1225*437bfbebSnyanmisaka         RK_U32 cime_sad_pu32_th    : 12;
1226*437bfbebSnyanmisaka         RK_U32 reserved1           : 4;
1227*437bfbebSnyanmisaka     } fme_sqi_thd0;
1228*437bfbebSnyanmisaka 
1229*437bfbebSnyanmisaka     /* 0x0000177c reg1503 */
1230*437bfbebSnyanmisaka     struct {
1231*437bfbebSnyanmisaka         RK_U32 cime_sad_pu64_th    : 12;
1232*437bfbebSnyanmisaka         RK_U32 reserved            : 4;
1233*437bfbebSnyanmisaka         RK_U32 move_lambda         : 4;
1234*437bfbebSnyanmisaka         RK_U32 reserved1           : 12;
1235*437bfbebSnyanmisaka     } fme_sqi_thd1;
1236*437bfbebSnyanmisaka 
1237*437bfbebSnyanmisaka     /* 0x1780 - 0x17fc */
1238*437bfbebSnyanmisaka     RK_U32 reserved1504_1535[32];
1239*437bfbebSnyanmisaka 
1240*437bfbebSnyanmisaka     /* 0x00001800 reg1536 - 0x000018cc reg1587  */
1241*437bfbebSnyanmisaka     // struct {
1242*437bfbebSnyanmisaka     //     RK_U32 wgt_qp0     : 20;
1243*437bfbebSnyanmisaka     //     RK_U32 reserved    : 12;
1244*437bfbebSnyanmisaka     // } iprd_wgt_qp_hevc_0_51[52];
1245*437bfbebSnyanmisaka     RK_U32 iprd_wgt_qp_hevc_0_51[52];
1246*437bfbebSnyanmisaka 
1247*437bfbebSnyanmisaka     /* 0x18d0 - 0x18fc */
1248*437bfbebSnyanmisaka     RK_U32 reserved1588_1599[12];
1249*437bfbebSnyanmisaka 
1250*437bfbebSnyanmisaka     /* wgt_qp48_grpa */
1251*437bfbebSnyanmisaka     /* 0x00001900 reg1600 - 0x19cc */
1252*437bfbebSnyanmisaka     RK_U32 rdo_wgta_qp_grpa_0_51[52];
1253*437bfbebSnyanmisaka } Vepu580Section3;
1254*437bfbebSnyanmisaka 
1255*437bfbebSnyanmisaka /* class: rdo/q_i */
1256*437bfbebSnyanmisaka /* 0x00002000 reg2048 - 0x00002c98 reg2854 */
1257*437bfbebSnyanmisaka typedef struct Vepu580RdoCfg_t {
1258*437bfbebSnyanmisaka     /* 0x00002000 reg2048 */
1259*437bfbebSnyanmisaka     struct {
1260*437bfbebSnyanmisaka         RK_U32 atf_pskip_en    : 1;
1261*437bfbebSnyanmisaka         RK_U32 reserved             : 31;
1262*437bfbebSnyanmisaka     } rdo_sqi_cfg;
1263*437bfbebSnyanmisaka 
1264*437bfbebSnyanmisaka     /* 0x00002004 reg2049 */
1265*437bfbebSnyanmisaka     struct {
1266*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_cime_thd0    : 12;
1267*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1268*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_cime_thd1    : 12;
1269*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1270*437bfbebSnyanmisaka     } rdo_b64_inter_cime_thd0;
1271*437bfbebSnyanmisaka 
1272*437bfbebSnyanmisaka     /* 0x00002008 reg2050 */
1273*437bfbebSnyanmisaka     struct {
1274*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_cime_thd2    : 12;
1275*437bfbebSnyanmisaka         RK_U32 reserved                    : 20;
1276*437bfbebSnyanmisaka     } rdo_b64_inter_cime_thd1;
1277*437bfbebSnyanmisaka 
1278*437bfbebSnyanmisaka     /* 0x0000200c reg2051 */
1279*437bfbebSnyanmisaka     struct {
1280*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_var_thd00    : 12;
1281*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1282*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_var_thd01    : 12;
1283*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1284*437bfbebSnyanmisaka     } rdo_b64_inter_var_thd0;
1285*437bfbebSnyanmisaka 
1286*437bfbebSnyanmisaka     /* 0x00002010 reg2052 */
1287*437bfbebSnyanmisaka     struct {
1288*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_var_thd10    : 12;
1289*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1290*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_var_thd11    : 12;
1291*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1292*437bfbebSnyanmisaka     } rdo_b64_inter_var_thd1;
1293*437bfbebSnyanmisaka 
1294*437bfbebSnyanmisaka     /* 0x00002014 reg2053 */
1295*437bfbebSnyanmisaka     struct {
1296*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_var_thd20    : 12;
1297*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1298*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_var_thd21    : 12;
1299*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1300*437bfbebSnyanmisaka     } rdo_b64_inter_var_thd2;
1301*437bfbebSnyanmisaka 
1302*437bfbebSnyanmisaka     /* 0x00002018 reg2054 */
1303*437bfbebSnyanmisaka     struct {
1304*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_var_thd30    : 12;
1305*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1306*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_var_thd31    : 12;
1307*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1308*437bfbebSnyanmisaka     } rdo_b64_inter_var_thd3;
1309*437bfbebSnyanmisaka 
1310*437bfbebSnyanmisaka     /* 0x0000201c reg2055 */
1311*437bfbebSnyanmisaka     struct {
1312*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt00    : 8;
1313*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt01    : 8;
1314*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt02    : 8;
1315*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1316*437bfbebSnyanmisaka     } rdo_b64_inter_atf_wgt0;
1317*437bfbebSnyanmisaka 
1318*437bfbebSnyanmisaka     /* 0x00002020 reg2056 */
1319*437bfbebSnyanmisaka     struct {
1320*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt10    : 8;
1321*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt11    : 8;
1322*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt12    : 8;
1323*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1324*437bfbebSnyanmisaka     } rdo_b64_inter_atf_wgt1;
1325*437bfbebSnyanmisaka 
1326*437bfbebSnyanmisaka     /* 0x00002024 reg2057 */
1327*437bfbebSnyanmisaka     struct {
1328*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt20    : 8;
1329*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt21    : 8;
1330*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt22    : 8;
1331*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1332*437bfbebSnyanmisaka     } rdo_b64_inter_atf_wgt2;
1333*437bfbebSnyanmisaka 
1334*437bfbebSnyanmisaka     /* 0x00002028 reg2058 */
1335*437bfbebSnyanmisaka     struct {
1336*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt30    : 8;
1337*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt31    : 8;
1338*437bfbebSnyanmisaka         RK_U32 cu64_rdo_inter_atf_wgt32    : 8;
1339*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1340*437bfbebSnyanmisaka     } rdo_b64_inter_atf_wgt3;
1341*437bfbebSnyanmisaka 
1342*437bfbebSnyanmisaka     /* 0x0000202c reg2059 */
1343*437bfbebSnyanmisaka     struct {
1344*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_cime_thd0    : 12;
1345*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1346*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_cime_thd1    : 12;
1347*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1348*437bfbebSnyanmisaka     } rdo_b64_skip_cime_thd0;
1349*437bfbebSnyanmisaka 
1350*437bfbebSnyanmisaka     /* 0x00002030 reg2060 */
1351*437bfbebSnyanmisaka     struct {
1352*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_cime_thd2    : 12;
1353*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1354*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_cime_thd3    : 12;
1355*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1356*437bfbebSnyanmisaka     } rdo_b64_skip_cime_thd1;
1357*437bfbebSnyanmisaka 
1358*437bfbebSnyanmisaka     /* 0x00002034 reg2061 */
1359*437bfbebSnyanmisaka     struct {
1360*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_var_thd10    : 12;
1361*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1362*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_var_thd11    : 12;
1363*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1364*437bfbebSnyanmisaka     } rdo_b64_skip_var_thd0;
1365*437bfbebSnyanmisaka 
1366*437bfbebSnyanmisaka     /* 0x00002038 reg2062 */
1367*437bfbebSnyanmisaka     struct {
1368*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_var_thd20    : 12;
1369*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1370*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_var_thd21    : 12;
1371*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1372*437bfbebSnyanmisaka     } rdo_b64_skip_var_thd1;
1373*437bfbebSnyanmisaka 
1374*437bfbebSnyanmisaka     /* 0x0000203c reg2063 */
1375*437bfbebSnyanmisaka     struct {
1376*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_var_thd30    : 12;
1377*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1378*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_var_thd31    : 12;
1379*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1380*437bfbebSnyanmisaka     } rdo_b64_skip_var_thd2;
1381*437bfbebSnyanmisaka 
1382*437bfbebSnyanmisaka     /* 0x00002040 reg2064 */
1383*437bfbebSnyanmisaka     struct {
1384*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_var_thd40    : 12;
1385*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1386*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_var_thd41    : 12;
1387*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1388*437bfbebSnyanmisaka     } rdo_b64_skip_var_thd3;
1389*437bfbebSnyanmisaka 
1390*437bfbebSnyanmisaka     /* 0x00002044 reg2065 */
1391*437bfbebSnyanmisaka     struct {
1392*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt00    : 8;
1393*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt10    : 8;
1394*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt11    : 8;
1395*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt12    : 8;
1396*437bfbebSnyanmisaka     } rdo_b64_skip_atf_wgt0;
1397*437bfbebSnyanmisaka 
1398*437bfbebSnyanmisaka     /* 0x00002048 reg2066 */
1399*437bfbebSnyanmisaka     struct {
1400*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt20    : 8;
1401*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt21    : 8;
1402*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt22    : 8;
1403*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1404*437bfbebSnyanmisaka     } rdo_b64_skip_atf_wgt1;
1405*437bfbebSnyanmisaka 
1406*437bfbebSnyanmisaka     /* 0x0000204c reg2067 */
1407*437bfbebSnyanmisaka     struct {
1408*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt30    : 8;
1409*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt31    : 8;
1410*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt32    : 8;
1411*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1412*437bfbebSnyanmisaka     } rdo_b64_skip_atf_wgt2;
1413*437bfbebSnyanmisaka 
1414*437bfbebSnyanmisaka     /* 0x00002050 reg2068 */
1415*437bfbebSnyanmisaka     struct {
1416*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt40    : 8;
1417*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt41    : 8;
1418*437bfbebSnyanmisaka         RK_U32 cu64_rdo_skip_atf_wgt42    : 8;
1419*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1420*437bfbebSnyanmisaka     } rdo_b64_skip_atf_wgt3;
1421*437bfbebSnyanmisaka 
1422*437bfbebSnyanmisaka     /* 0x00002054 reg2069 */
1423*437bfbebSnyanmisaka     struct {
1424*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_cime_thd0    : 12;
1425*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1426*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_cime_thd1    : 12;
1427*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1428*437bfbebSnyanmisaka     } rdo_b32_intra_cime_thd0;
1429*437bfbebSnyanmisaka 
1430*437bfbebSnyanmisaka     /* 0x00002058 reg2070 */
1431*437bfbebSnyanmisaka     struct {
1432*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_cime_thd2    : 12;
1433*437bfbebSnyanmisaka         RK_U32 reserved                    : 20;
1434*437bfbebSnyanmisaka     } rdo_b32_intra_cime_thd1;
1435*437bfbebSnyanmisaka 
1436*437bfbebSnyanmisaka     /* 0x0000205c reg2071 */
1437*437bfbebSnyanmisaka     struct {
1438*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_var_thd00    : 12;
1439*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1440*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_var_thd01    : 12;
1441*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1442*437bfbebSnyanmisaka     } rdo_b32_intra_var_thd0;
1443*437bfbebSnyanmisaka 
1444*437bfbebSnyanmisaka     /* 0x00002060 reg2072 */
1445*437bfbebSnyanmisaka     struct {
1446*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_var_thd10    : 12;
1447*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1448*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_var_thd11    : 12;
1449*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1450*437bfbebSnyanmisaka     } rdo_b32_intra_var_thd1;
1451*437bfbebSnyanmisaka 
1452*437bfbebSnyanmisaka     /* 0x00002064 reg2073 */
1453*437bfbebSnyanmisaka     struct {
1454*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_var_thd20    : 12;
1455*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1456*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_var_thd21    : 12;
1457*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1458*437bfbebSnyanmisaka     } rdo_b32_intra_var_thd2;
1459*437bfbebSnyanmisaka 
1460*437bfbebSnyanmisaka     /* 0x00002068 reg2074 */
1461*437bfbebSnyanmisaka     struct {
1462*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_var_thd30    : 12;
1463*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1464*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_var_thd31    : 12;
1465*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1466*437bfbebSnyanmisaka     } rdo_b32_intra_var_thd3;
1467*437bfbebSnyanmisaka 
1468*437bfbebSnyanmisaka     /* 0x0000206c reg2075 */
1469*437bfbebSnyanmisaka     struct {
1470*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt00    : 8;
1471*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt01    : 8;
1472*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt02    : 8;
1473*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1474*437bfbebSnyanmisaka     } rdo_b32_intra_atf_wgt0;
1475*437bfbebSnyanmisaka 
1476*437bfbebSnyanmisaka     /* 0x00002070 reg2076 */
1477*437bfbebSnyanmisaka     struct {
1478*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt10    : 8;
1479*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt11    : 8;
1480*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt12    : 8;
1481*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1482*437bfbebSnyanmisaka     } rdo_b32_intra_atf_wgt1;
1483*437bfbebSnyanmisaka 
1484*437bfbebSnyanmisaka     /* 0x00002074 reg2077 */
1485*437bfbebSnyanmisaka     struct {
1486*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt20    : 8;
1487*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt21    : 8;
1488*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt22    : 8;
1489*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1490*437bfbebSnyanmisaka     } rdo_b32_intra_atf_wgt2;
1491*437bfbebSnyanmisaka 
1492*437bfbebSnyanmisaka     /* 0x00002078 reg2078 */
1493*437bfbebSnyanmisaka     struct {
1494*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt30    : 8;
1495*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt31    : 8;
1496*437bfbebSnyanmisaka         RK_U32 cu32_rdo_intra_atf_wgt32    : 8;
1497*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1498*437bfbebSnyanmisaka     } rdo_b32_intra_atf_wgt3;
1499*437bfbebSnyanmisaka 
1500*437bfbebSnyanmisaka     /* 0x0000207c reg2079 */
1501*437bfbebSnyanmisaka     struct {
1502*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_cime_thd0    : 12;
1503*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1504*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_cime_thd1    : 12;
1505*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1506*437bfbebSnyanmisaka     } rdo_b32_inter_cime_thd0;
1507*437bfbebSnyanmisaka 
1508*437bfbebSnyanmisaka     /* 0x00002080 reg2080 */
1509*437bfbebSnyanmisaka     struct {
1510*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_cime_thd2    : 12;
1511*437bfbebSnyanmisaka         RK_U32 reserved                    : 20;
1512*437bfbebSnyanmisaka     } rdo_b32_inter_cime_thd1;
1513*437bfbebSnyanmisaka 
1514*437bfbebSnyanmisaka     /* 0x00002084 reg2081 */
1515*437bfbebSnyanmisaka     struct {
1516*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_var_thd00    : 12;
1517*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1518*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_var_thd01    : 12;
1519*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1520*437bfbebSnyanmisaka     } rdo_b32_inter_var_thd0;
1521*437bfbebSnyanmisaka 
1522*437bfbebSnyanmisaka     /* 0x00002088 reg2082 */
1523*437bfbebSnyanmisaka     struct {
1524*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_var_thd10    : 12;
1525*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1526*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_var_thd11    : 12;
1527*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1528*437bfbebSnyanmisaka     } rdo_b32_inter_var_thd1;
1529*437bfbebSnyanmisaka 
1530*437bfbebSnyanmisaka     /* 0x0000208c reg2083 */
1531*437bfbebSnyanmisaka     struct {
1532*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_var_thd20    : 12;
1533*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1534*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_var_thd21    : 12;
1535*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1536*437bfbebSnyanmisaka     } rdo_b32_inter_var_thd2;
1537*437bfbebSnyanmisaka 
1538*437bfbebSnyanmisaka     /* 0x00002090 reg2084 */
1539*437bfbebSnyanmisaka     struct {
1540*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_var_thd30    : 12;
1541*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1542*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_var_thd31    : 12;
1543*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1544*437bfbebSnyanmisaka     } rdo_b32_inter_var_thd3;
1545*437bfbebSnyanmisaka 
1546*437bfbebSnyanmisaka     /* 0x00002094 reg2085 */
1547*437bfbebSnyanmisaka     struct {
1548*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt00    : 8;
1549*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt01    : 8;
1550*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt02    : 8;
1551*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1552*437bfbebSnyanmisaka     } rdo_b32_inter_atf_wgt0;
1553*437bfbebSnyanmisaka 
1554*437bfbebSnyanmisaka     /* 0x00002098 reg2086 */
1555*437bfbebSnyanmisaka     struct {
1556*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt10    : 8;
1557*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt11    : 8;
1558*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt12    : 8;
1559*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1560*437bfbebSnyanmisaka     } rdo_b32_inter_atf_wgt1;
1561*437bfbebSnyanmisaka 
1562*437bfbebSnyanmisaka     /* 0x0000209c reg2087 */
1563*437bfbebSnyanmisaka     struct {
1564*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt20    : 8;
1565*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt21    : 8;
1566*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt22    : 8;
1567*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1568*437bfbebSnyanmisaka     } rdo_b32_inter_atf_wgt2;
1569*437bfbebSnyanmisaka 
1570*437bfbebSnyanmisaka     /* 0x000020a0 reg2088 */
1571*437bfbebSnyanmisaka     struct {
1572*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt30    : 8;
1573*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt31    : 8;
1574*437bfbebSnyanmisaka         RK_U32 cu32_rdo_inter_atf_wgt32    : 8;
1575*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1576*437bfbebSnyanmisaka     } rdo_b32_inter_atf_wgt3;
1577*437bfbebSnyanmisaka 
1578*437bfbebSnyanmisaka     /* 0x000020a4 reg2089 */
1579*437bfbebSnyanmisaka     struct {
1580*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_cime_thd0    : 12;
1581*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1582*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_cime_thd1    : 12;
1583*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1584*437bfbebSnyanmisaka     } rdo_b32_skip_cime_thd0;
1585*437bfbebSnyanmisaka 
1586*437bfbebSnyanmisaka     /* 0x000020a8 reg2090 */
1587*437bfbebSnyanmisaka     struct {
1588*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_cime_thd2    : 12;
1589*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1590*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_cime_thd3    : 12;
1591*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1592*437bfbebSnyanmisaka     } rdo_b32_skip_cime_thd1;
1593*437bfbebSnyanmisaka 
1594*437bfbebSnyanmisaka     /* 0x000020ac reg2091 */
1595*437bfbebSnyanmisaka     struct {
1596*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_var_thd10    : 12;
1597*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1598*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_var_thd11    : 12;
1599*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1600*437bfbebSnyanmisaka     } rdo_b32_sskip_var_thd0;
1601*437bfbebSnyanmisaka 
1602*437bfbebSnyanmisaka     /* 0x000020b0 reg2092 */
1603*437bfbebSnyanmisaka     struct {
1604*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_var_thd20    : 12;
1605*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1606*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_var_thd21    : 12;
1607*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1608*437bfbebSnyanmisaka     } rdo_b32_sskip_var_thd1;
1609*437bfbebSnyanmisaka 
1610*437bfbebSnyanmisaka     /* 0x000020b4 reg2093 */
1611*437bfbebSnyanmisaka     struct {
1612*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_var_thd30    : 12;
1613*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1614*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_var_thd31    : 12;
1615*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1616*437bfbebSnyanmisaka     } rdo_b32_sskip_var_thd2;
1617*437bfbebSnyanmisaka 
1618*437bfbebSnyanmisaka     /* 0x000020b8 reg2094 */
1619*437bfbebSnyanmisaka     struct {
1620*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_var_thd40    : 12;
1621*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1622*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_var_thd41    : 12;
1623*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1624*437bfbebSnyanmisaka     } rdo_b32_sskip_var_thd3;
1625*437bfbebSnyanmisaka 
1626*437bfbebSnyanmisaka     /* 0x000020bc reg2095 */
1627*437bfbebSnyanmisaka     struct {
1628*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt00    : 8;
1629*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt10    : 8;
1630*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt11    : 8;
1631*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt12    : 8;
1632*437bfbebSnyanmisaka     } rdo_b32_skip_atf_wgt0;
1633*437bfbebSnyanmisaka 
1634*437bfbebSnyanmisaka     /* 0x000020c0 reg2096 */
1635*437bfbebSnyanmisaka     struct {
1636*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt20    : 8;
1637*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt21    : 8;
1638*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt22    : 8;
1639*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1640*437bfbebSnyanmisaka     } rdo_b32_skip_atf_wgt1;
1641*437bfbebSnyanmisaka 
1642*437bfbebSnyanmisaka     /* 0x000020c4 reg2097 */
1643*437bfbebSnyanmisaka     struct {
1644*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt30    : 8;
1645*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt31    : 8;
1646*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt32    : 8;
1647*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1648*437bfbebSnyanmisaka     } rdo_b32_skip_atf_wgt2;
1649*437bfbebSnyanmisaka 
1650*437bfbebSnyanmisaka     /* 0x000020c8 reg2098 */
1651*437bfbebSnyanmisaka     struct {
1652*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt40    : 8;
1653*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt41    : 8;
1654*437bfbebSnyanmisaka         RK_U32 cu32_rdo_skip_atf_wgt42    : 8;
1655*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1656*437bfbebSnyanmisaka     } rdo_b32_skip_atf_wgt3;
1657*437bfbebSnyanmisaka 
1658*437bfbebSnyanmisaka     /* 0x000020cc reg2099 */
1659*437bfbebSnyanmisaka     struct {
1660*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_cime_thd0    : 12;
1661*437bfbebSnyanmisaka         RK_U32 reserved                        : 4;
1662*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_cime_thd1    : 12;
1663*437bfbebSnyanmisaka         RK_U32 reserved1                       : 4;
1664*437bfbebSnyanmisaka     } rdo_intra_cime_thd0;
1665*437bfbebSnyanmisaka 
1666*437bfbebSnyanmisaka     /* 0x000020d0 reg2100 */
1667*437bfbebSnyanmisaka     struct {
1668*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_cime_thd2    : 12;
1669*437bfbebSnyanmisaka         RK_U32 reserved                        : 20;
1670*437bfbebSnyanmisaka     } rdo_intra_cime_thd1;
1671*437bfbebSnyanmisaka 
1672*437bfbebSnyanmisaka     /* 0x000020d4 reg2101 */
1673*437bfbebSnyanmisaka     struct {
1674*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_var_thd00    : 12;
1675*437bfbebSnyanmisaka         RK_U32 reserved                        : 4;
1676*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_var_thd01    : 12;
1677*437bfbebSnyanmisaka         RK_U32 reserved1                       : 4;
1678*437bfbebSnyanmisaka     } rdo_intra_var_thd0;
1679*437bfbebSnyanmisaka 
1680*437bfbebSnyanmisaka     /* 0x000020d8 reg2102 */
1681*437bfbebSnyanmisaka     struct {
1682*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_var_thd10    : 12;
1683*437bfbebSnyanmisaka         RK_U32 reserved                        : 4;
1684*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_var_thd11    : 12;
1685*437bfbebSnyanmisaka         RK_U32 reserved1                       : 4;
1686*437bfbebSnyanmisaka     } rdo_intra_var_thd1;
1687*437bfbebSnyanmisaka 
1688*437bfbebSnyanmisaka     /* 0x000020dc reg2103 */
1689*437bfbebSnyanmisaka     struct {
1690*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_var_thd20    : 12;
1691*437bfbebSnyanmisaka         RK_U32 reserved                        : 4;
1692*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_var_thd21    : 12;
1693*437bfbebSnyanmisaka         RK_U32 reserved1                       : 4;
1694*437bfbebSnyanmisaka     } rdo_intra_var_thd2;
1695*437bfbebSnyanmisaka 
1696*437bfbebSnyanmisaka     /* 0x000020e0 reg2104 */
1697*437bfbebSnyanmisaka     struct {
1698*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_var_thd30    : 12;
1699*437bfbebSnyanmisaka         RK_U32 reserved                        : 4;
1700*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_var_thd31    : 12;
1701*437bfbebSnyanmisaka         RK_U32 reserved1                       : 4;
1702*437bfbebSnyanmisaka     } rdo_intra_var_thd3;
1703*437bfbebSnyanmisaka 
1704*437bfbebSnyanmisaka     /* 0x000020e4 reg2105 */
1705*437bfbebSnyanmisaka     struct {
1706*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt00    : 8;
1707*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt01    : 8;
1708*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt02    : 8;
1709*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1710*437bfbebSnyanmisaka     } rdo_intra_atf_wgt0;
1711*437bfbebSnyanmisaka 
1712*437bfbebSnyanmisaka     /* 0x000020e8 reg2106 */
1713*437bfbebSnyanmisaka     struct {
1714*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt10    : 8;
1715*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt11    : 8;
1716*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt12    : 8;
1717*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1718*437bfbebSnyanmisaka     } rdo_intra_atf_wgt1;
1719*437bfbebSnyanmisaka 
1720*437bfbebSnyanmisaka     /* 0x000020ec reg2107 */
1721*437bfbebSnyanmisaka     struct {
1722*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt20    : 8;
1723*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt21    : 8;
1724*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt22    : 8;
1725*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1726*437bfbebSnyanmisaka     } rdo_intra_atf_wgt2;
1727*437bfbebSnyanmisaka 
1728*437bfbebSnyanmisaka     /* 0x000020f0 reg2108 */
1729*437bfbebSnyanmisaka     struct {
1730*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt30    : 8;
1731*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt31    : 8;
1732*437bfbebSnyanmisaka         RK_U32 atf_rdo_intra_wgt32    : 8;
1733*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1734*437bfbebSnyanmisaka     } rdo_intra_atf_wgt3;
1735*437bfbebSnyanmisaka 
1736*437bfbebSnyanmisaka     /* 0x000020f4 reg2109 */
1737*437bfbebSnyanmisaka     struct {
1738*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_cime_thd0    : 12;
1739*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1740*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_cime_thd1    : 12;
1741*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1742*437bfbebSnyanmisaka     } rdo_b16_inter_cime_thd0;
1743*437bfbebSnyanmisaka 
1744*437bfbebSnyanmisaka     /* 0x000020f8 reg2110 */
1745*437bfbebSnyanmisaka     struct {
1746*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_cime_thd2    : 12;
1747*437bfbebSnyanmisaka         RK_U32 reserved                    : 20;
1748*437bfbebSnyanmisaka     } rdo_b16_inter_cime_thd1;
1749*437bfbebSnyanmisaka 
1750*437bfbebSnyanmisaka     /* 0x000020fc reg2111 */
1751*437bfbebSnyanmisaka     struct {
1752*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_var_thd00    : 12;
1753*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1754*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_var_thd01    : 12;
1755*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1756*437bfbebSnyanmisaka     } rdo_b16_inter_var_thd0;
1757*437bfbebSnyanmisaka 
1758*437bfbebSnyanmisaka     /* 0x00002100 reg2112 */
1759*437bfbebSnyanmisaka     struct {
1760*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_var_thd10    : 12;
1761*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1762*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_var_thd11    : 12;
1763*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1764*437bfbebSnyanmisaka     } rdo_b16_inter_var_thd1;
1765*437bfbebSnyanmisaka 
1766*437bfbebSnyanmisaka     /* 0x00002104 reg2113 */
1767*437bfbebSnyanmisaka     struct {
1768*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_var_thd20    : 12;
1769*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1770*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_var_thd21    : 12;
1771*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1772*437bfbebSnyanmisaka     } rdo_b16_inter_var_thd2;
1773*437bfbebSnyanmisaka 
1774*437bfbebSnyanmisaka     /* 0x00002108 reg2114 */
1775*437bfbebSnyanmisaka     struct {
1776*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_var_thd30    : 12;
1777*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
1778*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_var_thd31    : 12;
1779*437bfbebSnyanmisaka         RK_U32 reserved1                   : 4;
1780*437bfbebSnyanmisaka     } rdo_b16_inter_var_thd3;
1781*437bfbebSnyanmisaka 
1782*437bfbebSnyanmisaka     /* 0x0000210c reg2115 */
1783*437bfbebSnyanmisaka     struct {
1784*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt00    : 8;
1785*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt01    : 8;
1786*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt02    : 8;
1787*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1788*437bfbebSnyanmisaka     } rdo_b16_inter_atf_wgt0;
1789*437bfbebSnyanmisaka 
1790*437bfbebSnyanmisaka     /* 0x00002110 reg2116 */
1791*437bfbebSnyanmisaka     struct {
1792*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt10    : 8;
1793*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt11    : 8;
1794*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt12    : 8;
1795*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1796*437bfbebSnyanmisaka     } rdo_b16_inter_atf_wgt1;
1797*437bfbebSnyanmisaka 
1798*437bfbebSnyanmisaka     /* 0x00002114 reg2117 */
1799*437bfbebSnyanmisaka     struct {
1800*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt20    : 8;
1801*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt21    : 8;
1802*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt22    : 8;
1803*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1804*437bfbebSnyanmisaka     } rdo_b16_inter_atf_wgt2;
1805*437bfbebSnyanmisaka 
1806*437bfbebSnyanmisaka     /* 0x00002118 reg2118 */
1807*437bfbebSnyanmisaka     struct {
1808*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt30    : 8;
1809*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt31    : 8;
1810*437bfbebSnyanmisaka         RK_U32 cu16_rdo_inter_atf_wgt32    : 8;
1811*437bfbebSnyanmisaka         RK_U32 reserved                    : 8;
1812*437bfbebSnyanmisaka     } rdo_b16_inter_atf_wgt3;
1813*437bfbebSnyanmisaka 
1814*437bfbebSnyanmisaka     /* 0x0000211c reg2119 */
1815*437bfbebSnyanmisaka     struct {
1816*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_cime_thd0    : 12;
1817*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
1818*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_cime_thd1    : 12;
1819*437bfbebSnyanmisaka         RK_U32 reserved1                      : 4;
1820*437bfbebSnyanmisaka     } rdo_skip_cime_thd0;
1821*437bfbebSnyanmisaka 
1822*437bfbebSnyanmisaka     /* 0x00002120 reg2120 */
1823*437bfbebSnyanmisaka     struct {
1824*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_cime_thd2    : 12;
1825*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
1826*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_cime_thd3    : 12;
1827*437bfbebSnyanmisaka         RK_U32 reserved1                      : 4;
1828*437bfbebSnyanmisaka     } rdo_skip_cime_thd1;
1829*437bfbebSnyanmisaka 
1830*437bfbebSnyanmisaka     /* 0x00002124 reg2121 */
1831*437bfbebSnyanmisaka     struct {
1832*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_var_thd10    : 12;
1833*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
1834*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_var_thd11    : 12;
1835*437bfbebSnyanmisaka         RK_U32 reserved1                      : 4;
1836*437bfbebSnyanmisaka     } rdo_skip_var_thd0;
1837*437bfbebSnyanmisaka 
1838*437bfbebSnyanmisaka     /* 0x00002128 reg2122 */
1839*437bfbebSnyanmisaka     struct {
1840*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_var_thd20    : 12;
1841*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
1842*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_var_thd21    : 12;
1843*437bfbebSnyanmisaka         RK_U32 reserved1                      : 4;
1844*437bfbebSnyanmisaka     } rdo_skip_var_thd1;
1845*437bfbebSnyanmisaka 
1846*437bfbebSnyanmisaka     /* 0x0000212c reg2123 */
1847*437bfbebSnyanmisaka     struct {
1848*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_var_thd30    : 12;
1849*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
1850*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_var_thd31    : 12;
1851*437bfbebSnyanmisaka         RK_U32 reserved1                      : 4;
1852*437bfbebSnyanmisaka     } rdo_skip_var_thd2;
1853*437bfbebSnyanmisaka 
1854*437bfbebSnyanmisaka     /* 0x00002130 reg2124 */
1855*437bfbebSnyanmisaka     struct {
1856*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_var_thd40    : 12;
1857*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
1858*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_var_thd41    : 12;
1859*437bfbebSnyanmisaka         RK_U32 reserved1                      : 4;
1860*437bfbebSnyanmisaka     } rdo_skip_var_thd3;
1861*437bfbebSnyanmisaka 
1862*437bfbebSnyanmisaka     /* 0x00002134 reg2125 */
1863*437bfbebSnyanmisaka     struct {
1864*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt00    : 8;
1865*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt10    : 8;
1866*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt11    : 8;
1867*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt12    : 8;
1868*437bfbebSnyanmisaka     } rdo_skip_atf_wgt0;
1869*437bfbebSnyanmisaka 
1870*437bfbebSnyanmisaka     /* 0x00002138 reg2126 */
1871*437bfbebSnyanmisaka     struct {
1872*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt20    : 8;
1873*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt21    : 8;
1874*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt22    : 8;
1875*437bfbebSnyanmisaka         RK_U32 reserved                       : 8;
1876*437bfbebSnyanmisaka     } rdo_skip_atf_wgt1;
1877*437bfbebSnyanmisaka 
1878*437bfbebSnyanmisaka     /* 0x0000213c reg2127 */
1879*437bfbebSnyanmisaka     struct {
1880*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt30    : 8;
1881*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt31    : 8;
1882*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt32    : 8;
1883*437bfbebSnyanmisaka         RK_U32 reserved                       : 8;
1884*437bfbebSnyanmisaka     } rdo_skip_atf_wgt2;
1885*437bfbebSnyanmisaka 
1886*437bfbebSnyanmisaka     /* 0x00002140 reg2128 */
1887*437bfbebSnyanmisaka     struct {
1888*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt40    : 8;
1889*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt41    : 8;
1890*437bfbebSnyanmisaka         RK_U32 atf_rdo_skip_atf_wgt42    : 8;
1891*437bfbebSnyanmisaka         RK_U32 reserved                       : 8;
1892*437bfbebSnyanmisaka     } rdo_skip_atf_wgt3;
1893*437bfbebSnyanmisaka 
1894*437bfbebSnyanmisaka     /* 0x00002144 reg2129 */
1895*437bfbebSnyanmisaka     struct {
1896*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_cime_thd0    : 12;
1897*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1898*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_cime_thd1    : 12;
1899*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1900*437bfbebSnyanmisaka     } rdo_b8_intra_cime_thd0;
1901*437bfbebSnyanmisaka 
1902*437bfbebSnyanmisaka     /* 0x00002148 reg2130 */
1903*437bfbebSnyanmisaka     struct {
1904*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_cime_thd2    : 12;
1905*437bfbebSnyanmisaka         RK_U32 reserved                   : 20;
1906*437bfbebSnyanmisaka     } rdo_b8_intra_cime_thd1;
1907*437bfbebSnyanmisaka 
1908*437bfbebSnyanmisaka     /* 0x0000214c reg2131 */
1909*437bfbebSnyanmisaka     struct {
1910*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_var_thd00    : 12;
1911*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1912*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_var_thd01    : 12;
1913*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1914*437bfbebSnyanmisaka     } rdo_b8_intra_var_thd0;
1915*437bfbebSnyanmisaka 
1916*437bfbebSnyanmisaka     /* 0x00002150 reg2132 */
1917*437bfbebSnyanmisaka     struct {
1918*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_var_thd10    : 12;
1919*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1920*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_var_thd11    : 12;
1921*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1922*437bfbebSnyanmisaka     } rdo_b8_intra_var_thd1;
1923*437bfbebSnyanmisaka 
1924*437bfbebSnyanmisaka     /* 0x00002154 reg2133 */
1925*437bfbebSnyanmisaka     struct {
1926*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_var_thd20    : 12;
1927*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1928*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_var_thd21    : 12;
1929*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1930*437bfbebSnyanmisaka     } rdo_b8_intra_var_thd2;
1931*437bfbebSnyanmisaka 
1932*437bfbebSnyanmisaka     /* 0x00002158 reg2134 */
1933*437bfbebSnyanmisaka     struct {
1934*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_var_thd30    : 12;
1935*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1936*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_var_thd31    : 12;
1937*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1938*437bfbebSnyanmisaka     } rdo_b8_intra_var_thd3;
1939*437bfbebSnyanmisaka 
1940*437bfbebSnyanmisaka     /* 0x0000215c reg2135 */
1941*437bfbebSnyanmisaka     struct {
1942*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt00    : 8;
1943*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt01    : 8;
1944*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt02    : 8;
1945*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1946*437bfbebSnyanmisaka     } rdo_b8_intra_atf_wgt0;
1947*437bfbebSnyanmisaka 
1948*437bfbebSnyanmisaka     /* 0x00002160 reg2136 */
1949*437bfbebSnyanmisaka     struct {
1950*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt10    : 8;
1951*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt11    : 8;
1952*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt12    : 8;
1953*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1954*437bfbebSnyanmisaka     } rdo_b8_intra_atf_wgt1;
1955*437bfbebSnyanmisaka 
1956*437bfbebSnyanmisaka     /* 0x00002164 reg2137 */
1957*437bfbebSnyanmisaka     struct {
1958*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt20    : 8;
1959*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt21    : 8;
1960*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt22    : 8;
1961*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1962*437bfbebSnyanmisaka     } rdo_b8_intra_atf_wgt2;
1963*437bfbebSnyanmisaka 
1964*437bfbebSnyanmisaka     /* 0x00002168 reg2138 */
1965*437bfbebSnyanmisaka     struct {
1966*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt30    : 8;
1967*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt31    : 8;
1968*437bfbebSnyanmisaka         RK_U32 cu8_rdo_intra_atf_wgt32    : 8;
1969*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
1970*437bfbebSnyanmisaka     } rdo_b8_intra_atf_wgt3;
1971*437bfbebSnyanmisaka 
1972*437bfbebSnyanmisaka     /* 0x0000216c reg2139 */
1973*437bfbebSnyanmisaka     struct {
1974*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_cime_thd0    : 12;
1975*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1976*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_cime_thd1    : 12;
1977*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1978*437bfbebSnyanmisaka     } rdo_b8_inter_cime_thd0;
1979*437bfbebSnyanmisaka 
1980*437bfbebSnyanmisaka     /* 0x00002170 reg2140 */
1981*437bfbebSnyanmisaka     struct {
1982*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_cime_thd2    : 12;
1983*437bfbebSnyanmisaka         RK_U32 reserved                   : 20;
1984*437bfbebSnyanmisaka     } rdo_b8_inter_cime_thd1;
1985*437bfbebSnyanmisaka 
1986*437bfbebSnyanmisaka     /* 0x00002174 reg2141 */
1987*437bfbebSnyanmisaka     struct {
1988*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_var_thd00    : 12;
1989*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1990*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_var_thd01    : 12;
1991*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
1992*437bfbebSnyanmisaka     } rdo_b8_inter_var_thd0;
1993*437bfbebSnyanmisaka 
1994*437bfbebSnyanmisaka     /* 0x00002178 reg2142 */
1995*437bfbebSnyanmisaka     struct {
1996*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_var_thd10    : 12;
1997*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
1998*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_var_thd11    : 12;
1999*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
2000*437bfbebSnyanmisaka     } rdo_b8_inter_var_thd1;
2001*437bfbebSnyanmisaka 
2002*437bfbebSnyanmisaka     /* 0x0000217c reg2143 */
2003*437bfbebSnyanmisaka     struct {
2004*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_var_thd20    : 12;
2005*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
2006*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_var_thd21    : 12;
2007*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
2008*437bfbebSnyanmisaka     } rdo_b8_inter_var_thd2;
2009*437bfbebSnyanmisaka 
2010*437bfbebSnyanmisaka     /* 0x00002180 reg2144 */
2011*437bfbebSnyanmisaka     struct {
2012*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_var_thd30    : 12;
2013*437bfbebSnyanmisaka         RK_U32 reserved                   : 4;
2014*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_var_thd31    : 12;
2015*437bfbebSnyanmisaka         RK_U32 reserved1                  : 4;
2016*437bfbebSnyanmisaka     } rdo_b8_inter_var_thd3;
2017*437bfbebSnyanmisaka 
2018*437bfbebSnyanmisaka     /* 0x00002184 reg2145 */
2019*437bfbebSnyanmisaka     struct {
2020*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt00    : 8;
2021*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt01    : 8;
2022*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt02    : 8;
2023*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
2024*437bfbebSnyanmisaka     } rdo_b8_inter_atf_wgt0;
2025*437bfbebSnyanmisaka 
2026*437bfbebSnyanmisaka     /* 0x00002188 reg2146 */
2027*437bfbebSnyanmisaka     struct {
2028*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt10    : 8;
2029*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt11    : 8;
2030*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt12    : 8;
2031*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
2032*437bfbebSnyanmisaka     } rdo_b8_inter_atf_wgt1;
2033*437bfbebSnyanmisaka 
2034*437bfbebSnyanmisaka     /* 0x0000218c reg2147 */
2035*437bfbebSnyanmisaka     struct {
2036*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt20    : 8;
2037*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt21    : 8;
2038*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt22    : 8;
2039*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
2040*437bfbebSnyanmisaka     } rdo_b8_inter_atf_wgt2;
2041*437bfbebSnyanmisaka 
2042*437bfbebSnyanmisaka     /* 0x00002190 reg2148 */
2043*437bfbebSnyanmisaka     struct {
2044*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt30    : 8;
2045*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt31    : 8;
2046*437bfbebSnyanmisaka         RK_U32 cu8_rdo_inter_atf_wgt32    : 8;
2047*437bfbebSnyanmisaka         RK_U32 reserved                   : 8;
2048*437bfbebSnyanmisaka     } rdo_b8_inter_atf_wgt3;
2049*437bfbebSnyanmisaka 
2050*437bfbebSnyanmisaka     /* 0x00002194 reg2149 */
2051*437bfbebSnyanmisaka     struct {
2052*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_cime_thd0    : 12;
2053*437bfbebSnyanmisaka         RK_U32 reserved                  : 4;
2054*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_cime_thd1    : 12;
2055*437bfbebSnyanmisaka         RK_U32 reserved1                 : 4;
2056*437bfbebSnyanmisaka     } rdo_b8_skip_cime_thd0;
2057*437bfbebSnyanmisaka 
2058*437bfbebSnyanmisaka     /* 0x00002198 reg2150 */
2059*437bfbebSnyanmisaka     struct {
2060*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_cime_thd2    : 12;
2061*437bfbebSnyanmisaka         RK_U32 reserved                  : 4;
2062*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_cime_thd3    : 12;
2063*437bfbebSnyanmisaka         RK_U32 reserved1                 : 4;
2064*437bfbebSnyanmisaka     } rdo_b8_skip_cime_thd1;
2065*437bfbebSnyanmisaka 
2066*437bfbebSnyanmisaka     /* 0x0000219c reg2151 */
2067*437bfbebSnyanmisaka     struct {
2068*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_var_thd10    : 12;
2069*437bfbebSnyanmisaka         RK_U32 reserved                  : 4;
2070*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_var_thd11    : 12;
2071*437bfbebSnyanmisaka         RK_U32 reserved1                 : 4;
2072*437bfbebSnyanmisaka     } rdo_b8_skip_var_thd0;
2073*437bfbebSnyanmisaka 
2074*437bfbebSnyanmisaka     /* 0x000021a0 reg2152 */
2075*437bfbebSnyanmisaka     struct {
2076*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_var_thd20    : 12;
2077*437bfbebSnyanmisaka         RK_U32 reserved                  : 4;
2078*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_var_thd21    : 12;
2079*437bfbebSnyanmisaka         RK_U32 reserved1                 : 4;
2080*437bfbebSnyanmisaka     } rdo_b8_skip_var_thd1;
2081*437bfbebSnyanmisaka 
2082*437bfbebSnyanmisaka     /* 0x000021a4 reg2153 */
2083*437bfbebSnyanmisaka     struct {
2084*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_var_thd30    : 12;
2085*437bfbebSnyanmisaka         RK_U32 reserved                  : 4;
2086*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_var_thd31    : 12;
2087*437bfbebSnyanmisaka         RK_U32 reserved1                 : 4;
2088*437bfbebSnyanmisaka     } rdo_b8_skip_var_thd2;
2089*437bfbebSnyanmisaka 
2090*437bfbebSnyanmisaka     /* 0x000021a8 reg2154 */
2091*437bfbebSnyanmisaka     struct {
2092*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_var_thd40    : 12;
2093*437bfbebSnyanmisaka         RK_U32 reserved                  : 4;
2094*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_var_thd41    : 12;
2095*437bfbebSnyanmisaka         RK_U32 reserved1                 : 4;
2096*437bfbebSnyanmisaka     } rdo_b8_skip_var_thd3;
2097*437bfbebSnyanmisaka 
2098*437bfbebSnyanmisaka     /* 0x000021ac reg2155 */
2099*437bfbebSnyanmisaka     struct {
2100*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt00    : 8;
2101*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt10    : 8;
2102*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt11    : 8;
2103*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt12    : 8;
2104*437bfbebSnyanmisaka     } rdo_b8_skip_atf_wgt0;
2105*437bfbebSnyanmisaka 
2106*437bfbebSnyanmisaka     /* 0x000021b0 reg2156 */
2107*437bfbebSnyanmisaka     struct {
2108*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt20    : 8;
2109*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt21    : 8;
2110*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt22    : 8;
2111*437bfbebSnyanmisaka         RK_U32 reserved                  : 8;
2112*437bfbebSnyanmisaka     } rdo_b8_skip_atf_wgt1;
2113*437bfbebSnyanmisaka 
2114*437bfbebSnyanmisaka     /* 0x000021b4 reg2157 */
2115*437bfbebSnyanmisaka     struct {
2116*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt30    : 8;
2117*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt31    : 8;
2118*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt32    : 8;
2119*437bfbebSnyanmisaka         RK_U32 reserved                  : 8;
2120*437bfbebSnyanmisaka     } rdo_b8_skip_atf_wgt2;
2121*437bfbebSnyanmisaka 
2122*437bfbebSnyanmisaka     /* 0x000021b8 reg2158 */
2123*437bfbebSnyanmisaka     struct {
2124*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt40    : 8;
2125*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt41    : 8;
2126*437bfbebSnyanmisaka         RK_U32 cu8_rdo_skip_atf_wgt42    : 8;
2127*437bfbebSnyanmisaka         RK_U32 reserved                  : 8;
2128*437bfbebSnyanmisaka     } rdo_b8_skip_atf_wgt3;
2129*437bfbebSnyanmisaka 
2130*437bfbebSnyanmisaka     /* 0x000021bc reg2159 */
2131*437bfbebSnyanmisaka     struct {
2132*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu64_th0    : 12;
2133*437bfbebSnyanmisaka         RK_U32 reserved                : 4;
2134*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu64_th1    : 12;
2135*437bfbebSnyanmisaka         RK_U32 reserved1               : 4;
2136*437bfbebSnyanmisaka     } rdo_segment_b64_thd0;
2137*437bfbebSnyanmisaka 
2138*437bfbebSnyanmisaka     /* 0x000021c0 reg2160 */
2139*437bfbebSnyanmisaka     struct {
2140*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu64_th2           : 12;
2141*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
2142*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu64_th3           : 4;
2143*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu64_th4           : 4;
2144*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu64_th5_minus1    : 4;
2145*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu64_th6_minus1    : 4;
2146*437bfbebSnyanmisaka     } rdo_segment_b64_thd1;
2147*437bfbebSnyanmisaka 
2148*437bfbebSnyanmisaka     /* 0x000021c4 reg2161 */
2149*437bfbebSnyanmisaka     struct {
2150*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu32_th0    : 12;
2151*437bfbebSnyanmisaka         RK_U32 reserved                : 4;
2152*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu32_th1    : 12;
2153*437bfbebSnyanmisaka         RK_U32 reserved1               : 4;
2154*437bfbebSnyanmisaka     } rdo_segment_b32_thd0;
2155*437bfbebSnyanmisaka 
2156*437bfbebSnyanmisaka     /* 0x000021c8 reg2162 */
2157*437bfbebSnyanmisaka     struct {
2158*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu32_th2           : 12;
2159*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
2160*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu32_th3           : 2;
2161*437bfbebSnyanmisaka         RK_U32 reserved1                      : 2;
2162*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu32_th4           : 2;
2163*437bfbebSnyanmisaka         RK_U32 reserved2                      : 2;
2164*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu32_th5_minus1    : 2;
2165*437bfbebSnyanmisaka         RK_U32 reserved3                      : 2;
2166*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu32_th6_minus1    : 2;
2167*437bfbebSnyanmisaka         RK_U32 reserved4                      : 2;
2168*437bfbebSnyanmisaka     } rdo_segment_b32_thd1;
2169*437bfbebSnyanmisaka 
2170*437bfbebSnyanmisaka     /* 0x000021cc reg2163 */
2171*437bfbebSnyanmisaka     struct {
2172*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu64_multi    : 8;
2173*437bfbebSnyanmisaka         RK_U32 rdo_segment_cu32_multi    : 8;
2174*437bfbebSnyanmisaka         RK_U32 rdo_smear_cu16_multi      : 8;
2175*437bfbebSnyanmisaka         RK_U32 reserved                  : 8;
2176*437bfbebSnyanmisaka     } rdo_segment_multi;
2177*437bfbebSnyanmisaka 
2178*437bfbebSnyanmisaka     /* 0x000021d0 reg2164 */
2179*437bfbebSnyanmisaka     struct {
2180*437bfbebSnyanmisaka         RK_U32 rdo_smear_cu16_cime_sad_th0    : 12;
2181*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
2182*437bfbebSnyanmisaka         RK_U32 rdo_smear_cu16_cime_sad_th1    : 12;
2183*437bfbebSnyanmisaka         RK_U32 reserved1                      : 4;
2184*437bfbebSnyanmisaka     } rdo_b16_smear_thd0;
2185*437bfbebSnyanmisaka 
2186*437bfbebSnyanmisaka     /* 0x000021d4 reg2165 */
2187*437bfbebSnyanmisaka     struct {
2188*437bfbebSnyanmisaka         RK_U32 rdo_smear_cu16_cime_sad_th2    : 12;
2189*437bfbebSnyanmisaka         RK_U32 reserved                       : 4;
2190*437bfbebSnyanmisaka         RK_U32 rdo_smear_cu16_cime_sad_th3    : 12;
2191*437bfbebSnyanmisaka         RK_U32 reserved1                      : 4;
2192*437bfbebSnyanmisaka     } rdo_b16_smear_thd1;
2193*437bfbebSnyanmisaka 
2194*437bfbebSnyanmisaka     /* 0x000021d8 reg2166 */
2195*437bfbebSnyanmisaka     struct {
2196*437bfbebSnyanmisaka         RK_U32 pre_intra32_cst_var_th00    : 12;
2197*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
2198*437bfbebSnyanmisaka         RK_U32 pre_intra32_cst_var_th01    : 12;
2199*437bfbebSnyanmisaka         RK_U32 reserved1                   : 1;
2200*437bfbebSnyanmisaka         RK_U32 pre_intra32_mode_th         : 3;
2201*437bfbebSnyanmisaka     } preintra_b32_cst_var_thd;
2202*437bfbebSnyanmisaka 
2203*437bfbebSnyanmisaka     /* 0x000021dc reg2167 */
2204*437bfbebSnyanmisaka     struct {
2205*437bfbebSnyanmisaka         RK_U32 pre_intra32_cst_wgt00    : 8;
2206*437bfbebSnyanmisaka         RK_U32 reserved                 : 8;
2207*437bfbebSnyanmisaka         RK_U32 pre_intra32_cst_wgt01    : 8;
2208*437bfbebSnyanmisaka         RK_U32 reserved1                : 8;
2209*437bfbebSnyanmisaka     } preintra_b32_cst_wgt;
2210*437bfbebSnyanmisaka 
2211*437bfbebSnyanmisaka     /* 0x000021e0 reg2168 */
2212*437bfbebSnyanmisaka     struct {
2213*437bfbebSnyanmisaka         RK_U32 pre_intra16_cst_var_th00    : 12;
2214*437bfbebSnyanmisaka         RK_U32 reserved                    : 4;
2215*437bfbebSnyanmisaka         RK_U32 pre_intra16_cst_var_th01    : 12;
2216*437bfbebSnyanmisaka         RK_U32 reserved1                   : 1;
2217*437bfbebSnyanmisaka         RK_U32 pre_intra16_mode_th         : 3;
2218*437bfbebSnyanmisaka     } preintra_b16_cst_var_thd;
2219*437bfbebSnyanmisaka 
2220*437bfbebSnyanmisaka     /* 0x000021e4 reg2169 */
2221*437bfbebSnyanmisaka     struct {
2222*437bfbebSnyanmisaka         RK_U32 pre_intra16_cst_wgt00    : 8;
2223*437bfbebSnyanmisaka         RK_U32 reserved                 : 8;
2224*437bfbebSnyanmisaka         RK_U32 pre_intra16_cst_wgt01    : 8;
2225*437bfbebSnyanmisaka         RK_U32 reserved1                : 8;
2226*437bfbebSnyanmisaka     } preintra_b16_cst_wgt;
2227*437bfbebSnyanmisaka } Vepu580RdoCfg;
2228*437bfbebSnyanmisaka 
2229*437bfbebSnyanmisaka /* class: scaling list  */
2230*437bfbebSnyanmisaka /* 0x00002200 reg2200 - 0x00003084 reg3105*/
2231*437bfbebSnyanmisaka typedef struct Vepu580SclCfg_t {
2232*437bfbebSnyanmisaka     /* 0x00002200 */
2233*437bfbebSnyanmisaka     RK_U16  intra8_y[64];
2234*437bfbebSnyanmisaka     RK_U16  intra8_u[64];
2235*437bfbebSnyanmisaka     RK_U16  intra8_v[64];
2236*437bfbebSnyanmisaka     RK_U16  inter8_y[64];
2237*437bfbebSnyanmisaka     RK_U16  inter8_u[64];
2238*437bfbebSnyanmisaka     RK_U16  inter8_v[64];
2239*437bfbebSnyanmisaka     /* 0x00002500 */
2240*437bfbebSnyanmisaka     RK_U32  q_iq_16_32[480];
2241*437bfbebSnyanmisaka     /* 0x00002c80 */
2242*437bfbebSnyanmisaka     RK_U32  q_dc_y16;
2243*437bfbebSnyanmisaka     RK_U32  q_dc_u16;
2244*437bfbebSnyanmisaka     RK_U32  q_dc_v16;
2245*437bfbebSnyanmisaka     RK_U32  q_dc_v32;
2246*437bfbebSnyanmisaka     /* 0x00002c90 */
2247*437bfbebSnyanmisaka     RK_U32  iq_dc_0;
2248*437bfbebSnyanmisaka     RK_U32  iq_dc_1;
2249*437bfbebSnyanmisaka     /* 0x00002c98 */
2250*437bfbebSnyanmisaka     RK_U32  scal_clk_sel;
2251*437bfbebSnyanmisaka } Vepu580SclCfg;
2252*437bfbebSnyanmisaka 
2253*437bfbebSnyanmisaka /* class: osd */
2254*437bfbebSnyanmisaka /* 0x00003000 reg3072 - 0x00003084 reg3105*/
2255*437bfbebSnyanmisaka typedef struct Vepu580Osd_t {
2256*437bfbebSnyanmisaka     /* 0x00003000 reg3072 */
2257*437bfbebSnyanmisaka     struct {
2258*437bfbebSnyanmisaka         RK_U32 osd_lu_inv_en     : 8;
2259*437bfbebSnyanmisaka         RK_U32 osd_ch_inv_en     : 8;
2260*437bfbebSnyanmisaka         RK_U32 osd_lu_inv_msk    : 8;
2261*437bfbebSnyanmisaka         RK_U32 osd_ch_inv_msk    : 8;
2262*437bfbebSnyanmisaka     } osd_inv_en;
2263*437bfbebSnyanmisaka 
2264*437bfbebSnyanmisaka     /* 0x00003004 reg3073 */
2265*437bfbebSnyanmisaka     struct {
2266*437bfbebSnyanmisaka         RK_U32 osd_ithd_r0    : 4;
2267*437bfbebSnyanmisaka         RK_U32 osd_ithd_r1    : 4;
2268*437bfbebSnyanmisaka         RK_U32 osd_ithd_r2    : 4;
2269*437bfbebSnyanmisaka         RK_U32 osd_ithd_r3    : 4;
2270*437bfbebSnyanmisaka         RK_U32 osd_ithd_r4    : 4;
2271*437bfbebSnyanmisaka         RK_U32 osd_ithd_r5    : 4;
2272*437bfbebSnyanmisaka         RK_U32 osd_ithd_r6    : 4;
2273*437bfbebSnyanmisaka         RK_U32 osd_ithd_r7    : 4;
2274*437bfbebSnyanmisaka     } osd_inv_thd;
2275*437bfbebSnyanmisaka 
2276*437bfbebSnyanmisaka     /* 0x00003008 reg3074 */
2277*437bfbebSnyanmisaka     struct {
2278*437bfbebSnyanmisaka         RK_U32 osd_en         : 8;
2279*437bfbebSnyanmisaka         RK_U32 osd_itype      : 8;
2280*437bfbebSnyanmisaka         RK_U32 osd_plt_cks    : 1;
2281*437bfbebSnyanmisaka         RK_U32 osd_plt_typ    : 1;
2282*437bfbebSnyanmisaka         RK_U32 reserved       : 14;
2283*437bfbebSnyanmisaka     } osd_cfg;
2284*437bfbebSnyanmisaka 
2285*437bfbebSnyanmisaka     /* 0x300c */
2286*437bfbebSnyanmisaka     RK_U32 reserved_3075;
2287*437bfbebSnyanmisaka 
2288*437bfbebSnyanmisaka     /* 0x00003010 reg3076 - 0x0000304c reg3091*/
2289*437bfbebSnyanmisaka     OSD_POS_NEW osd_pos[8];
2290*437bfbebSnyanmisaka 
2291*437bfbebSnyanmisaka     /* 0x00003050 reg3092 - 0x0000306c reg3099 */
2292*437bfbebSnyanmisaka     RK_U32 osd_addr[8];
2293*437bfbebSnyanmisaka 
2294*437bfbebSnyanmisaka     /* 0x3070 - 0x307c */
2295*437bfbebSnyanmisaka     RK_U32 reserved3100_3103[4];
2296*437bfbebSnyanmisaka 
2297*437bfbebSnyanmisaka     /* 0x03080-0x347c reg3104-reg3360 */
2298*437bfbebSnyanmisaka     RK_U32 plt[256];
2299*437bfbebSnyanmisaka } Vepu580Osd;
2300*437bfbebSnyanmisaka 
2301*437bfbebSnyanmisaka // /* class: osd_plt 255 */
2302*437bfbebSnyanmisaka // /* 0x0000347c reg3359 */
2303*437bfbebSnyanmisaka // typedef struct Vepu580Section6_t {
2304*437bfbebSnyanmisaka //     /* 0x0000347c reg3359 */
2305*437bfbebSnyanmisaka //     struct {
2306*437bfbebSnyanmisaka //         RK_U32 y        : 8;
2307*437bfbebSnyanmisaka //         RK_U32 u        : 8;
2308*437bfbebSnyanmisaka //         RK_U32 v        : 8;
2309*437bfbebSnyanmisaka //         RK_U32 alpha    : 8;
2310*437bfbebSnyanmisaka //     } osd_plt255;
2311*437bfbebSnyanmisaka // } vepu580section6;
2312*437bfbebSnyanmisaka 
2313*437bfbebSnyanmisaka /* class: st */
2314*437bfbebSnyanmisaka /* 0x00004000 reg4096 - 0x000042cc reg4275 */
2315*437bfbebSnyanmisaka typedef struct Vepu580Status_t {
2316*437bfbebSnyanmisaka     /* 0x00004000 reg4096 */
2317*437bfbebSnyanmisaka     RK_U32 bs_lgth_l32;
2318*437bfbebSnyanmisaka 
2319*437bfbebSnyanmisaka     /* 0x00004004 reg4097 */
2320*437bfbebSnyanmisaka     struct {
2321*437bfbebSnyanmisaka         RK_U32 bs_lgth_h8    : 8;
2322*437bfbebSnyanmisaka         RK_U32 reserved      : 8;
2323*437bfbebSnyanmisaka         RK_U32 sse_l16       : 16;
2324*437bfbebSnyanmisaka     } st_sse_bsl;
2325*437bfbebSnyanmisaka 
2326*437bfbebSnyanmisaka     /* 0x00004008 reg4098 */
2327*437bfbebSnyanmisaka     RK_U32 sse_h32;
2328*437bfbebSnyanmisaka 
2329*437bfbebSnyanmisaka     /* 0x0000400c reg4099 */
2330*437bfbebSnyanmisaka     RK_U32 qp_sum;
2331*437bfbebSnyanmisaka 
2332*437bfbebSnyanmisaka     /* 0x00004010 reg4100 */
2333*437bfbebSnyanmisaka     struct {
2334*437bfbebSnyanmisaka         RK_U32 sao_cnum    : 16;
2335*437bfbebSnyanmisaka         RK_U32 sao_ynum    : 16;
2336*437bfbebSnyanmisaka     } st_sao;
2337*437bfbebSnyanmisaka 
2338*437bfbebSnyanmisaka     /* 0x00004014 reg4101 */
2339*437bfbebSnyanmisaka     RK_U32 rdo_head_bits;
2340*437bfbebSnyanmisaka 
2341*437bfbebSnyanmisaka     /* 0x00004018 reg4102 */
2342*437bfbebSnyanmisaka     struct {
2343*437bfbebSnyanmisaka         RK_U32 rdo_head_bits_h8    : 8;
2344*437bfbebSnyanmisaka         RK_U32 reserved            : 8;
2345*437bfbebSnyanmisaka         RK_U32 rdo_res_bits_l16    : 16;
2346*437bfbebSnyanmisaka     } st_head_res_bl;
2347*437bfbebSnyanmisaka 
2348*437bfbebSnyanmisaka     /* 0x0000401c reg4103 */
2349*437bfbebSnyanmisaka     RK_U32 rdo_res_bits_h24;
2350*437bfbebSnyanmisaka 
2351*437bfbebSnyanmisaka     /* 0x00004020 reg4104 */
2352*437bfbebSnyanmisaka     struct {
2353*437bfbebSnyanmisaka         RK_U32 st_enc      : 2;
2354*437bfbebSnyanmisaka         RK_U32 st_sclr     : 1;
2355*437bfbebSnyanmisaka         RK_U32 reserved    : 29;
2356*437bfbebSnyanmisaka     } st_enc;
2357*437bfbebSnyanmisaka 
2358*437bfbebSnyanmisaka     /* 0x00004024 reg4105 */
2359*437bfbebSnyanmisaka     struct {
2360*437bfbebSnyanmisaka         RK_U32 fnum_cfg_done    : 8;
2361*437bfbebSnyanmisaka         RK_U32 fnum_cfg         : 8;
2362*437bfbebSnyanmisaka         RK_U32 fnum_int         : 8;
2363*437bfbebSnyanmisaka         RK_U32 fnum_enc_done    : 8;
2364*437bfbebSnyanmisaka     } st_lkt;
2365*437bfbebSnyanmisaka 
2366*437bfbebSnyanmisaka     /* 0x00004028 reg4106 */
2367*437bfbebSnyanmisaka     RK_U32 node_addr;
2368*437bfbebSnyanmisaka 
2369*437bfbebSnyanmisaka     /* 0x0000402c reg4107 */
2370*437bfbebSnyanmisaka     struct {
2371*437bfbebSnyanmisaka         RK_U32 bsbw_ovfl    : 1;
2372*437bfbebSnyanmisaka         RK_U32 reserved     : 2;
2373*437bfbebSnyanmisaka         RK_U32 bsbw_addr    : 28;
2374*437bfbebSnyanmisaka         RK_U32 reserved1    : 1;
2375*437bfbebSnyanmisaka     } st_bsb;
2376*437bfbebSnyanmisaka 
2377*437bfbebSnyanmisaka     /* 0x00004030 reg4108 */
2378*437bfbebSnyanmisaka     struct {
2379*437bfbebSnyanmisaka         RK_U32 axib_idl     : 8;
2380*437bfbebSnyanmisaka         RK_U32 axib_ovfl    : 8;
2381*437bfbebSnyanmisaka         RK_U32 axib_err     : 8;
2382*437bfbebSnyanmisaka         RK_U32 axir_err     : 7;
2383*437bfbebSnyanmisaka         RK_U32 reserved     : 1;
2384*437bfbebSnyanmisaka     } st_bus;
2385*437bfbebSnyanmisaka 
2386*437bfbebSnyanmisaka     /* 0x00004034 reg4109 */
2387*437bfbebSnyanmisaka     struct {
2388*437bfbebSnyanmisaka         RK_U32 sli_num     : 6;
2389*437bfbebSnyanmisaka         RK_U32 reserved    : 26;
2390*437bfbebSnyanmisaka     } st_snum;
2391*437bfbebSnyanmisaka 
2392*437bfbebSnyanmisaka     /* 0x00004038 reg4110 */
2393*437bfbebSnyanmisaka     struct {
2394*437bfbebSnyanmisaka         RK_U32 sli_len     : 25;
2395*437bfbebSnyanmisaka         RK_U32 reserved    : 7;
2396*437bfbebSnyanmisaka     } st_slen;
2397*437bfbebSnyanmisaka 
2398*437bfbebSnyanmisaka     /* 0x403c - 0x40fc */
2399*437bfbebSnyanmisaka     RK_U32 reserved4111_4159[49];
2400*437bfbebSnyanmisaka 
2401*437bfbebSnyanmisaka     /* 0x00004100 reg4160 */
2402*437bfbebSnyanmisaka     struct {
2403*437bfbebSnyanmisaka         RK_U32 pnum_p64    : 17;
2404*437bfbebSnyanmisaka         RK_U32 reserved    : 15;
2405*437bfbebSnyanmisaka     } st_pnum_p64;
2406*437bfbebSnyanmisaka 
2407*437bfbebSnyanmisaka     /* 0x00004104 reg4161 */
2408*437bfbebSnyanmisaka     struct {
2409*437bfbebSnyanmisaka         RK_U32 pnum_p32    : 19;
2410*437bfbebSnyanmisaka         RK_U32 reserved    : 13;
2411*437bfbebSnyanmisaka     } st_pnum_p32;
2412*437bfbebSnyanmisaka 
2413*437bfbebSnyanmisaka     /* 0x00004108 reg4162 */
2414*437bfbebSnyanmisaka     struct {
2415*437bfbebSnyanmisaka         RK_U32 pnum_p16    : 21;
2416*437bfbebSnyanmisaka         RK_U32 reserved    : 11;
2417*437bfbebSnyanmisaka     } st_pnum_p16;
2418*437bfbebSnyanmisaka 
2419*437bfbebSnyanmisaka     /* 0x0000410c reg4163 */
2420*437bfbebSnyanmisaka     struct {
2421*437bfbebSnyanmisaka         RK_U32 pnum_p8     : 23;
2422*437bfbebSnyanmisaka         RK_U32 reserved    : 9;
2423*437bfbebSnyanmisaka     } st_pnum_p8;
2424*437bfbebSnyanmisaka 
2425*437bfbebSnyanmisaka     /* 0x00004110 reg4164 */
2426*437bfbebSnyanmisaka     struct {
2427*437bfbebSnyanmisaka         RK_U32 pnum_i32    : 19;
2428*437bfbebSnyanmisaka         RK_U32 reserved    : 13;
2429*437bfbebSnyanmisaka     } st_pnum_i32;
2430*437bfbebSnyanmisaka 
2431*437bfbebSnyanmisaka     /* 0x00004114 reg4165 */
2432*437bfbebSnyanmisaka     struct {
2433*437bfbebSnyanmisaka         RK_U32 pnum_i16    : 21;
2434*437bfbebSnyanmisaka         RK_U32 reserved    : 11;
2435*437bfbebSnyanmisaka     } st_pnum_i16;
2436*437bfbebSnyanmisaka 
2437*437bfbebSnyanmisaka     /* 0x00004118 reg4166 */
2438*437bfbebSnyanmisaka     struct {
2439*437bfbebSnyanmisaka         RK_U32 pnum_i8     : 23;
2440*437bfbebSnyanmisaka         RK_U32 reserved    : 9;
2441*437bfbebSnyanmisaka     } st_pnum_i8;
2442*437bfbebSnyanmisaka 
2443*437bfbebSnyanmisaka     /* 0x0000411c reg4167 */
2444*437bfbebSnyanmisaka     struct {
2445*437bfbebSnyanmisaka         RK_U32 pnum_i4     : 23;
2446*437bfbebSnyanmisaka         RK_U32 reserved    : 9;
2447*437bfbebSnyanmisaka     } st_pnum_i4;
2448*437bfbebSnyanmisaka 
2449*437bfbebSnyanmisaka     /* 0x00004120 reg4168 */
2450*437bfbebSnyanmisaka     RK_U32 madp;
2451*437bfbebSnyanmisaka 
2452*437bfbebSnyanmisaka     /* 0x00004124 reg4169 */
2453*437bfbebSnyanmisaka     struct {
2454*437bfbebSnyanmisaka         RK_U32 num_ctu     : 21;
2455*437bfbebSnyanmisaka         RK_U32 reserved    : 11;
2456*437bfbebSnyanmisaka     } st_bnum_cme;
2457*437bfbebSnyanmisaka 
2458*437bfbebSnyanmisaka     /* 0x00004128 reg4170 */
2459*437bfbebSnyanmisaka     RK_U32 madi;
2460*437bfbebSnyanmisaka 
2461*437bfbebSnyanmisaka     /* 0x0000412c reg4171 */
2462*437bfbebSnyanmisaka     struct {
2463*437bfbebSnyanmisaka         RK_U32 num_b16     : 23;
2464*437bfbebSnyanmisaka         RK_U32 reserved    : 9;
2465*437bfbebSnyanmisaka     } st_bnum_b16;
2466*437bfbebSnyanmisaka 
2467*437bfbebSnyanmisaka     /* 0x00004130 reg4172 */
2468*437bfbebSnyanmisaka     RK_U32 num_madi_max_b16;
2469*437bfbebSnyanmisaka 
2470*437bfbebSnyanmisaka     /* 0x00004134 reg4173 */
2471*437bfbebSnyanmisaka     RK_U32 md_sad_b16num0;
2472*437bfbebSnyanmisaka 
2473*437bfbebSnyanmisaka     /* 0x00004138 reg4174 */
2474*437bfbebSnyanmisaka     RK_U32 md_sad_b16num1;
2475*437bfbebSnyanmisaka 
2476*437bfbebSnyanmisaka     /* 0x0000413c reg4175 */
2477*437bfbebSnyanmisaka     RK_U32 md_sad_b16num2;
2478*437bfbebSnyanmisaka 
2479*437bfbebSnyanmisaka     /* 0x00004140 reg4176 */
2480*437bfbebSnyanmisaka     RK_U32 md_sad_b16num3;
2481*437bfbebSnyanmisaka 
2482*437bfbebSnyanmisaka     /* 0x00004144 reg4177 */
2483*437bfbebSnyanmisaka     RK_U32 madi_b16num0;
2484*437bfbebSnyanmisaka 
2485*437bfbebSnyanmisaka     /* 0x00004148 reg4178 */
2486*437bfbebSnyanmisaka     RK_U32 madi_b16num1;
2487*437bfbebSnyanmisaka 
2488*437bfbebSnyanmisaka     /* 0x0000414c reg4179 */
2489*437bfbebSnyanmisaka     RK_U32 madi_b16num2;
2490*437bfbebSnyanmisaka 
2491*437bfbebSnyanmisaka     /* 0x00004150 reg4180 */
2492*437bfbebSnyanmisaka     RK_U32 madi_b16num3;
2493*437bfbebSnyanmisaka 
2494*437bfbebSnyanmisaka     /* 0x4154 - 0x41fc */
2495*437bfbebSnyanmisaka     RK_U32 reserved4181_4223[43];
2496*437bfbebSnyanmisaka 
2497*437bfbebSnyanmisaka     /* 0x00004200 reg4224 - 0x000042cc reg4275 */
2498*437bfbebSnyanmisaka     // b8num_qp0-51
2499*437bfbebSnyanmisaka     /*
2500*437bfbebSnyanmisaka      * RK_U32 b8num_qp0    : 22;
2501*437bfbebSnyanmisaka      * RK_U32 reserved     : 10;
2502*437bfbebSnyanmisaka      */
2503*437bfbebSnyanmisaka     RK_U32 st_b8_qp[52];
2504*437bfbebSnyanmisaka } Vepu580Status;
2505*437bfbebSnyanmisaka 
2506*437bfbebSnyanmisaka /* class: dbg/st/axipn */
2507*437bfbebSnyanmisaka /* 0x00005000 reg5120 - 0x00005354 reg5333*/
2508*437bfbebSnyanmisaka typedef struct Vepu580Dbg_t {
2509*437bfbebSnyanmisaka     /* 0x00005000 reg5120 */
2510*437bfbebSnyanmisaka     struct {
2511*437bfbebSnyanmisaka         RK_U32 pp_tout      : 1;
2512*437bfbebSnyanmisaka         RK_U32 cme_tout     : 1;
2513*437bfbebSnyanmisaka         RK_U32 swn_tout     : 1;
2514*437bfbebSnyanmisaka         RK_U32 rme_tout     : 1;
2515*437bfbebSnyanmisaka         RK_U32 fme_tout     : 1;
2516*437bfbebSnyanmisaka         RK_U32 rdo_tout     : 1;
2517*437bfbebSnyanmisaka         RK_U32 lpf_tout     : 1;
2518*437bfbebSnyanmisaka         RK_U32 etpy_tout    : 1;
2519*437bfbebSnyanmisaka         RK_U32 frm_tout     : 1;
2520*437bfbebSnyanmisaka         RK_U32 reserved     : 23;
2521*437bfbebSnyanmisaka     } st_wdg;
2522*437bfbebSnyanmisaka 
2523*437bfbebSnyanmisaka     /* 0x00005004 reg5121 */
2524*437bfbebSnyanmisaka     struct {
2525*437bfbebSnyanmisaka         RK_U32 pp_wrk      : 1;
2526*437bfbebSnyanmisaka         RK_U32 cme_wrk     : 1;
2527*437bfbebSnyanmisaka         RK_U32 swn_wrk     : 1;
2528*437bfbebSnyanmisaka         RK_U32 rme_wrk     : 1;
2529*437bfbebSnyanmisaka         RK_U32 fme_wrk     : 1;
2530*437bfbebSnyanmisaka         RK_U32 rdo_wrk     : 1;
2531*437bfbebSnyanmisaka         RK_U32 lpf_wrk     : 1;
2532*437bfbebSnyanmisaka         RK_U32 etpy_wrk    : 1;
2533*437bfbebSnyanmisaka         RK_U32 frm_wrk     : 1;
2534*437bfbebSnyanmisaka         RK_U32 reserved    : 23;
2535*437bfbebSnyanmisaka     } st_ppl;
2536*437bfbebSnyanmisaka 
2537*437bfbebSnyanmisaka     /* 0x00005008 reg5122 */
2538*437bfbebSnyanmisaka     struct {
2539*437bfbebSnyanmisaka         RK_U32 pp_pos_x    : 16;
2540*437bfbebSnyanmisaka         RK_U32 pp_pos_y    : 16;
2541*437bfbebSnyanmisaka     } st_ppl_pos_pp;
2542*437bfbebSnyanmisaka 
2543*437bfbebSnyanmisaka     /* 0x0000500c reg5123 */
2544*437bfbebSnyanmisaka     struct {
2545*437bfbebSnyanmisaka         RK_U32 cme_pos_x    : 16;
2546*437bfbebSnyanmisaka         RK_U32 cme_pos_y    : 16;
2547*437bfbebSnyanmisaka     } st_ppl_pos_cme;
2548*437bfbebSnyanmisaka 
2549*437bfbebSnyanmisaka     /* 0x00005010 reg5124 */
2550*437bfbebSnyanmisaka     struct {
2551*437bfbebSnyanmisaka         RK_U32 swin_pos_x    : 16;
2552*437bfbebSnyanmisaka         RK_U32 swin_pos_y    : 16;
2553*437bfbebSnyanmisaka     } st_ppl_pos_swin;
2554*437bfbebSnyanmisaka 
2555*437bfbebSnyanmisaka     /* 0x00005014 reg5125 */
2556*437bfbebSnyanmisaka     struct {
2557*437bfbebSnyanmisaka         RK_U32 rme_pos_x    : 16;
2558*437bfbebSnyanmisaka         RK_U32 rme_pos_y    : 16;
2559*437bfbebSnyanmisaka     } st_ppl_pos_rme;
2560*437bfbebSnyanmisaka 
2561*437bfbebSnyanmisaka     /* 0x00005018 reg5126 */
2562*437bfbebSnyanmisaka     struct {
2563*437bfbebSnyanmisaka         RK_U32 fme_pos_x    : 16;
2564*437bfbebSnyanmisaka         RK_U32 fme_pos_y    : 16;
2565*437bfbebSnyanmisaka     } st_ppl_pos_fme;
2566*437bfbebSnyanmisaka 
2567*437bfbebSnyanmisaka     /* 0x0000501c reg5127 */
2568*437bfbebSnyanmisaka     struct {
2569*437bfbebSnyanmisaka         RK_U32 rdo_pos_x    : 16;
2570*437bfbebSnyanmisaka         RK_U32 rdo_pos_y    : 16;
2571*437bfbebSnyanmisaka     } st_ppl_pos_rdo;
2572*437bfbebSnyanmisaka 
2573*437bfbebSnyanmisaka     /* 0x00005020 reg5128 */
2574*437bfbebSnyanmisaka     struct {
2575*437bfbebSnyanmisaka         RK_U32 lpf_pos_x    : 16;
2576*437bfbebSnyanmisaka         RK_U32 lpf_pos_y    : 16;
2577*437bfbebSnyanmisaka     } st_ppl_pos_lpf;
2578*437bfbebSnyanmisaka 
2579*437bfbebSnyanmisaka     /* 0x00005024 reg5129 */
2580*437bfbebSnyanmisaka     struct {
2581*437bfbebSnyanmisaka         RK_U32 etpy_pos_x    : 16;
2582*437bfbebSnyanmisaka         RK_U32 etpy_pos_y    : 16;
2583*437bfbebSnyanmisaka     } st_ppl_pos_etpy;
2584*437bfbebSnyanmisaka 
2585*437bfbebSnyanmisaka     /* 0x00005028 reg5130 */
2586*437bfbebSnyanmisaka     struct {
2587*437bfbebSnyanmisaka         RK_U32 sli_num     : 15;
2588*437bfbebSnyanmisaka         RK_U32 reserved    : 17;
2589*437bfbebSnyanmisaka     } st_sli_num;
2590*437bfbebSnyanmisaka 
2591*437bfbebSnyanmisaka     /* 0x0000502c reg5131 */
2592*437bfbebSnyanmisaka     struct {
2593*437bfbebSnyanmisaka         RK_U32 lkt_err     : 3;
2594*437bfbebSnyanmisaka         RK_U32 reserved    : 29;
2595*437bfbebSnyanmisaka     } st_lkt_err;
2596*437bfbebSnyanmisaka 
2597*437bfbebSnyanmisaka     /* 0x5030 - 0x50fc */
2598*437bfbebSnyanmisaka     RK_U32 reserved5132_5183[52];
2599*437bfbebSnyanmisaka 
2600*437bfbebSnyanmisaka     /* 0x00005100 reg5184 */
2601*437bfbebSnyanmisaka     struct {
2602*437bfbebSnyanmisaka         RK_U32 empty_oafifo        : 1;
2603*437bfbebSnyanmisaka         RK_U32 full_cmd_oafifo     : 1;
2604*437bfbebSnyanmisaka         RK_U32 full_data_oafifo    : 1;
2605*437bfbebSnyanmisaka         RK_U32 empty_iafifo        : 1;
2606*437bfbebSnyanmisaka         RK_U32 full_cmd_iafifo     : 1;
2607*437bfbebSnyanmisaka         RK_U32 full_info_iafifo    : 1;
2608*437bfbebSnyanmisaka         RK_U32 fbd_brq_st          : 4;
2609*437bfbebSnyanmisaka         RK_U32 fbd_hdr_vld         : 1;
2610*437bfbebSnyanmisaka         RK_U32 fbd_bmng_end        : 1;
2611*437bfbebSnyanmisaka         RK_U32 nfbd_req_st         : 4;
2612*437bfbebSnyanmisaka         RK_U32 acc_axi_cmd         : 8;
2613*437bfbebSnyanmisaka         RK_U32 reserved            : 8;
2614*437bfbebSnyanmisaka     } dbg_pp_st;
2615*437bfbebSnyanmisaka 
2616*437bfbebSnyanmisaka     /* 0x00005104 reg5185 */
2617*437bfbebSnyanmisaka     struct {
2618*437bfbebSnyanmisaka         RK_U32 cur_state_cime    : 2;
2619*437bfbebSnyanmisaka         RK_U32 cur_state_ds      : 3;
2620*437bfbebSnyanmisaka         RK_U32 cur_state_ref     : 2;
2621*437bfbebSnyanmisaka         RK_U32 cur_state_cst     : 2;
2622*437bfbebSnyanmisaka         RK_U32 reserved          : 23;
2623*437bfbebSnyanmisaka     } dbg_cime_st;
2624*437bfbebSnyanmisaka 
2625*437bfbebSnyanmisaka     /* 0x00005108 reg5186 */
2626*437bfbebSnyanmisaka     RK_U32 swin_dbg_inf;
2627*437bfbebSnyanmisaka 
2628*437bfbebSnyanmisaka     /* 0x0000510c reg5187 */
2629*437bfbebSnyanmisaka     struct {
2630*437bfbebSnyanmisaka         RK_U32 bbrq_cmps_left_len2    : 1;
2631*437bfbebSnyanmisaka         RK_U32 bbrq_cmps_left_len1    : 1;
2632*437bfbebSnyanmisaka         RK_U32 cmps_left_len0         : 1;
2633*437bfbebSnyanmisaka         RK_U32 bbrq_rdy2              : 1;
2634*437bfbebSnyanmisaka         RK_U32 dcps_vld2              : 1;
2635*437bfbebSnyanmisaka         RK_U32 bbrq_rdy1              : 1;
2636*437bfbebSnyanmisaka         RK_U32 dcps_vld1              : 1;
2637*437bfbebSnyanmisaka         RK_U32 bbrq_rdy0              : 1;
2638*437bfbebSnyanmisaka         RK_U32 dcps_vld0              : 1;
2639*437bfbebSnyanmisaka         RK_U32 hb_rdy2                : 1;
2640*437bfbebSnyanmisaka         RK_U32 bbrq_vld2              : 1;
2641*437bfbebSnyanmisaka         RK_U32 hb_rdy1                : 1;
2642*437bfbebSnyanmisaka         RK_U32 bbrq_vld1              : 1;
2643*437bfbebSnyanmisaka         RK_U32 hb_rdy0                : 1;
2644*437bfbebSnyanmisaka         RK_U32 bbrq_vld0              : 1;
2645*437bfbebSnyanmisaka         RK_U32 idle_msb2              : 1;
2646*437bfbebSnyanmisaka         RK_U32 idle_msb1              : 1;
2647*437bfbebSnyanmisaka         RK_U32 idle_msb0              : 1;
2648*437bfbebSnyanmisaka         RK_U32 cur_state_dcps         : 1;
2649*437bfbebSnyanmisaka         RK_U32 cur_state_bbrq         : 1;
2650*437bfbebSnyanmisaka         RK_U32 cur_state_hb           : 1;
2651*437bfbebSnyanmisaka         RK_U32 cke_bbrq_dcps          : 1;
2652*437bfbebSnyanmisaka         RK_U32 cke_dcps               : 1;
2653*437bfbebSnyanmisaka         RK_U32 cke_bbrq               : 1;
2654*437bfbebSnyanmisaka         RK_U32 rdy_lwcd_rsp           : 1;
2655*437bfbebSnyanmisaka         RK_U32 vld_lwcd_rsp           : 1;
2656*437bfbebSnyanmisaka         RK_U32 rdy_lwcd_req           : 1;
2657*437bfbebSnyanmisaka         RK_U32 vld_lwcd_req           : 1;
2658*437bfbebSnyanmisaka         RK_U32 rdy_lwrsp              : 1;
2659*437bfbebSnyanmisaka         RK_U32 vld_lwrsp              : 1;
2660*437bfbebSnyanmisaka         RK_U32 rdy_lwreq              : 1;
2661*437bfbebSnyanmisaka         RK_U32 vld_lwreq              : 1;
2662*437bfbebSnyanmisaka     } dbg_fbd_hhit0;
2663*437bfbebSnyanmisaka 
2664*437bfbebSnyanmisaka     /* 0x5110 */
2665*437bfbebSnyanmisaka     RK_U32 reserved_5188;
2666*437bfbebSnyanmisaka 
2667*437bfbebSnyanmisaka     /* 0x00005114 reg5189 */
2668*437bfbebSnyanmisaka     struct {
2669*437bfbebSnyanmisaka         RK_U32 mscnt_clr    : 1;
2670*437bfbebSnyanmisaka         RK_U32 reserved     : 31;
2671*437bfbebSnyanmisaka     } dbg_cach_clr;
2672*437bfbebSnyanmisaka 
2673*437bfbebSnyanmisaka     /* 0x00005118 reg5190 */
2674*437bfbebSnyanmisaka     RK_U32 l1_mis;
2675*437bfbebSnyanmisaka 
2676*437bfbebSnyanmisaka     /* 0x0000511c reg5191 */
2677*437bfbebSnyanmisaka     RK_U32 l2_mis;
2678*437bfbebSnyanmisaka 
2679*437bfbebSnyanmisaka     /* 0x00005120 reg5192 */
2680*437bfbebSnyanmisaka     RK_U32 rdo_st;
2681*437bfbebSnyanmisaka 
2682*437bfbebSnyanmisaka     /* 0x00005124 reg5193 */
2683*437bfbebSnyanmisaka     RK_U32 rdo_if;
2684*437bfbebSnyanmisaka 
2685*437bfbebSnyanmisaka     /* 0x00005128 reg5194 */
2686*437bfbebSnyanmisaka     struct {
2687*437bfbebSnyanmisaka         RK_U32 sh_st_cs    : 4;
2688*437bfbebSnyanmisaka         RK_U32 rsd_st_cs        : 4;
2689*437bfbebSnyanmisaka         RK_U32 sd_st_cs    : 5;
2690*437bfbebSnyanmisaka         RK_U32 etpy_rdy         : 1;
2691*437bfbebSnyanmisaka         RK_U32 reserved         : 18;
2692*437bfbebSnyanmisaka     } dbg_etpy;
2693*437bfbebSnyanmisaka 
2694*437bfbebSnyanmisaka     /* 0x0000512c reg5195 */
2695*437bfbebSnyanmisaka     struct {
2696*437bfbebSnyanmisaka         RK_U32 crdy_ppr    : 1;
2697*437bfbebSnyanmisaka         RK_U32 cvld_ppr    : 1;
2698*437bfbebSnyanmisaka         RK_U32 drdy_ppw    : 1;
2699*437bfbebSnyanmisaka         RK_U32 dvld_ppw    : 1;
2700*437bfbebSnyanmisaka         RK_U32 crdy_ppw    : 1;
2701*437bfbebSnyanmisaka         RK_U32 cvld_ppw    : 1;
2702*437bfbebSnyanmisaka         RK_U32 reserved    : 26;
2703*437bfbebSnyanmisaka     } dbg_dma_pp;
2704*437bfbebSnyanmisaka 
2705*437bfbebSnyanmisaka     /* 0x00005130 reg5196 */
2706*437bfbebSnyanmisaka     struct {
2707*437bfbebSnyanmisaka         RK_U32 axi_wrdy     : 8;
2708*437bfbebSnyanmisaka         RK_U32 axi_wvld     : 8;
2709*437bfbebSnyanmisaka         RK_U32 axi_awrdy    : 8;
2710*437bfbebSnyanmisaka         RK_U32 axi_awvld    : 8;
2711*437bfbebSnyanmisaka     } dbg_dma_w;
2712*437bfbebSnyanmisaka 
2713*437bfbebSnyanmisaka     /* 0x00005134 reg5197 */
2714*437bfbebSnyanmisaka     struct {
2715*437bfbebSnyanmisaka         RK_U32 axi_otsd_read    : 16;
2716*437bfbebSnyanmisaka         RK_U32 axi_arrdy        : 7;
2717*437bfbebSnyanmisaka         RK_U32 reserved         : 1;
2718*437bfbebSnyanmisaka         RK_U32 axi_arvld        : 7;
2719*437bfbebSnyanmisaka         RK_U32 reserved1        : 1;
2720*437bfbebSnyanmisaka     } dbg_dma_r;
2721*437bfbebSnyanmisaka 
2722*437bfbebSnyanmisaka     /* 0x00005138 reg5198 */
2723*437bfbebSnyanmisaka     struct {
2724*437bfbebSnyanmisaka         RK_U32 dfifo0_lvl    : 4;
2725*437bfbebSnyanmisaka         RK_U32 dfifo1_lvl    : 4;
2726*437bfbebSnyanmisaka         RK_U32 dfifo2_lvl    : 4;
2727*437bfbebSnyanmisaka         RK_U32 dfifo3_lvl    : 4;
2728*437bfbebSnyanmisaka         RK_U32 dfifo4_lvl    : 4;
2729*437bfbebSnyanmisaka         RK_U32 dfifo5_lvl    : 4;
2730*437bfbebSnyanmisaka         RK_U32 reserved      : 6;
2731*437bfbebSnyanmisaka         RK_U32 cmd_vld       : 1;
2732*437bfbebSnyanmisaka         RK_U32 reserved1     : 1;
2733*437bfbebSnyanmisaka     } dbg_dma_rfpr;
2734*437bfbebSnyanmisaka 
2735*437bfbebSnyanmisaka     /* 0x0000513c reg5199 */
2736*437bfbebSnyanmisaka     struct {
2737*437bfbebSnyanmisaka         RK_U32 meiw_busy    : 1;
2738*437bfbebSnyanmisaka         RK_U32 dspw_busy    : 1;
2739*437bfbebSnyanmisaka         RK_U32 bsw_rdy      : 1;
2740*437bfbebSnyanmisaka         RK_U32 bsw_flsh     : 1;
2741*437bfbebSnyanmisaka         RK_U32 bsw_busy     : 1;
2742*437bfbebSnyanmisaka         RK_U32 crpw_busy    : 1;
2743*437bfbebSnyanmisaka         RK_U32 lktw_busy    : 1;
2744*437bfbebSnyanmisaka         RK_U32 lpfw_busy    : 1;
2745*437bfbebSnyanmisaka         RK_U32 roir_busy    : 1;
2746*437bfbebSnyanmisaka         RK_U32 dspr_crdy    : 1;
2747*437bfbebSnyanmisaka         RK_U32 dspr_cvld    : 1;
2748*437bfbebSnyanmisaka         RK_U32 lktr_busy    : 1;
2749*437bfbebSnyanmisaka         RK_U32 lpfr_otsd    : 4;
2750*437bfbebSnyanmisaka         RK_U32 rfpr_otsd    : 12;
2751*437bfbebSnyanmisaka         RK_U32 dspr_otsd    : 4;
2752*437bfbebSnyanmisaka     } dbg_dma_ch_st;
2753*437bfbebSnyanmisaka 
2754*437bfbebSnyanmisaka     /* 0x00005140 reg5200 */
2755*437bfbebSnyanmisaka     struct {
2756*437bfbebSnyanmisaka         RK_U32 cpip_st     : 2;
2757*437bfbebSnyanmisaka         RK_U32 mvp_st      : 3;
2758*437bfbebSnyanmisaka         RK_U32 qpd6_st     : 2;
2759*437bfbebSnyanmisaka         RK_U32 cmd_st      : 2;
2760*437bfbebSnyanmisaka         RK_U32 reserved    : 23;
2761*437bfbebSnyanmisaka     } dbg_tctrl_cime_st;
2762*437bfbebSnyanmisaka 
2763*437bfbebSnyanmisaka     /* 0x00005144 reg5201 */
2764*437bfbebSnyanmisaka     struct {
2765*437bfbebSnyanmisaka         RK_U32 cme_byps      : 1;
2766*437bfbebSnyanmisaka         RK_U32 swin_byps     : 1;
2767*437bfbebSnyanmisaka         RK_U32 rme_byps      : 1;
2768*437bfbebSnyanmisaka         RK_U32 intra_byps    : 1;
2769*437bfbebSnyanmisaka         RK_U32 fme_byps      : 1;
2770*437bfbebSnyanmisaka         RK_U32 rdo_byps      : 1;
2771*437bfbebSnyanmisaka         RK_U32 lpf_byps      : 1;
2772*437bfbebSnyanmisaka         RK_U32 etpy_byps     : 1;
2773*437bfbebSnyanmisaka         RK_U32 reserved      : 24;
2774*437bfbebSnyanmisaka     } dbg_tctrl;
2775*437bfbebSnyanmisaka 
2776*437bfbebSnyanmisaka     /* 0x5148 */
2777*437bfbebSnyanmisaka     RK_U32 reserved_5202;
2778*437bfbebSnyanmisaka 
2779*437bfbebSnyanmisaka     /* 0x0000514c reg5203 */
2780*437bfbebSnyanmisaka     RK_U32 dbg_lpf_st;
2781*437bfbebSnyanmisaka 
2782*437bfbebSnyanmisaka     /* 0x00005150 reg5204 */
2783*437bfbebSnyanmisaka     RK_U32 dbg_topc_lpfr;
2784*437bfbebSnyanmisaka 
2785*437bfbebSnyanmisaka     /* 0x00005154 reg5205 */
2786*437bfbebSnyanmisaka     RK_U32 dbg0_cache;
2787*437bfbebSnyanmisaka 
2788*437bfbebSnyanmisaka     /* 0x00005158 reg5206 */
2789*437bfbebSnyanmisaka     RK_U32 dbg1_cache;
2790*437bfbebSnyanmisaka 
2791*437bfbebSnyanmisaka     /* 0x0000515c reg5207 */
2792*437bfbebSnyanmisaka     RK_U32 dbg2_cache;
2793*437bfbebSnyanmisaka 
2794*437bfbebSnyanmisaka     /* 0x5160 - 0x51fc */
2795*437bfbebSnyanmisaka     RK_U32 reserved5208_5247[40];
2796*437bfbebSnyanmisaka 
2797*437bfbebSnyanmisaka     /* 0x00005200 reg5248 */
2798*437bfbebSnyanmisaka     RK_U32 frame_cyc;
2799*437bfbebSnyanmisaka 
2800*437bfbebSnyanmisaka     /* 0x00005204 reg5249 */
2801*437bfbebSnyanmisaka     RK_U32 pp_fcyc;
2802*437bfbebSnyanmisaka 
2803*437bfbebSnyanmisaka     /* 0x00005208 reg5250 */
2804*437bfbebSnyanmisaka     RK_U32 cme_fcyc;
2805*437bfbebSnyanmisaka 
2806*437bfbebSnyanmisaka     /* 0x0000520c reg5251 */
2807*437bfbebSnyanmisaka     RK_U32 cme_dspr_fcyc;
2808*437bfbebSnyanmisaka 
2809*437bfbebSnyanmisaka     /* 0x00005210 reg5252 */
2810*437bfbebSnyanmisaka     RK_U32 ldr_fcyc;
2811*437bfbebSnyanmisaka 
2812*437bfbebSnyanmisaka     /* 0x00005214 reg5253 */
2813*437bfbebSnyanmisaka     RK_U32 rme_fcyc;
2814*437bfbebSnyanmisaka 
2815*437bfbebSnyanmisaka     /* 0x00005218 reg5254 */
2816*437bfbebSnyanmisaka     RK_U32 fme_fcyc;
2817*437bfbebSnyanmisaka 
2818*437bfbebSnyanmisaka     /* 0x0000521c reg5255 */
2819*437bfbebSnyanmisaka     RK_U32 rdo_fcyc;
2820*437bfbebSnyanmisaka 
2821*437bfbebSnyanmisaka     /* 0x00005220 reg5256 */
2822*437bfbebSnyanmisaka     RK_U32 lpf_fcyc;
2823*437bfbebSnyanmisaka 
2824*437bfbebSnyanmisaka     /* 0x00005224 reg5257 */
2825*437bfbebSnyanmisaka     RK_U32 etpy_fcyc;
2826*437bfbebSnyanmisaka 
2827*437bfbebSnyanmisaka     /* 0x5228 - 0x52fc */
2828*437bfbebSnyanmisaka     RK_U32 reserved5258_5311[54];
2829*437bfbebSnyanmisaka 
2830*437bfbebSnyanmisaka     /* 0x00005300 reg5312 */
2831*437bfbebSnyanmisaka     struct {
2832*437bfbebSnyanmisaka         RK_U32 axip_e      : 1;
2833*437bfbebSnyanmisaka         RK_U32 axip_clr    : 1;
2834*437bfbebSnyanmisaka         RK_U32 axip_mod    : 1;
2835*437bfbebSnyanmisaka         RK_U32 reserved    : 29;
2836*437bfbebSnyanmisaka     } axip0_cmd;
2837*437bfbebSnyanmisaka 
2838*437bfbebSnyanmisaka     /* 0x00005304 reg5313 */
2839*437bfbebSnyanmisaka     struct {
2840*437bfbebSnyanmisaka         RK_U32 axip_ltcy_id     : 4;
2841*437bfbebSnyanmisaka         RK_U32 axip_ltcy_thd    : 12;
2842*437bfbebSnyanmisaka         RK_U32 reserved         : 16;
2843*437bfbebSnyanmisaka     } axip0_ltcy;
2844*437bfbebSnyanmisaka 
2845*437bfbebSnyanmisaka     /* 0x00005308 reg5314 */
2846*437bfbebSnyanmisaka     struct {
2847*437bfbebSnyanmisaka         RK_U32 axip_cnt_typ    : 1;
2848*437bfbebSnyanmisaka         RK_U32 axip_cnt_ddr    : 2;
2849*437bfbebSnyanmisaka         RK_U32 axip_cnt_rid    : 5;
2850*437bfbebSnyanmisaka         RK_U32 axip_cnt_wid    : 5;
2851*437bfbebSnyanmisaka         RK_U32 reserved        : 19;
2852*437bfbebSnyanmisaka     } axip0_cnt;
2853*437bfbebSnyanmisaka 
2854*437bfbebSnyanmisaka     /* 0x530c */
2855*437bfbebSnyanmisaka     RK_U32 reserved_5315;
2856*437bfbebSnyanmisaka 
2857*437bfbebSnyanmisaka     /* 0x00005310 reg5316 */
2858*437bfbebSnyanmisaka     struct {
2859*437bfbebSnyanmisaka         RK_U32 axip_e      : 1;
2860*437bfbebSnyanmisaka         RK_U32 axip_clr    : 1;
2861*437bfbebSnyanmisaka         RK_U32 axip_mod    : 1;
2862*437bfbebSnyanmisaka         RK_U32 reserved    : 29;
2863*437bfbebSnyanmisaka     } axip1_cmd;
2864*437bfbebSnyanmisaka 
2865*437bfbebSnyanmisaka     /* 0x00005314 reg5317 */
2866*437bfbebSnyanmisaka     struct {
2867*437bfbebSnyanmisaka         RK_U32 axip_ltcy_id     : 4;
2868*437bfbebSnyanmisaka         RK_U32 axip_ltcy_thd    : 12;
2869*437bfbebSnyanmisaka         RK_U32 reserved         : 16;
2870*437bfbebSnyanmisaka     } axip1_ltcy;
2871*437bfbebSnyanmisaka 
2872*437bfbebSnyanmisaka     /* 0x00005318 reg5318 */
2873*437bfbebSnyanmisaka     struct {
2874*437bfbebSnyanmisaka         RK_U32 axip_cnt_typ    : 1;
2875*437bfbebSnyanmisaka         RK_U32 axip_cnt_ddr    : 2;
2876*437bfbebSnyanmisaka         RK_U32 axip_cnt_rid    : 5;
2877*437bfbebSnyanmisaka         RK_U32 axip_cnt_wid    : 5;
2878*437bfbebSnyanmisaka         RK_U32 reserved        : 19;
2879*437bfbebSnyanmisaka     } axip1_cnt;
2880*437bfbebSnyanmisaka 
2881*437bfbebSnyanmisaka     /* 0x531c */
2882*437bfbebSnyanmisaka     RK_U32 reserved_5319;
2883*437bfbebSnyanmisaka 
2884*437bfbebSnyanmisaka     /* 0x00005320 reg5320 */
2885*437bfbebSnyanmisaka     struct {
2886*437bfbebSnyanmisaka         RK_U32 axip_max_ltcy    : 16;
2887*437bfbebSnyanmisaka         RK_U32 reserved         : 16;
2888*437bfbebSnyanmisaka     } st_axip0_maxl;
2889*437bfbebSnyanmisaka 
2890*437bfbebSnyanmisaka     /* 0x00005324 reg5321 */
2891*437bfbebSnyanmisaka     RK_U32 axip0_num_ltcy;
2892*437bfbebSnyanmisaka 
2893*437bfbebSnyanmisaka     /* 0x00005328 reg5322 */
2894*437bfbebSnyanmisaka     RK_U32 axip0_sum_ltcy;
2895*437bfbebSnyanmisaka 
2896*437bfbebSnyanmisaka     /* 0x0000532c reg5323 */
2897*437bfbebSnyanmisaka     RK_U32 axip0_rbyt;
2898*437bfbebSnyanmisaka 
2899*437bfbebSnyanmisaka     /* 0x00005330 reg5324 */
2900*437bfbebSnyanmisaka     RK_U32 axip0_wbyt;
2901*437bfbebSnyanmisaka 
2902*437bfbebSnyanmisaka     /* 0x00005334 reg5325 */
2903*437bfbebSnyanmisaka     RK_U32 axip0_wrk_cyc;
2904*437bfbebSnyanmisaka 
2905*437bfbebSnyanmisaka     /* 0x5338 - 0x533c */
2906*437bfbebSnyanmisaka     RK_U32 reserved5326_5327[2];
2907*437bfbebSnyanmisaka 
2908*437bfbebSnyanmisaka     /* 0x00005340 reg5328 */
2909*437bfbebSnyanmisaka     struct {
2910*437bfbebSnyanmisaka         RK_U32 axip_max_ltcy    : 16;
2911*437bfbebSnyanmisaka         RK_U32 reserved         : 16;
2912*437bfbebSnyanmisaka     } st_axip1_maxl;
2913*437bfbebSnyanmisaka 
2914*437bfbebSnyanmisaka     /* 0x00005344 reg5329 */
2915*437bfbebSnyanmisaka     RK_U32 axip1_num_ltcy;
2916*437bfbebSnyanmisaka 
2917*437bfbebSnyanmisaka     /* 0x00005348 reg5330 */
2918*437bfbebSnyanmisaka     RK_U32 axip1_sum_ltcy;
2919*437bfbebSnyanmisaka 
2920*437bfbebSnyanmisaka     /* 0x0000534c reg5331 */
2921*437bfbebSnyanmisaka     RK_U32 axip1_rbyt;
2922*437bfbebSnyanmisaka 
2923*437bfbebSnyanmisaka     /* 0x00005350 reg5332 */
2924*437bfbebSnyanmisaka     RK_U32 axip1_wbyt;
2925*437bfbebSnyanmisaka 
2926*437bfbebSnyanmisaka     /* 0x00005354 reg5333 */
2927*437bfbebSnyanmisaka     RK_U32 axip1_wrk_cyc;
2928*437bfbebSnyanmisaka } Vepu580Dbg;
2929*437bfbebSnyanmisaka 
2930*437bfbebSnyanmisaka /* class: mmu */
2931*437bfbebSnyanmisaka /* 0x0000f000 reg15360 - 0x0000f064 reg15385 */
2932*437bfbebSnyanmisaka 
2933*437bfbebSnyanmisaka typedef struct HalVepu580Reg_t {
2934*437bfbebSnyanmisaka     Vepu580ControlCfg   reg_ctl;
2935*437bfbebSnyanmisaka     Vepu580BaseCfg      reg_base;
2936*437bfbebSnyanmisaka     Vepu580RcKlutCfg    reg_rc_klut;
2937*437bfbebSnyanmisaka     Vepu580Section3     reg_s3;
2938*437bfbebSnyanmisaka     Vepu580RdoCfg       reg_rdo;
2939*437bfbebSnyanmisaka     Vepu580SclCfg       reg_scl;
2940*437bfbebSnyanmisaka     Vepu580Osd          reg_osd;
2941*437bfbebSnyanmisaka     Vepu580Status       reg_st;
2942*437bfbebSnyanmisaka     Vepu580Dbg          reg_dbg;
2943*437bfbebSnyanmisaka } HalVepu580RegSet;
2944*437bfbebSnyanmisaka 
2945*437bfbebSnyanmisaka #endif
2946