xref: /OK3568_Linux_fs/kernel/include/uapi/linux/rk-isp3-config.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: (GPL-2.0+ WITH Linux-syscall-note) OR MIT
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * Rockchip ISP3
4*4882a593Smuzhiyun  * Copyright (C) 2021 Rockchip Electronics Co., Ltd.
5*4882a593Smuzhiyun  */
6*4882a593Smuzhiyun 
7*4882a593Smuzhiyun #ifndef _UAPI_RK_ISP3_CONFIG_H
8*4882a593Smuzhiyun #define _UAPI_RK_ISP3_CONFIG_H
9*4882a593Smuzhiyun 
10*4882a593Smuzhiyun #include <linux/types.h>
11*4882a593Smuzhiyun #include <linux/v4l2-controls.h>
12*4882a593Smuzhiyun #include <linux/rk-isp21-config.h>
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun #define ISP3X_MODULE_DPCC		ISP2X_MODULE_DPCC
15*4882a593Smuzhiyun #define ISP3X_MODULE_BLS		ISP2X_MODULE_BLS
16*4882a593Smuzhiyun #define ISP3X_MODULE_SDG		ISP2X_MODULE_SDG
17*4882a593Smuzhiyun #define ISP3X_MODULE_LSC		ISP2X_MODULE_LSC
18*4882a593Smuzhiyun #define ISP3X_MODULE_AWB_GAIN		ISP2X_MODULE_AWB_GAIN
19*4882a593Smuzhiyun #define ISP3X_MODULE_BDM		ISP2X_MODULE_BDM
20*4882a593Smuzhiyun #define ISP3X_MODULE_CCM		ISP2X_MODULE_CCM
21*4882a593Smuzhiyun #define ISP3X_MODULE_GOC		ISP2X_MODULE_GOC
22*4882a593Smuzhiyun #define ISP3X_MODULE_CPROC		ISP2X_MODULE_CPROC
23*4882a593Smuzhiyun #define ISP3X_MODULE_IE			ISP2X_MODULE_IE
24*4882a593Smuzhiyun #define ISP3X_MODULE_RAWAF		ISP2X_MODULE_RAWAF
25*4882a593Smuzhiyun #define ISP3X_MODULE_RAWAE0		ISP2X_MODULE_RAWAE0
26*4882a593Smuzhiyun #define ISP3X_MODULE_RAWAE1		ISP2X_MODULE_RAWAE1
27*4882a593Smuzhiyun #define ISP3X_MODULE_RAWAE2		ISP2X_MODULE_RAWAE2
28*4882a593Smuzhiyun #define ISP3X_MODULE_RAWAE3		ISP2X_MODULE_RAWAE3
29*4882a593Smuzhiyun #define ISP3X_MODULE_RAWAWB		ISP2X_MODULE_RAWAWB
30*4882a593Smuzhiyun #define ISP3X_MODULE_RAWHIST0		ISP2X_MODULE_RAWHIST0
31*4882a593Smuzhiyun #define ISP3X_MODULE_RAWHIST1		ISP2X_MODULE_RAWHIST1
32*4882a593Smuzhiyun #define ISP3X_MODULE_RAWHIST2		ISP2X_MODULE_RAWHIST2
33*4882a593Smuzhiyun #define ISP3X_MODULE_RAWHIST3		ISP2X_MODULE_RAWHIST3
34*4882a593Smuzhiyun #define ISP3X_MODULE_HDRMGE		ISP2X_MODULE_HDRMGE
35*4882a593Smuzhiyun #define ISP3X_MODULE_RAWNR		ISP2X_MODULE_RAWNR
36*4882a593Smuzhiyun #define ISP3X_MODULE_GIC		ISP2X_MODULE_GIC
37*4882a593Smuzhiyun #define ISP3X_MODULE_DHAZ		ISP2X_MODULE_DHAZ
38*4882a593Smuzhiyun #define ISP3X_MODULE_3DLUT		ISP2X_MODULE_3DLUT
39*4882a593Smuzhiyun #define ISP3X_MODULE_LDCH		ISP2X_MODULE_LDCH
40*4882a593Smuzhiyun #define ISP3X_MODULE_GAIN		ISP2X_MODULE_GAIN
41*4882a593Smuzhiyun #define ISP3X_MODULE_DEBAYER		ISP2X_MODULE_DEBAYER
42*4882a593Smuzhiyun #define ISP3X_MODULE_BAYNR		ISP2X_MODULE_BAYNR
43*4882a593Smuzhiyun #define ISP3X_MODULE_BAY3D		ISP2X_MODULE_BAY3D
44*4882a593Smuzhiyun #define ISP3X_MODULE_YNR		ISP2X_MODULE_YNR
45*4882a593Smuzhiyun #define ISP3X_MODULE_CNR		ISP2X_MODULE_CNR
46*4882a593Smuzhiyun #define ISP3X_MODULE_SHARP		ISP2X_MODULE_SHARP
47*4882a593Smuzhiyun #define ISP3X_MODULE_DRC		ISP2X_MODULE_DRC
48*4882a593Smuzhiyun #define ISP3X_MODULE_CAC		BIT_ULL(42)
49*4882a593Smuzhiyun #define ISP3X_MODULE_CSM		ISP2X_MODULE_CSM
50*4882a593Smuzhiyun #define ISP3X_MODULE_CGC		ISP2X_MODULE_CGC
51*4882a593Smuzhiyun 
52*4882a593Smuzhiyun #define ISP3X_MODULE_FORCE		ISP2X_MODULE_FORCE
53*4882a593Smuzhiyun 
54*4882a593Smuzhiyun /* Measurement types */
55*4882a593Smuzhiyun #define ISP3X_STAT_RAWAWB		ISP2X_STAT_RAWAWB
56*4882a593Smuzhiyun #define ISP3X_STAT_RAWAF		ISP2X_STAT_RAWAF
57*4882a593Smuzhiyun #define ISP3X_STAT_RAWAE0		ISP2X_STAT_RAWAE0
58*4882a593Smuzhiyun #define ISP3X_STAT_RAWAE1		ISP2X_STAT_RAWAE1
59*4882a593Smuzhiyun #define ISP3X_STAT_RAWAE2		ISP2X_STAT_RAWAE2
60*4882a593Smuzhiyun #define ISP3X_STAT_RAWAE3		ISP2X_STAT_RAWAE3
61*4882a593Smuzhiyun #define ISP3X_STAT_RAWHST0		ISP2X_STAT_RAWHST0
62*4882a593Smuzhiyun #define ISP3X_STAT_RAWHST1		ISP2X_STAT_RAWHST1
63*4882a593Smuzhiyun #define ISP3X_STAT_RAWHST2		ISP2X_STAT_RAWHST2
64*4882a593Smuzhiyun #define ISP3X_STAT_RAWHST3		ISP2X_STAT_RAWHST3
65*4882a593Smuzhiyun #define ISP3X_STAT_BLS			ISP2X_STAT_BLS
66*4882a593Smuzhiyun #define ISP3X_STAT_DHAZ			ISP2X_STAT_DHAZ
67*4882a593Smuzhiyun 
68*4882a593Smuzhiyun #define ISP3X_MESH_BUF_NUM		ISP2X_MESH_BUF_NUM
69*4882a593Smuzhiyun 
70*4882a593Smuzhiyun #define ISP3X_LSC_GRAD_TBL_SIZE		16
71*4882a593Smuzhiyun #define ISP3X_LSC_SIZE_TBL_SIZE		16
72*4882a593Smuzhiyun #define ISP3X_LSC_DATA_TBL_SIZE		ISP2X_LSC_DATA_TBL_SIZE
73*4882a593Smuzhiyun 
74*4882a593Smuzhiyun #define ISP3X_DEGAMMA_CURVE_SIZE	ISP2X_DEGAMMA_CURVE_SIZE
75*4882a593Smuzhiyun 
76*4882a593Smuzhiyun #define ISP3X_GAIN_IDX_NUM		ISP2X_GAIN_IDX_NUM
77*4882a593Smuzhiyun #define ISP3X_GAIN_LUT_NUM		ISP2X_GAIN_LUT_NUM
78*4882a593Smuzhiyun 
79*4882a593Smuzhiyun #define ISP3X_RAWAWB_MULWD_NUM		4
80*4882a593Smuzhiyun #define ISP3X_RAWAWB_EXCL_STAT_NUM	4
81*4882a593Smuzhiyun #define ISP3X_RAWAWB_HSTBIN_NUM		ISP21_RAWAWB_HSTBIN_NUM
82*4882a593Smuzhiyun #define ISP3X_RAWAWB_WEIGHT_NUM		ISP21_RAWAWB_WEIGHT_NUM
83*4882a593Smuzhiyun #define ISP3X_RAWAWB_SUM_NUM		ISP2X_RAWAWB_SUM_NUM
84*4882a593Smuzhiyun #define ISP3X_RAWAWB_RAMDATA_NUM	ISP2X_RAWAWB_RAMDATA_NUM
85*4882a593Smuzhiyun 
86*4882a593Smuzhiyun #define	ISP3X_RAWAEBIG_SUBWIN_NUM	ISP2X_RAWAEBIG_SUBWIN_NUM
87*4882a593Smuzhiyun #define ISP3X_RAWAEBIG_MEAN_NUM		ISP2X_RAWAEBIG_MEAN_NUM
88*4882a593Smuzhiyun #define ISP3X_RAWAELITE_MEAN_NUM	ISP2X_RAWAELITE_MEAN_NUM
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun #define ISP3X_RAWHISTBIG_SUBWIN_NUM	ISP2X_RAWHISTBIG_SUBWIN_NUM
91*4882a593Smuzhiyun #define ISP3X_RAWHISTLITE_SUBWIN_NUM	ISP2X_RAWHISTLITE_SUBWIN_NUM
92*4882a593Smuzhiyun #define ISP3X_HIST_BIN_N_MAX		ISP2X_HIST_BIN_N_MAX
93*4882a593Smuzhiyun 
94*4882a593Smuzhiyun #define ISP3X_RAWAF_CURVE_NUM		2
95*4882a593Smuzhiyun #define ISP3X_RAWAF_HIIR_COE_NUM	6
96*4882a593Smuzhiyun #define ISP3X_RAWAF_V1IIR_COE_NUM	9
97*4882a593Smuzhiyun #define ISP3X_RAWAF_V2IIR_COE_NUM	3
98*4882a593Smuzhiyun #define ISP3X_RAWAF_VFIR_COE_NUM	3
99*4882a593Smuzhiyun #define ISP3X_RAWAF_WIN_NUM		ISP2X_RAWAF_WIN_NUM
100*4882a593Smuzhiyun #define ISP3X_RAWAF_LINE_NUM		ISP2X_RAWAF_LINE_NUM
101*4882a593Smuzhiyun #define ISP3X_RAWAF_GAMMA_NUM		ISP2X_RAWAF_GAMMA_NUM
102*4882a593Smuzhiyun #define ISP3X_RAWAF_SUMDATA_NUM		ISP2X_RAWAF_SUMDATA_NUM
103*4882a593Smuzhiyun 
104*4882a593Smuzhiyun #define ISP3X_DPCC_PDAF_POINT_NUM	ISP2X_DPCC_PDAF_POINT_NUM
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun #define ISP3X_HDRMGE_L_CURVE_NUM	ISP2X_HDRMGE_L_CURVE_NUM
107*4882a593Smuzhiyun #define ISP3X_HDRMGE_E_CURVE_NUM	ISP2X_HDRMGE_E_CURVE_NUM
108*4882a593Smuzhiyun 
109*4882a593Smuzhiyun #define ISP3X_GIC_SIGMA_Y_NUM		ISP2X_GIC_SIGMA_Y_NUM
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun #define ISP3X_CCM_CURVE_NUM		ISP2X_CCM_CURVE_NUM
112*4882a593Smuzhiyun 
113*4882a593Smuzhiyun #define ISP3X_3DLUT_DATA_NUM		ISP2X_3DLUT_DATA_NUM
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun #define ISP3X_LDCH_MESH_XY_NUM		ISP2X_LDCH_MESH_XY_NUM
116*4882a593Smuzhiyun 
117*4882a593Smuzhiyun #define ISP3X_GAMMA_OUT_MAX_SAMPLES     49
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun #define ISP3X_DHAZ_SIGMA_IDX_NUM	15
120*4882a593Smuzhiyun #define ISP3X_DHAZ_SIGMA_LUT_NUM	17
121*4882a593Smuzhiyun #define ISP3X_DHAZ_HIST_WR_NUM		64
122*4882a593Smuzhiyun #define ISP3X_DHAZ_ENH_CURVE_NUM	ISP21_DHAZ_ENH_CURVE_NUM
123*4882a593Smuzhiyun #define ISP3X_DHAZ_HIST_IIR_NUM		ISP21_DHAZ_HIST_IIR_NUM
124*4882a593Smuzhiyun 
125*4882a593Smuzhiyun #define ISP3X_DRC_Y_NUM			ISP21_DRC_Y_NUM
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun #define ISP3X_CNR_SIGMA_Y_NUM		13
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun #define ISP3X_YNR_XY_NUM		ISP21_YNR_XY_NUM
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun #define ISP3X_BAYNR_XY_NUM		ISP21_BAYNR_XY_NUM
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun #define ISP3X_BAY3D_XY_NUM		ISP21_BAY3D_XY_NUM
134*4882a593Smuzhiyun 
135*4882a593Smuzhiyun #define ISP3X_SHARP_X_NUM		ISP21_SHARP_X_NUM
136*4882a593Smuzhiyun #define ISP3X_SHARP_Y_NUM		ISP21_SHARP_Y_NUM
137*4882a593Smuzhiyun #define ISP3X_SHARP_GAUS_COEF_NUM	6
138*4882a593Smuzhiyun 
139*4882a593Smuzhiyun #define ISP3X_CAC_STRENGTH_NUM		22
140*4882a593Smuzhiyun 
141*4882a593Smuzhiyun #define ISP3X_CSM_COEFF_NUM		ISP21_CSM_COEFF_NUM
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun enum isp3x_unite_id {
144*4882a593Smuzhiyun 	ISP3_LEFT = 0,
145*4882a593Smuzhiyun 	ISP3_RIGHT,
146*4882a593Smuzhiyun 	ISP3_UNITE_MAX,
147*4882a593Smuzhiyun };
148*4882a593Smuzhiyun 
149*4882a593Smuzhiyun struct isp3x_gammaout_cfg {
150*4882a593Smuzhiyun 	__u8 equ_segm;
151*4882a593Smuzhiyun 	__u8 finalx4_dense_en;
152*4882a593Smuzhiyun 	__u16 offset;
153*4882a593Smuzhiyun 	__u16 gamma_y[ISP3X_GAMMA_OUT_MAX_SAMPLES];
154*4882a593Smuzhiyun } __attribute__ ((packed));
155*4882a593Smuzhiyun 
156*4882a593Smuzhiyun struct isp3x_lsc_cfg {
157*4882a593Smuzhiyun 	__u8 sector_16x16;
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun 	__u16 r_data_tbl[ISP3X_LSC_DATA_TBL_SIZE];
160*4882a593Smuzhiyun 	__u16 gr_data_tbl[ISP3X_LSC_DATA_TBL_SIZE];
161*4882a593Smuzhiyun 	__u16 gb_data_tbl[ISP3X_LSC_DATA_TBL_SIZE];
162*4882a593Smuzhiyun 	__u16 b_data_tbl[ISP3X_LSC_DATA_TBL_SIZE];
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun 	__u16 x_grad_tbl[ISP3X_LSC_GRAD_TBL_SIZE];
165*4882a593Smuzhiyun 	__u16 y_grad_tbl[ISP3X_LSC_GRAD_TBL_SIZE];
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun 	__u16 x_size_tbl[ISP3X_LSC_SIZE_TBL_SIZE];
168*4882a593Smuzhiyun 	__u16 y_size_tbl[ISP3X_LSC_SIZE_TBL_SIZE];
169*4882a593Smuzhiyun } __attribute__ ((packed));
170*4882a593Smuzhiyun 
171*4882a593Smuzhiyun struct isp3x_baynr_cfg {
172*4882a593Smuzhiyun 	__u8 lg2_mode;
173*4882a593Smuzhiyun 	__u8 gauss_en;
174*4882a593Smuzhiyun 	__u8 log_bypass;
175*4882a593Smuzhiyun 
176*4882a593Smuzhiyun 	__u16 dgain1;
177*4882a593Smuzhiyun 	__u16 dgain0;
178*4882a593Smuzhiyun 	__u16 dgain2;
179*4882a593Smuzhiyun 
180*4882a593Smuzhiyun 	__u16 pix_diff;
181*4882a593Smuzhiyun 
182*4882a593Smuzhiyun 	__u16 diff_thld;
183*4882a593Smuzhiyun 	__u16 softthld;
184*4882a593Smuzhiyun 
185*4882a593Smuzhiyun 	__u16 bltflt_streng;
186*4882a593Smuzhiyun 	__u16 reg_w1;
187*4882a593Smuzhiyun 
188*4882a593Smuzhiyun 	__u16 sigma_x[ISP3X_BAYNR_XY_NUM];
189*4882a593Smuzhiyun 	__u16 sigma_y[ISP3X_BAYNR_XY_NUM];
190*4882a593Smuzhiyun 
191*4882a593Smuzhiyun 	__u16 weit_d2;
192*4882a593Smuzhiyun 	__u16 weit_d1;
193*4882a593Smuzhiyun 	__u16 weit_d0;
194*4882a593Smuzhiyun 
195*4882a593Smuzhiyun 	__u16 lg2_lgoff;
196*4882a593Smuzhiyun 	__u16 lg2_off;
197*4882a593Smuzhiyun 
198*4882a593Smuzhiyun 	__u32 dat_max;
199*4882a593Smuzhiyun } __attribute__ ((packed));
200*4882a593Smuzhiyun 
201*4882a593Smuzhiyun struct isp3x_bay3d_cfg {
202*4882a593Smuzhiyun 	__u8 bypass_en;
203*4882a593Smuzhiyun 	__u8 hibypass_en;
204*4882a593Smuzhiyun 	__u8 lobypass_en;
205*4882a593Smuzhiyun 	__u8 himed_bypass_en;
206*4882a593Smuzhiyun 	__u8 higaus_bypass_en;
207*4882a593Smuzhiyun 	__u8 hiabs_possel;
208*4882a593Smuzhiyun 	__u8 hichnsplit_en;
209*4882a593Smuzhiyun 	__u8 lomed_bypass_en;
210*4882a593Smuzhiyun 	__u8 logaus5_bypass_en;
211*4882a593Smuzhiyun 	__u8 logaus3_bypass_en;
212*4882a593Smuzhiyun 	__u8 glbpk_en;
213*4882a593Smuzhiyun 	__u8 loswitch_protect;
214*4882a593Smuzhiyun 
215*4882a593Smuzhiyun 	__u16 softwgt;
216*4882a593Smuzhiyun 	__u16 hidif_th;
217*4882a593Smuzhiyun 
218*4882a593Smuzhiyun 	__u32 glbpk2;
219*4882a593Smuzhiyun 
220*4882a593Smuzhiyun 	__u16 wgtlmt;
221*4882a593Smuzhiyun 	__u16 wgtratio;
222*4882a593Smuzhiyun 
223*4882a593Smuzhiyun 	__u16 sig0_x[ISP3X_BAY3D_XY_NUM];
224*4882a593Smuzhiyun 	__u16 sig0_y[ISP3X_BAY3D_XY_NUM];
225*4882a593Smuzhiyun 	__u16 sig1_x[ISP3X_BAY3D_XY_NUM];
226*4882a593Smuzhiyun 	__u16 sig1_y[ISP3X_BAY3D_XY_NUM];
227*4882a593Smuzhiyun 	__u16 sig2_x[ISP3X_BAY3D_XY_NUM];
228*4882a593Smuzhiyun 	__u16 sig2_y[ISP3X_BAY3D_XY_NUM];
229*4882a593Smuzhiyun } __attribute__ ((packed));
230*4882a593Smuzhiyun 
231*4882a593Smuzhiyun struct isp3x_ynr_cfg {
232*4882a593Smuzhiyun 	__u8 rnr_en;
233*4882a593Smuzhiyun 	__u8 thumb_mix_cur_en;
234*4882a593Smuzhiyun 	__u8 global_gain_alpha;
235*4882a593Smuzhiyun 	__u8 flt1x1_bypass_sel;
236*4882a593Smuzhiyun 	__u8 sft5x5_bypass;
237*4882a593Smuzhiyun 	__u8 flt1x1_bypass;
238*4882a593Smuzhiyun 	__u8 lgft3x3_bypass;
239*4882a593Smuzhiyun 	__u8 lbft5x5_bypass;
240*4882a593Smuzhiyun 	__u8 bft3x3_bypass;
241*4882a593Smuzhiyun 	__u16 global_gain;
242*4882a593Smuzhiyun 
243*4882a593Smuzhiyun 	__u16 rnr_max_r;
244*4882a593Smuzhiyun 	__u16 local_gainscale;
245*4882a593Smuzhiyun 
246*4882a593Smuzhiyun 	__u16 rnr_center_coorh;
247*4882a593Smuzhiyun 	__u16 rnr_center_coorv;
248*4882a593Smuzhiyun 
249*4882a593Smuzhiyun 	__u16 loclagain_adj_thresh;
250*4882a593Smuzhiyun 	__u16 localgain_adj;
251*4882a593Smuzhiyun 
252*4882a593Smuzhiyun 	__u16 low_bf_inv1;
253*4882a593Smuzhiyun 	__u16 low_bf_inv0;
254*4882a593Smuzhiyun 
255*4882a593Smuzhiyun 	__u16 low_peak_supress;
256*4882a593Smuzhiyun 	__u16 low_thred_adj;
257*4882a593Smuzhiyun 
258*4882a593Smuzhiyun 	__u16 low_dist_adj;
259*4882a593Smuzhiyun 	__u16 low_edge_adj_thresh;
260*4882a593Smuzhiyun 
261*4882a593Smuzhiyun 	__u16 low_bi_weight;
262*4882a593Smuzhiyun 	__u16 low_weight;
263*4882a593Smuzhiyun 	__u16 low_center_weight;
264*4882a593Smuzhiyun 	__u16 hi_min_adj;
265*4882a593Smuzhiyun 	__u16 high_thred_adj;
266*4882a593Smuzhiyun 	__u8 high_retain_weight;
267*4882a593Smuzhiyun 	__u8 hi_edge_thed;
268*4882a593Smuzhiyun 	__u8 base_filter_weight2;
269*4882a593Smuzhiyun 	__u8 base_filter_weight1;
270*4882a593Smuzhiyun 	__u8 base_filter_weight0;
271*4882a593Smuzhiyun 	__u16 frame_full_size;
272*4882a593Smuzhiyun 	__u16 lbf_weight_thres;
273*4882a593Smuzhiyun 	__u16 low_gauss1_coeff2;
274*4882a593Smuzhiyun 	__u16 low_gauss1_coeff1;
275*4882a593Smuzhiyun 	__u16 low_gauss1_coeff0;
276*4882a593Smuzhiyun 	__u16 low_gauss2_coeff2;
277*4882a593Smuzhiyun 	__u16 low_gauss2_coeff1;
278*4882a593Smuzhiyun 	__u16 low_gauss2_coeff0;
279*4882a593Smuzhiyun 	__u8 direction_weight3;
280*4882a593Smuzhiyun 	__u8 direction_weight2;
281*4882a593Smuzhiyun 	__u8 direction_weight1;
282*4882a593Smuzhiyun 	__u8 direction_weight0;
283*4882a593Smuzhiyun 	__u8 direction_weight7;
284*4882a593Smuzhiyun 	__u8 direction_weight6;
285*4882a593Smuzhiyun 	__u8 direction_weight5;
286*4882a593Smuzhiyun 	__u8 direction_weight4;
287*4882a593Smuzhiyun 	__u16 luma_points_x[ISP3X_YNR_XY_NUM];
288*4882a593Smuzhiyun 	__u16 lsgm_y[ISP3X_YNR_XY_NUM];
289*4882a593Smuzhiyun 	__u16 hsgm_y[ISP3X_YNR_XY_NUM];
290*4882a593Smuzhiyun 	__u8 rnr_strength3[ISP3X_YNR_XY_NUM];
291*4882a593Smuzhiyun } __attribute__ ((packed));
292*4882a593Smuzhiyun 
293*4882a593Smuzhiyun struct isp3x_cnr_cfg {
294*4882a593Smuzhiyun 	__u8 thumb_mix_cur_en;
295*4882a593Smuzhiyun 	__u8 lq_bila_bypass;
296*4882a593Smuzhiyun 	__u8 hq_bila_bypass;
297*4882a593Smuzhiyun 	__u8 exgain_bypass;
298*4882a593Smuzhiyun 
299*4882a593Smuzhiyun 	__u8 global_gain_alpha;
300*4882a593Smuzhiyun 	__u16 global_gain;
301*4882a593Smuzhiyun 
302*4882a593Smuzhiyun 	__u8 gain_iso;
303*4882a593Smuzhiyun 	__u8 gain_offset;
304*4882a593Smuzhiyun 	__u8 gain_1sigma;
305*4882a593Smuzhiyun 
306*4882a593Smuzhiyun 	__u8 gain_uvgain1;
307*4882a593Smuzhiyun 	__u8 gain_uvgain0;
308*4882a593Smuzhiyun 
309*4882a593Smuzhiyun 	__u8 lmed3_alpha;
310*4882a593Smuzhiyun 
311*4882a593Smuzhiyun 	__u8 lbf5_gain_y;
312*4882a593Smuzhiyun 	__u8 lbf5_gain_c;
313*4882a593Smuzhiyun 
314*4882a593Smuzhiyun 	__u8 lbf5_weit_d3;
315*4882a593Smuzhiyun 	__u8 lbf5_weit_d2;
316*4882a593Smuzhiyun 	__u8 lbf5_weit_d1;
317*4882a593Smuzhiyun 	__u8 lbf5_weit_d0;
318*4882a593Smuzhiyun 
319*4882a593Smuzhiyun 	__u8 lbf5_weit_d4;
320*4882a593Smuzhiyun 
321*4882a593Smuzhiyun 	__u8 hmed3_alpha;
322*4882a593Smuzhiyun 
323*4882a593Smuzhiyun 	__u16 hbf5_weit_src;
324*4882a593Smuzhiyun 	__u16 hbf5_min_wgt;
325*4882a593Smuzhiyun 	__u16 hbf5_sigma;
326*4882a593Smuzhiyun 
327*4882a593Smuzhiyun 	__u16 lbf5_weit_src;
328*4882a593Smuzhiyun 	__u16 lbf3_sigma;
329*4882a593Smuzhiyun 
330*4882a593Smuzhiyun 	__u8 sigma_y[ISP3X_CNR_SIGMA_Y_NUM];
331*4882a593Smuzhiyun } __attribute__ ((packed));
332*4882a593Smuzhiyun 
333*4882a593Smuzhiyun struct isp3x_sharp_cfg {
334*4882a593Smuzhiyun 	__u8 bypass;
335*4882a593Smuzhiyun 	__u8 center_mode;
336*4882a593Smuzhiyun 	__u8 exgain_bypass;
337*4882a593Smuzhiyun 
338*4882a593Smuzhiyun 	__u8 sharp_ratio;
339*4882a593Smuzhiyun 	__u8 bf_ratio;
340*4882a593Smuzhiyun 	__u8 gaus_ratio;
341*4882a593Smuzhiyun 	__u8 pbf_ratio;
342*4882a593Smuzhiyun 
343*4882a593Smuzhiyun 	__u8 luma_dx[ISP3X_SHARP_X_NUM];
344*4882a593Smuzhiyun 
345*4882a593Smuzhiyun 	__u16 pbf_sigma_inv[ISP3X_SHARP_Y_NUM];
346*4882a593Smuzhiyun 
347*4882a593Smuzhiyun 	__u16 bf_sigma_inv[ISP3X_SHARP_Y_NUM];
348*4882a593Smuzhiyun 
349*4882a593Smuzhiyun 	__u8 bf_sigma_shift;
350*4882a593Smuzhiyun 	__u8 pbf_sigma_shift;
351*4882a593Smuzhiyun 
352*4882a593Smuzhiyun 	__u16 ehf_th[ISP3X_SHARP_Y_NUM];
353*4882a593Smuzhiyun 
354*4882a593Smuzhiyun 	__u16 clip_hf[ISP3X_SHARP_Y_NUM];
355*4882a593Smuzhiyun 
356*4882a593Smuzhiyun 	__u8 pbf_coef2;
357*4882a593Smuzhiyun 	__u8 pbf_coef1;
358*4882a593Smuzhiyun 	__u8 pbf_coef0;
359*4882a593Smuzhiyun 
360*4882a593Smuzhiyun 	__u8 bf_coef2;
361*4882a593Smuzhiyun 	__u8 bf_coef1;
362*4882a593Smuzhiyun 	__u8 bf_coef0;
363*4882a593Smuzhiyun 
364*4882a593Smuzhiyun 	__u8 gaus_coef[ISP3X_SHARP_GAUS_COEF_NUM];
365*4882a593Smuzhiyun } __attribute__ ((packed));
366*4882a593Smuzhiyun 
367*4882a593Smuzhiyun struct isp3x_dhaz_cfg {
368*4882a593Smuzhiyun 	__u8 round_en;
369*4882a593Smuzhiyun 	__u8 soft_wr_en;
370*4882a593Smuzhiyun 	__u8 enhance_en;
371*4882a593Smuzhiyun 	__u8 air_lc_en;
372*4882a593Smuzhiyun 	__u8 hpara_en;
373*4882a593Smuzhiyun 	__u8 hist_en;
374*4882a593Smuzhiyun 	__u8 dc_en;
375*4882a593Smuzhiyun 
376*4882a593Smuzhiyun 	__u8 yblk_th;
377*4882a593Smuzhiyun 	__u8 yhist_th;
378*4882a593Smuzhiyun 	__u8 dc_max_th;
379*4882a593Smuzhiyun 	__u8 dc_min_th;
380*4882a593Smuzhiyun 
381*4882a593Smuzhiyun 	__u16 wt_max;
382*4882a593Smuzhiyun 	__u8 bright_max;
383*4882a593Smuzhiyun 	__u8 bright_min;
384*4882a593Smuzhiyun 
385*4882a593Smuzhiyun 	__u8 tmax_base;
386*4882a593Smuzhiyun 	__u8 dark_th;
387*4882a593Smuzhiyun 	__u8 air_max;
388*4882a593Smuzhiyun 	__u8 air_min;
389*4882a593Smuzhiyun 
390*4882a593Smuzhiyun 	__u16 tmax_max;
391*4882a593Smuzhiyun 	__u16 tmax_off;
392*4882a593Smuzhiyun 
393*4882a593Smuzhiyun 	__u8 hist_k;
394*4882a593Smuzhiyun 	__u8 hist_th_off;
395*4882a593Smuzhiyun 	__u16 hist_min;
396*4882a593Smuzhiyun 
397*4882a593Smuzhiyun 	__u16 hist_gratio;
398*4882a593Smuzhiyun 	__u16 hist_scale;
399*4882a593Smuzhiyun 
400*4882a593Smuzhiyun 	__u16 enhance_value;
401*4882a593Smuzhiyun 	__u16 enhance_chroma;
402*4882a593Smuzhiyun 
403*4882a593Smuzhiyun 	__u16 iir_wt_sigma;
404*4882a593Smuzhiyun 	__u16 iir_sigma;
405*4882a593Smuzhiyun 	__u16 stab_fnum;
406*4882a593Smuzhiyun 
407*4882a593Smuzhiyun 	__u16 iir_tmax_sigma;
408*4882a593Smuzhiyun 	__u16 iir_air_sigma;
409*4882a593Smuzhiyun 	__u8 iir_pre_wet;
410*4882a593Smuzhiyun 
411*4882a593Smuzhiyun 	__u16 cfg_wt;
412*4882a593Smuzhiyun 	__u16 cfg_air;
413*4882a593Smuzhiyun 	__u16 cfg_alpha;
414*4882a593Smuzhiyun 
415*4882a593Smuzhiyun 	__u16 cfg_gratio;
416*4882a593Smuzhiyun 	__u16 cfg_tmax;
417*4882a593Smuzhiyun 
418*4882a593Smuzhiyun 	__u16 range_sima;
419*4882a593Smuzhiyun 	__u8 space_sigma_pre;
420*4882a593Smuzhiyun 	__u8 space_sigma_cur;
421*4882a593Smuzhiyun 
422*4882a593Smuzhiyun 	__u16 dc_weitcur;
423*4882a593Smuzhiyun 	__u16 bf_weight;
424*4882a593Smuzhiyun 
425*4882a593Smuzhiyun 	__u16 enh_curve[ISP3X_DHAZ_ENH_CURVE_NUM];
426*4882a593Smuzhiyun 
427*4882a593Smuzhiyun 	__u8 gaus_h2;
428*4882a593Smuzhiyun 	__u8 gaus_h1;
429*4882a593Smuzhiyun 	__u8 gaus_h0;
430*4882a593Smuzhiyun 
431*4882a593Smuzhiyun 	__u8 sigma_idx[ISP3X_DHAZ_SIGMA_IDX_NUM];
432*4882a593Smuzhiyun 	__u16 sigma_lut[ISP3X_DHAZ_SIGMA_LUT_NUM];
433*4882a593Smuzhiyun 
434*4882a593Smuzhiyun 	__u16 adp_wt_wr;
435*4882a593Smuzhiyun 	__u16 adp_air_wr;
436*4882a593Smuzhiyun 
437*4882a593Smuzhiyun 	__u16 adp_tmax_wr;
438*4882a593Smuzhiyun 	__u16 adp_gratio_wr;
439*4882a593Smuzhiyun 
440*4882a593Smuzhiyun 	__u16 hist_wr[ISP3X_DHAZ_HIST_WR_NUM];
441*4882a593Smuzhiyun } __attribute__ ((packed));
442*4882a593Smuzhiyun 
443*4882a593Smuzhiyun struct isp3x_dhaz_stat {
444*4882a593Smuzhiyun 	__u32 dhaz_pic_sumh;
445*4882a593Smuzhiyun 
446*4882a593Smuzhiyun 	__u16 dhaz_adp_air_base;
447*4882a593Smuzhiyun 	__u16 dhaz_adp_wt;
448*4882a593Smuzhiyun 
449*4882a593Smuzhiyun 	__u16 dhaz_adp_gratio;
450*4882a593Smuzhiyun 	__u16 dhaz_adp_tmax;
451*4882a593Smuzhiyun 
452*4882a593Smuzhiyun 	__u16 h_rgb_iir[ISP3X_DHAZ_HIST_IIR_NUM];
453*4882a593Smuzhiyun } __attribute__ ((packed));
454*4882a593Smuzhiyun 
455*4882a593Smuzhiyun struct isp3x_drc_cfg {
456*4882a593Smuzhiyun 	__u8 bypass_en;
457*4882a593Smuzhiyun 	__u8 offset_pow2;
458*4882a593Smuzhiyun 	__u16 compres_scl;
459*4882a593Smuzhiyun 	__u16 position;
460*4882a593Smuzhiyun 	__u16 delta_scalein;
461*4882a593Smuzhiyun 	__u16 hpdetail_ratio;
462*4882a593Smuzhiyun 	__u16 lpdetail_ratio;
463*4882a593Smuzhiyun 	__u8 weicur_pix;
464*4882a593Smuzhiyun 	__u8 weipre_frame;
465*4882a593Smuzhiyun 	__u8 bilat_wt_off;
466*4882a593Smuzhiyun 	__u16 force_sgm_inv0;
467*4882a593Smuzhiyun 	__u8 motion_scl;
468*4882a593Smuzhiyun 	__u8 edge_scl;
469*4882a593Smuzhiyun 	__u16 space_sgm_inv1;
470*4882a593Smuzhiyun 	__u16 space_sgm_inv0;
471*4882a593Smuzhiyun 	__u16 range_sgm_inv1;
472*4882a593Smuzhiyun 	__u16 range_sgm_inv0;
473*4882a593Smuzhiyun 	__u8 weig_maxl;
474*4882a593Smuzhiyun 	__u8 weig_bilat;
475*4882a593Smuzhiyun 	__u8 enable_soft_thd;
476*4882a593Smuzhiyun 	__u16 bilat_soft_thd;
477*4882a593Smuzhiyun 	__u16 gain_y[ISP3X_DRC_Y_NUM];
478*4882a593Smuzhiyun 	__u16 compres_y[ISP3X_DRC_Y_NUM];
479*4882a593Smuzhiyun 	__u16 scale_y[ISP3X_DRC_Y_NUM];
480*4882a593Smuzhiyun 	__u16 wr_cycle;
481*4882a593Smuzhiyun 	__u16 iir_weight;
482*4882a593Smuzhiyun 	__u16 min_ogain;
483*4882a593Smuzhiyun } __attribute__ ((packed));
484*4882a593Smuzhiyun 
485*4882a593Smuzhiyun struct isp3x_hdrmge_cfg {
486*4882a593Smuzhiyun 	__u8 s_base;
487*4882a593Smuzhiyun 	__u8 mode;
488*4882a593Smuzhiyun 
489*4882a593Smuzhiyun 	__u16 gain0_inv;
490*4882a593Smuzhiyun 	__u16 gain0;
491*4882a593Smuzhiyun 	__u16 gain1_inv;
492*4882a593Smuzhiyun 	__u16 gain1;
493*4882a593Smuzhiyun 	__u8 gain2;
494*4882a593Smuzhiyun 
495*4882a593Smuzhiyun 	__u8 lm_dif_0p15;
496*4882a593Smuzhiyun 	__u8 lm_dif_0p9;
497*4882a593Smuzhiyun 	__u8 ms_diff_0p15;
498*4882a593Smuzhiyun 	__u8 ms_dif_0p8;
499*4882a593Smuzhiyun 
500*4882a593Smuzhiyun 	__u16 ms_thd1;
501*4882a593Smuzhiyun 	__u16 ms_thd0;
502*4882a593Smuzhiyun 	__u16 ms_scl;
503*4882a593Smuzhiyun 	__u16 lm_thd1;
504*4882a593Smuzhiyun 	__u16 lm_thd0;
505*4882a593Smuzhiyun 	__u16 lm_scl;
506*4882a593Smuzhiyun 	struct isp2x_hdrmge_curve curve;
507*4882a593Smuzhiyun 	__u16 e_y[ISP3X_HDRMGE_E_CURVE_NUM];
508*4882a593Smuzhiyun } __attribute__ ((packed));
509*4882a593Smuzhiyun 
510*4882a593Smuzhiyun struct isp3x_rawawb_meas_cfg {
511*4882a593Smuzhiyun 	__u8 rawawb_sel;
512*4882a593Smuzhiyun 	__u8 sw_rawawb_xy_en0;
513*4882a593Smuzhiyun 	__u8 sw_rawawb_uv_en0;
514*4882a593Smuzhiyun 	__u8 sw_rawawb_xy_en1;
515*4882a593Smuzhiyun 	__u8 sw_rawawb_uv_en1;
516*4882a593Smuzhiyun 	__u8 sw_rawawb_3dyuv_en0;
517*4882a593Smuzhiyun 	__u8 sw_rawawb_3dyuv_en1;
518*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_blk_wei_en0;
519*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_blk_wei_en1;
520*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_wei_en0;
521*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_wei_en1;
522*4882a593Smuzhiyun 	__u8 sw_rawlsc_bypass_en;
523*4882a593Smuzhiyun 	__u8 sw_rawawb_blk_measure_enable;
524*4882a593Smuzhiyun 	__u8 sw_rawawb_blk_measure_mode;
525*4882a593Smuzhiyun 	__u8 sw_rawawb_blk_measure_xytype;
526*4882a593Smuzhiyun 	__u8 sw_rawawb_blk_measure_illu_idx;
527*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_hist_xytype;
528*4882a593Smuzhiyun 	__u8 sw_rawawb_light_num;
529*4882a593Smuzhiyun 	__u8 sw_rawawb_wind_size;
530*4882a593Smuzhiyun 	__u8 sw_rawawb_r_max;
531*4882a593Smuzhiyun 	__u8 sw_rawawb_g_max;
532*4882a593Smuzhiyun 	__u8 sw_rawawb_b_max;
533*4882a593Smuzhiyun 	__u8 sw_rawawb_y_max;
534*4882a593Smuzhiyun 	__u8 sw_rawawb_r_min;
535*4882a593Smuzhiyun 	__u8 sw_rawawb_g_min;
536*4882a593Smuzhiyun 	__u8 sw_rawawb_b_min;
537*4882a593Smuzhiyun 	__u8 sw_rawawb_y_min;
538*4882a593Smuzhiyun 	__u8 sw_rawawb_3dyuv_ls_idx0;
539*4882a593Smuzhiyun 	__u8 sw_rawawb_3dyuv_ls_idx1;
540*4882a593Smuzhiyun 	__u8 sw_rawawb_3dyuv_ls_idx2;
541*4882a593Smuzhiyun 	__u8 sw_rawawb_3dyuv_ls_idx3;
542*4882a593Smuzhiyun 	__u8 sw_rawawb_multiwindow_en;
543*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region0_excen0;
544*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region0_excen1;
545*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region0_measen;
546*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region0_domain;
547*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region1_excen0;
548*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region1_excen1;
549*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region1_measen;
550*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region1_domain;
551*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region2_excen0;
552*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region2_excen1;
553*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region2_measen;
554*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region2_domain;
555*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region3_excen0;
556*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region3_excen1;
557*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region3_measen;
558*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region3_domain;
559*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region4_excen0;
560*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region4_excen1;
561*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region4_domain;
562*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region5_excen0;
563*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region5_excen1;
564*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region5_domain;
565*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region6_excen0;
566*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region6_excen1;
567*4882a593Smuzhiyun 	__u8 sw_rawawb_exc_wp_region6_domain;
568*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y0;
569*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y1;
570*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y2;
571*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y3;
572*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y4;
573*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y5;
574*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y6;
575*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y7;
576*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_y8;
577*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w0;
578*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w1;
579*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w2;
580*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w3;
581*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w4;
582*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w5;
583*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w6;
584*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w7;
585*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_luma_weicurve_w8;
586*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu0_ls0;
587*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu1_ls0;
588*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu2_ls0;
589*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu3_ls0;
590*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu4_ls0;
591*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu5_ls0;
592*4882a593Smuzhiyun 	__u8 sw_rawawb_dis_x1x2_ls0;
593*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu0_ls1;
594*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu1_ls1;
595*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu2_ls1;
596*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu3_ls1;
597*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu4_ls1;
598*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu5_ls1;
599*4882a593Smuzhiyun 	__u8 sw_rawawb_dis_x1x2_ls1;
600*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu0_ls2;
601*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu1_ls2;
602*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu2_ls2;
603*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu3_ls2;
604*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu4_ls2;
605*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu5_ls2;
606*4882a593Smuzhiyun 	__u8 sw_rawawb_dis_x1x2_ls2;
607*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu0_ls3;
608*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu1_ls3;
609*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu2_ls3;
610*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu3_ls3;
611*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu4_ls3;
612*4882a593Smuzhiyun 	__u8 sw_rawawb_rotu5_ls3;
613*4882a593Smuzhiyun 	__u8 sw_rawawb_dis_x1x2_ls3;
614*4882a593Smuzhiyun 	__u8 sw_rawawb_blk_rtdw_measure_en;
615*4882a593Smuzhiyun 	__u8 sw_rawawb_blk_with_luma_wei_en;
616*4882a593Smuzhiyun 	__u8 sw_rawawb_wp_blk_wei_w[ISP3X_RAWAWB_WEIGHT_NUM];
617*4882a593Smuzhiyun 
618*4882a593Smuzhiyun 	__u16 sw_rawawb_h_offs;
619*4882a593Smuzhiyun 	__u16 sw_rawawb_v_offs;
620*4882a593Smuzhiyun 	__u16 sw_rawawb_h_size;
621*4882a593Smuzhiyun 	__u16 sw_rawawb_v_size;
622*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_u_0;
623*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_v_0;
624*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_u_0;
625*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_v_0;
626*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_u_0;
627*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_v_0;
628*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_u_0;
629*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_v_0;
630*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_u_1;
631*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_v_1;
632*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_u_1;
633*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_v_1;
634*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_u_1;
635*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_v_1;
636*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_u_1;
637*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_v_1;
638*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_u_2;
639*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_v_2;
640*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_u_2;
641*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_v_2;
642*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_u_2;
643*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_v_2;
644*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_u_2;
645*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_v_2;
646*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_u_3;
647*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_v_3;
648*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_u_3;
649*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_v_3;
650*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_u_3;
651*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_v_3;
652*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_u_3;
653*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_v_3;
654*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_u_4;
655*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_v_4;
656*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_u_4;
657*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_v_4;
658*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_u_4;
659*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_v_4;
660*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_u_4;
661*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_v_4;
662*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_u_5;
663*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_v_5;
664*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_u_5;
665*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_v_5;
666*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_u_5;
667*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_v_5;
668*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_u_5;
669*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_v_5;
670*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_u_6;
671*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex0_v_6;
672*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_u_6;
673*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex1_v_6;
674*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_u_6;
675*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex2_v_6;
676*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_u_6;
677*4882a593Smuzhiyun 	__u16 sw_rawawb_vertex3_v_6;
678*4882a593Smuzhiyun 
679*4882a593Smuzhiyun 	__u16 sw_rawawb_wt0;
680*4882a593Smuzhiyun 	__u16 sw_rawawb_wt1;
681*4882a593Smuzhiyun 	__u16 sw_rawawb_wt2;
682*4882a593Smuzhiyun 	__u16 sw_rawawb_mat0_x;
683*4882a593Smuzhiyun 	__u16 sw_rawawb_mat1_x;
684*4882a593Smuzhiyun 	__u16 sw_rawawb_mat2_x;
685*4882a593Smuzhiyun 	__u16 sw_rawawb_mat0_y;
686*4882a593Smuzhiyun 	__u16 sw_rawawb_mat1_y;
687*4882a593Smuzhiyun 	__u16 sw_rawawb_mat2_y;
688*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x0_0;
689*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x1_0;
690*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y0_0;
691*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y1_0;
692*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x0_0;
693*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x1_0;
694*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y0_0;
695*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y1_0;
696*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x0_1;
697*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x1_1;
698*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y0_1;
699*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y1_1;
700*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x0_1;
701*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x1_1;
702*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y0_1;
703*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y1_1;
704*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x0_2;
705*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x1_2;
706*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y0_2;
707*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y1_2;
708*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x0_2;
709*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x1_2;
710*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y0_2;
711*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y1_2;
712*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x0_3;
713*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x1_3;
714*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y0_3;
715*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y1_3;
716*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x0_3;
717*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x1_3;
718*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y0_3;
719*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y1_3;
720*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x0_4;
721*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x1_4;
722*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y0_4;
723*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y1_4;
724*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x0_4;
725*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x1_4;
726*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y0_4;
727*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y1_4;
728*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x0_5;
729*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x1_5;
730*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y0_5;
731*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y1_5;
732*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x0_5;
733*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x1_5;
734*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y0_5;
735*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y1_5;
736*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x0_6;
737*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_x1_6;
738*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y0_6;
739*4882a593Smuzhiyun 	__u16 sw_rawawb_nor_y1_6;
740*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x0_6;
741*4882a593Smuzhiyun 	__u16 sw_rawawb_big_x1_6;
742*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y0_6;
743*4882a593Smuzhiyun 	__u16 sw_rawawb_big_y1_6;
744*4882a593Smuzhiyun 	__u16 sw_rawawb_pre_wbgain_inv_r;
745*4882a593Smuzhiyun 	__u16 sw_rawawb_pre_wbgain_inv_g;
746*4882a593Smuzhiyun 	__u16 sw_rawawb_pre_wbgain_inv_b;
747*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow0_v_offs;
748*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow0_h_offs;
749*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow0_v_size;
750*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow0_h_size;
751*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow1_v_offs;
752*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow1_h_offs;
753*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow1_v_size;
754*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow1_h_size;
755*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow2_v_offs;
756*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow2_h_offs;
757*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow2_v_size;
758*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow2_h_size;
759*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow3_v_offs;
760*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow3_h_offs;
761*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow3_v_size;
762*4882a593Smuzhiyun 	__u16 sw_rawawb_multiwindow3_h_size;
763*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region0_xu0;
764*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region0_xu1;
765*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region0_yv0;
766*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region0_yv1;
767*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region1_xu0;
768*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region1_xu1;
769*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region1_yv0;
770*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region1_yv1;
771*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region2_xu0;
772*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region2_xu1;
773*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region2_yv0;
774*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region2_yv1;
775*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region3_xu0;
776*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region3_xu1;
777*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region3_yv0;
778*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region3_yv1;
779*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region4_xu0;
780*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region4_xu1;
781*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region4_yv0;
782*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region4_yv1;
783*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region5_xu0;
784*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region5_xu1;
785*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region5_yv0;
786*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region5_yv1;
787*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region6_xu0;
788*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region6_xu1;
789*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region6_yv0;
790*4882a593Smuzhiyun 	__u16 sw_rawawb_exc_wp_region6_yv1;
791*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat0_u;
792*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat1_u;
793*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat2_u;
794*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvofs_u;
795*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat0_v;
796*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat1_v;
797*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat2_v;
798*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvofs_v;
799*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat0_y;
800*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat1_y;
801*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvmat2_y;
802*4882a593Smuzhiyun 	__u16 sw_rawawb_rgb2ryuvofs_y;
803*4882a593Smuzhiyun 	__u16 sw_rawawb_th0_ls0;
804*4882a593Smuzhiyun 	__u16 sw_rawawb_th1_ls0;
805*4882a593Smuzhiyun 	__u16 sw_rawawb_th2_ls0;
806*4882a593Smuzhiyun 	__u16 sw_rawawb_th3_ls0;
807*4882a593Smuzhiyun 	__u16 sw_rawawb_th4_ls0;
808*4882a593Smuzhiyun 	__u16 sw_rawawb_th5_ls0;
809*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls0_u;
810*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls0_v;
811*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls0_y;
812*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls0_u;
813*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls0_v;
814*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls0_y;
815*4882a593Smuzhiyun 	__u16 sw_rawawb_th0_ls1;
816*4882a593Smuzhiyun 	__u16 sw_rawawb_th1_ls1;
817*4882a593Smuzhiyun 	__u16 sw_rawawb_th2_ls1;
818*4882a593Smuzhiyun 	__u16 sw_rawawb_th3_ls1;
819*4882a593Smuzhiyun 	__u16 sw_rawawb_th4_ls1;
820*4882a593Smuzhiyun 	__u16 sw_rawawb_th5_ls1;
821*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls1_u;
822*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls1_v;
823*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls1_y;
824*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls1_u;
825*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls1_v;
826*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls1_y;
827*4882a593Smuzhiyun 	__u16 sw_rawawb_th0_ls2;
828*4882a593Smuzhiyun 	__u16 sw_rawawb_th1_ls2;
829*4882a593Smuzhiyun 	__u16 sw_rawawb_th2_ls2;
830*4882a593Smuzhiyun 	__u16 sw_rawawb_th3_ls2;
831*4882a593Smuzhiyun 	__u16 sw_rawawb_th4_ls2;
832*4882a593Smuzhiyun 	__u16 sw_rawawb_th5_ls2;
833*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls2_u;
834*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls2_v;
835*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls2_y;
836*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls2_u;
837*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls2_v;
838*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls2_y;
839*4882a593Smuzhiyun 	__u16 sw_rawawb_th0_ls3;
840*4882a593Smuzhiyun 	__u16 sw_rawawb_th1_ls3;
841*4882a593Smuzhiyun 	__u16 sw_rawawb_th2_ls3;
842*4882a593Smuzhiyun 	__u16 sw_rawawb_th3_ls3;
843*4882a593Smuzhiyun 	__u16 sw_rawawb_th4_ls3;
844*4882a593Smuzhiyun 	__u16 sw_rawawb_th5_ls3;
845*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls3_u;
846*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls3_v;
847*4882a593Smuzhiyun 	__u16 sw_rawawb_coor_x1_ls3_y;
848*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls3_u;
849*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls3_v;
850*4882a593Smuzhiyun 	__u16 sw_rawawb_vec_x21_ls3_y;
851*4882a593Smuzhiyun 
852*4882a593Smuzhiyun 	__u32 sw_rawawb_islope01_0;
853*4882a593Smuzhiyun 	__u32 sw_rawawb_islope12_0;
854*4882a593Smuzhiyun 	__u32 sw_rawawb_islope23_0;
855*4882a593Smuzhiyun 	__u32 sw_rawawb_islope30_0;
856*4882a593Smuzhiyun 	__u32 sw_rawawb_islope01_1;
857*4882a593Smuzhiyun 	__u32 sw_rawawb_islope12_1;
858*4882a593Smuzhiyun 	__u32 sw_rawawb_islope23_1;
859*4882a593Smuzhiyun 	__u32 sw_rawawb_islope30_1;
860*4882a593Smuzhiyun 	__u32 sw_rawawb_islope01_2;
861*4882a593Smuzhiyun 	__u32 sw_rawawb_islope12_2;
862*4882a593Smuzhiyun 	__u32 sw_rawawb_islope23_2;
863*4882a593Smuzhiyun 	__u32 sw_rawawb_islope30_2;
864*4882a593Smuzhiyun 	__u32 sw_rawawb_islope01_3;
865*4882a593Smuzhiyun 	__u32 sw_rawawb_islope12_3;
866*4882a593Smuzhiyun 	__u32 sw_rawawb_islope23_3;
867*4882a593Smuzhiyun 	__u32 sw_rawawb_islope30_3;
868*4882a593Smuzhiyun 	__u32 sw_rawawb_islope01_4;
869*4882a593Smuzhiyun 	__u32 sw_rawawb_islope12_4;
870*4882a593Smuzhiyun 	__u32 sw_rawawb_islope23_4;
871*4882a593Smuzhiyun 	__u32 sw_rawawb_islope30_4;
872*4882a593Smuzhiyun 	__u32 sw_rawawb_islope01_5;
873*4882a593Smuzhiyun 	__u32 sw_rawawb_islope12_5;
874*4882a593Smuzhiyun 	__u32 sw_rawawb_islope23_5;
875*4882a593Smuzhiyun 	__u32 sw_rawawb_islope30_5;
876*4882a593Smuzhiyun 	__u32 sw_rawawb_islope01_6;
877*4882a593Smuzhiyun 	__u32 sw_rawawb_islope12_6;
878*4882a593Smuzhiyun 	__u32 sw_rawawb_islope23_6;
879*4882a593Smuzhiyun 	__u32 sw_rawawb_islope30_6;
880*4882a593Smuzhiyun } __attribute__ ((packed));
881*4882a593Smuzhiyun 
882*4882a593Smuzhiyun struct isp3x_rawawb_meas_stat {
883*4882a593Smuzhiyun 	__u16 ro_yhist_bin[ISP3X_RAWAWB_HSTBIN_NUM];
884*4882a593Smuzhiyun 	__u32 ro_rawawb_sum_rgain_nor[ISP3X_RAWAWB_SUM_NUM];
885*4882a593Smuzhiyun 	__u32 ro_rawawb_sum_bgain_nor[ISP3X_RAWAWB_SUM_NUM];
886*4882a593Smuzhiyun 	__u32 ro_rawawb_wp_num_nor[ISP3X_RAWAWB_SUM_NUM];
887*4882a593Smuzhiyun 	__u32 ro_rawawb_sum_rgain_big[ISP3X_RAWAWB_SUM_NUM];
888*4882a593Smuzhiyun 	__u32 ro_rawawb_sum_bgain_big[ISP3X_RAWAWB_SUM_NUM];
889*4882a593Smuzhiyun 	__u32 ro_rawawb_wp_num_big[ISP3X_RAWAWB_SUM_NUM];
890*4882a593Smuzhiyun 	__u32 ro_wp_num2[ISP3X_RAWAWB_SUM_NUM];
891*4882a593Smuzhiyun 	__u32 ro_sum_r_nor_multiwindow[ISP3X_RAWAWB_MULWD_NUM];
892*4882a593Smuzhiyun 	__u32 ro_sum_b_nor_multiwindow[ISP3X_RAWAWB_MULWD_NUM];
893*4882a593Smuzhiyun 	__u32 ro_wp_nm_nor_multiwindow[ISP3X_RAWAWB_MULWD_NUM];
894*4882a593Smuzhiyun 	__u32 ro_sum_r_big_multiwindow[ISP3X_RAWAWB_MULWD_NUM];
895*4882a593Smuzhiyun 	__u32 ro_sum_b_big_multiwindow[ISP3X_RAWAWB_MULWD_NUM];
896*4882a593Smuzhiyun 	__u32 ro_wp_nm_big_multiwindow[ISP3X_RAWAWB_MULWD_NUM];
897*4882a593Smuzhiyun 	__u32 ro_sum_r_exc[ISP3X_RAWAWB_EXCL_STAT_NUM];
898*4882a593Smuzhiyun 	__u32 ro_sum_b_exc[ISP3X_RAWAWB_EXCL_STAT_NUM];
899*4882a593Smuzhiyun 	__u32 ro_wp_nm_exc[ISP3X_RAWAWB_EXCL_STAT_NUM];
900*4882a593Smuzhiyun 	struct isp2x_rawawb_ramdata ramdata[ISP3X_RAWAWB_RAMDATA_NUM];
901*4882a593Smuzhiyun } __attribute__ ((packed));
902*4882a593Smuzhiyun 
903*4882a593Smuzhiyun struct isp3x_rawaf_curve {
904*4882a593Smuzhiyun 	__u8 ldg_lumth;
905*4882a593Smuzhiyun 	__u8 ldg_gain;
906*4882a593Smuzhiyun 	__u16 ldg_gslp;
907*4882a593Smuzhiyun } __attribute__ ((packed));
908*4882a593Smuzhiyun 
909*4882a593Smuzhiyun struct isp3x_rawaf_meas_cfg {
910*4882a593Smuzhiyun 	__u8 rawaf_sel;
911*4882a593Smuzhiyun 	__u8 num_afm_win;
912*4882a593Smuzhiyun 	/* CTRL */
913*4882a593Smuzhiyun 	__u8 gamma_en;
914*4882a593Smuzhiyun 	__u8 gaus_en;
915*4882a593Smuzhiyun 	__u8 v1_fir_sel;
916*4882a593Smuzhiyun 	__u8 hiir_en;
917*4882a593Smuzhiyun 	__u8 viir_en;
918*4882a593Smuzhiyun 	__u8 accu_8bit_mode;
919*4882a593Smuzhiyun 	__u8 ldg_en;
920*4882a593Smuzhiyun 	__u8 h1_fv_mode;
921*4882a593Smuzhiyun 	__u8 h2_fv_mode;
922*4882a593Smuzhiyun 	__u8 v1_fv_mode;
923*4882a593Smuzhiyun 	__u8 v2_fv_mode;
924*4882a593Smuzhiyun 	__u8 ae_mode;
925*4882a593Smuzhiyun 	__u8 y_mode;
926*4882a593Smuzhiyun 	/* WINA_B */
927*4882a593Smuzhiyun 	struct isp2x_window win[ISP3X_RAWAF_WIN_NUM];
928*4882a593Smuzhiyun 	/* INT_LINE */
929*4882a593Smuzhiyun 	__u8 line_num[ISP3X_RAWAF_LINE_NUM];
930*4882a593Smuzhiyun 	__u8 line_en[ISP3X_RAWAF_LINE_NUM];
931*4882a593Smuzhiyun 	/* THRES */
932*4882a593Smuzhiyun 	__u16 afm_thres;
933*4882a593Smuzhiyun 	/* VAR_SHIFT */
934*4882a593Smuzhiyun 	__u8 afm_var_shift[ISP3X_RAWAF_WIN_NUM];
935*4882a593Smuzhiyun 	__u8 lum_var_shift[ISP3X_RAWAF_WIN_NUM];
936*4882a593Smuzhiyun 	/* HVIIR_VAR_SHIFT */
937*4882a593Smuzhiyun 	__u8 h1iir_var_shift;
938*4882a593Smuzhiyun 	__u8 h2iir_var_shift;
939*4882a593Smuzhiyun 	__u8 v1iir_var_shift;
940*4882a593Smuzhiyun 	__u8 v2iir_var_shift;
941*4882a593Smuzhiyun 	/* GAMMA_Y */
942*4882a593Smuzhiyun 	__u16 gamma_y[ISP3X_RAWAF_GAMMA_NUM];
943*4882a593Smuzhiyun 	/* HIIR_THRESH */
944*4882a593Smuzhiyun 	__u16 h_fv_thresh;
945*4882a593Smuzhiyun 	__u16 v_fv_thresh;
946*4882a593Smuzhiyun 	struct isp3x_rawaf_curve curve_h[ISP3X_RAWAF_CURVE_NUM];
947*4882a593Smuzhiyun 	struct isp3x_rawaf_curve curve_v[ISP3X_RAWAF_CURVE_NUM];
948*4882a593Smuzhiyun 	__s16 h1iir1_coe[ISP3X_RAWAF_HIIR_COE_NUM];
949*4882a593Smuzhiyun 	__s16 h1iir2_coe[ISP3X_RAWAF_HIIR_COE_NUM];
950*4882a593Smuzhiyun 	__s16 h2iir1_coe[ISP3X_RAWAF_HIIR_COE_NUM];
951*4882a593Smuzhiyun 	__s16 h2iir2_coe[ISP3X_RAWAF_HIIR_COE_NUM];
952*4882a593Smuzhiyun 	__s16 v1iir_coe[ISP3X_RAWAF_V1IIR_COE_NUM];
953*4882a593Smuzhiyun 	__s16 v2iir_coe[ISP3X_RAWAF_V2IIR_COE_NUM];
954*4882a593Smuzhiyun 	__s16 v1fir_coe[ISP3X_RAWAF_VFIR_COE_NUM];
955*4882a593Smuzhiyun 	__s16 v2fir_coe[ISP3X_RAWAF_VFIR_COE_NUM];
956*4882a593Smuzhiyun 	__u16 highlit_thresh;
957*4882a593Smuzhiyun } __attribute__ ((packed));
958*4882a593Smuzhiyun 
959*4882a593Smuzhiyun struct isp3x_rawaf_ramdata {
960*4882a593Smuzhiyun 	__u32 v1;
961*4882a593Smuzhiyun 	__u32 v2;
962*4882a593Smuzhiyun 	__u32 h1;
963*4882a593Smuzhiyun 	__u32 h2;
964*4882a593Smuzhiyun } __attribute__ ((packed));
965*4882a593Smuzhiyun 
966*4882a593Smuzhiyun struct isp3x_rawaf_stat {
967*4882a593Smuzhiyun 	__u32 int_state;
968*4882a593Smuzhiyun 	__u32 afm_sum_b;
969*4882a593Smuzhiyun 	__u32 afm_lum_b;
970*4882a593Smuzhiyun 	__u32 highlit_cnt_winb;
971*4882a593Smuzhiyun 	struct isp3x_rawaf_ramdata ramdata[ISP3X_RAWAF_SUMDATA_NUM];
972*4882a593Smuzhiyun } __attribute__ ((packed));
973*4882a593Smuzhiyun 
974*4882a593Smuzhiyun struct isp3x_cac_cfg {
975*4882a593Smuzhiyun 	__u8 bypass_en;
976*4882a593Smuzhiyun 	__u8 center_en;
977*4882a593Smuzhiyun 
978*4882a593Smuzhiyun 	__u8 psf_sft_bit;
979*4882a593Smuzhiyun 	__u16 cfg_num;
980*4882a593Smuzhiyun 
981*4882a593Smuzhiyun 	__u16 center_width;
982*4882a593Smuzhiyun 	__u16 center_height;
983*4882a593Smuzhiyun 
984*4882a593Smuzhiyun 	__u16 strength[ISP3X_CAC_STRENGTH_NUM];
985*4882a593Smuzhiyun 
986*4882a593Smuzhiyun 	__u32 hsize;
987*4882a593Smuzhiyun 	__u32 vsize;
988*4882a593Smuzhiyun 	__s32 buf_fd;
989*4882a593Smuzhiyun } __attribute__ ((packed));
990*4882a593Smuzhiyun 
991*4882a593Smuzhiyun struct isp3x_gain_cfg {
992*4882a593Smuzhiyun 	__u32 g0;
993*4882a593Smuzhiyun 	__u16 g1;
994*4882a593Smuzhiyun 	__u16 g2;
995*4882a593Smuzhiyun } __attribute__ ((packed));
996*4882a593Smuzhiyun 
997*4882a593Smuzhiyun struct isp3x_isp_other_cfg {
998*4882a593Smuzhiyun 	struct isp21_bls_cfg bls_cfg;
999*4882a593Smuzhiyun 	struct isp2x_dpcc_cfg dpcc_cfg;
1000*4882a593Smuzhiyun 	struct isp3x_lsc_cfg lsc_cfg;
1001*4882a593Smuzhiyun 	struct isp21_awb_gain_cfg awb_gain_cfg;
1002*4882a593Smuzhiyun 	struct isp21_gic_cfg gic_cfg;
1003*4882a593Smuzhiyun 	struct isp2x_debayer_cfg debayer_cfg;
1004*4882a593Smuzhiyun 	struct isp21_ccm_cfg ccm_cfg;
1005*4882a593Smuzhiyun 	struct isp3x_gammaout_cfg gammaout_cfg;
1006*4882a593Smuzhiyun 	struct isp2x_cproc_cfg cproc_cfg;
1007*4882a593Smuzhiyun 	struct isp2x_ie_cfg ie_cfg;
1008*4882a593Smuzhiyun 	struct isp2x_sdg_cfg sdg_cfg;
1009*4882a593Smuzhiyun 	struct isp3x_drc_cfg drc_cfg;
1010*4882a593Smuzhiyun 	struct isp3x_hdrmge_cfg hdrmge_cfg;
1011*4882a593Smuzhiyun 	struct isp3x_dhaz_cfg dhaz_cfg;
1012*4882a593Smuzhiyun 	struct isp2x_3dlut_cfg isp3dlut_cfg;
1013*4882a593Smuzhiyun 	struct isp2x_ldch_cfg ldch_cfg;
1014*4882a593Smuzhiyun 	struct isp3x_baynr_cfg baynr_cfg;
1015*4882a593Smuzhiyun 	struct isp3x_bay3d_cfg bay3d_cfg;
1016*4882a593Smuzhiyun 	struct isp3x_ynr_cfg ynr_cfg;
1017*4882a593Smuzhiyun 	struct isp3x_cnr_cfg cnr_cfg;
1018*4882a593Smuzhiyun 	struct isp3x_sharp_cfg sharp_cfg;
1019*4882a593Smuzhiyun 	struct isp3x_cac_cfg cac_cfg;
1020*4882a593Smuzhiyun 	struct isp3x_gain_cfg gain_cfg;
1021*4882a593Smuzhiyun 	struct isp21_csm_cfg csm_cfg;
1022*4882a593Smuzhiyun 	struct isp21_cgc_cfg cgc_cfg;
1023*4882a593Smuzhiyun } __attribute__ ((packed));
1024*4882a593Smuzhiyun 
1025*4882a593Smuzhiyun struct isp3x_isp_meas_cfg {
1026*4882a593Smuzhiyun 	struct isp3x_rawaf_meas_cfg rawaf;
1027*4882a593Smuzhiyun 	struct isp3x_rawawb_meas_cfg rawawb;
1028*4882a593Smuzhiyun 	struct isp2x_rawaelite_meas_cfg rawae0;
1029*4882a593Smuzhiyun 	struct isp2x_rawaebig_meas_cfg rawae1;
1030*4882a593Smuzhiyun 	struct isp2x_rawaebig_meas_cfg rawae2;
1031*4882a593Smuzhiyun 	struct isp2x_rawaebig_meas_cfg rawae3;
1032*4882a593Smuzhiyun 	struct isp2x_rawhistlite_cfg rawhist0;
1033*4882a593Smuzhiyun 	struct isp2x_rawhistbig_cfg rawhist1;
1034*4882a593Smuzhiyun 	struct isp2x_rawhistbig_cfg rawhist2;
1035*4882a593Smuzhiyun 	struct isp2x_rawhistbig_cfg rawhist3;
1036*4882a593Smuzhiyun } __attribute__ ((packed));
1037*4882a593Smuzhiyun 
1038*4882a593Smuzhiyun struct isp3x_isp_params_cfg {
1039*4882a593Smuzhiyun 	__u64 module_en_update;
1040*4882a593Smuzhiyun 	__u64 module_ens;
1041*4882a593Smuzhiyun 	__u64 module_cfg_update;
1042*4882a593Smuzhiyun 
1043*4882a593Smuzhiyun 	__u32 frame_id;
1044*4882a593Smuzhiyun 	struct isp3x_isp_meas_cfg meas;
1045*4882a593Smuzhiyun 	struct isp3x_isp_other_cfg others;
1046*4882a593Smuzhiyun } __attribute__ ((packed));
1047*4882a593Smuzhiyun 
1048*4882a593Smuzhiyun struct isp3x_stat {
1049*4882a593Smuzhiyun 	struct isp2x_rawaebig_stat rawae3;
1050*4882a593Smuzhiyun 	struct isp2x_rawaebig_stat rawae1;
1051*4882a593Smuzhiyun 	struct isp2x_rawaebig_stat rawae2;
1052*4882a593Smuzhiyun 	struct isp2x_rawaelite_stat rawae0;
1053*4882a593Smuzhiyun 	struct isp2x_rawhistbig_stat rawhist3;
1054*4882a593Smuzhiyun 	struct isp2x_rawhistlite_stat rawhist0;
1055*4882a593Smuzhiyun 	struct isp2x_rawhistbig_stat rawhist1;
1056*4882a593Smuzhiyun 	struct isp2x_rawhistbig_stat rawhist2;
1057*4882a593Smuzhiyun 	struct isp3x_rawaf_stat rawaf;
1058*4882a593Smuzhiyun 	struct isp3x_rawawb_meas_stat rawawb;
1059*4882a593Smuzhiyun 	struct isp3x_dhaz_stat dhaz;
1060*4882a593Smuzhiyun 	struct isp2x_bls_stat bls;
1061*4882a593Smuzhiyun } __attribute__ ((packed));
1062*4882a593Smuzhiyun 
1063*4882a593Smuzhiyun /**
1064*4882a593Smuzhiyun  * struct rkisp3x_isp_stat_buffer - Rockchip ISP3 Statistics Meta Data
1065*4882a593Smuzhiyun  *
1066*4882a593Smuzhiyun  * @meas_type: measurement types (ISP3X_STAT_ definitions)
1067*4882a593Smuzhiyun  * @frame_id: frame ID for sync
1068*4882a593Smuzhiyun  * @params: statistics data
1069*4882a593Smuzhiyun  */
1070*4882a593Smuzhiyun struct rkisp3x_isp_stat_buffer {
1071*4882a593Smuzhiyun 	__u32 meas_type;
1072*4882a593Smuzhiyun 	__u32 frame_id;
1073*4882a593Smuzhiyun 	__u32 params_id;
1074*4882a593Smuzhiyun 	struct isp3x_stat params;
1075*4882a593Smuzhiyun } __attribute__ ((packed));
1076*4882a593Smuzhiyun 
1077*4882a593Smuzhiyun #endif /* _UAPI_RK_ISP3_CONFIG_H */
1078