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