1/****************************************************************************
2 ****************************************************************************
3 ***
4 ***   This header was automatically generated from a Linux kernel header
5 ***   of the same name, to make information necessary for userspace to
6 ***   call into the kernel available to libc.  It contains only constants,
7 ***   structures, and macros generated from the original header, and thus,
8 ***   contains no copyrightable information.
9 ***
10 ***   To edit the content of this header, modify the corresponding
11 ***   source file (e.g. under external/kernel-headers/original/) then
12 ***   run bionic/libc/kernel/tools/update_all.py
13 ***
14 ***   Any manual change here will be lost the next time this script will
15 ***   be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef OMAP3_ISP_USER_H
20#define OMAP3_ISP_USER_H
21#include <linux/types.h>
22#include <linux/videodev2.h>
23/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
24#define VIDIOC_OMAP3ISP_CCDC_CFG   _IOWR('V', BASE_VIDIOC_PRIVATE + 1, struct omap3isp_ccdc_update_config)
25#define VIDIOC_OMAP3ISP_PRV_CFG   _IOWR('V', BASE_VIDIOC_PRIVATE + 2, struct omap3isp_prev_update_config)
26#define VIDIOC_OMAP3ISP_AEWB_CFG   _IOWR('V', BASE_VIDIOC_PRIVATE + 3, struct omap3isp_h3a_aewb_config)
27#define VIDIOC_OMAP3ISP_HIST_CFG   _IOWR('V', BASE_VIDIOC_PRIVATE + 4, struct omap3isp_hist_config)
28/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
29#define VIDIOC_OMAP3ISP_AF_CFG   _IOWR('V', BASE_VIDIOC_PRIVATE + 5, struct omap3isp_h3a_af_config)
30#define VIDIOC_OMAP3ISP_STAT_REQ   _IOWR('V', BASE_VIDIOC_PRIVATE + 6, struct omap3isp_stat_data)
31#define VIDIOC_OMAP3ISP_STAT_EN   _IOWR('V', BASE_VIDIOC_PRIVATE + 7, unsigned long)
32#define V4L2_EVENT_OMAP3ISP_CLASS (V4L2_EVENT_PRIVATE_START | 0x100)
33/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
34#define V4L2_EVENT_OMAP3ISP_AEWB (V4L2_EVENT_OMAP3ISP_CLASS | 0x1)
35#define V4L2_EVENT_OMAP3ISP_AF (V4L2_EVENT_OMAP3ISP_CLASS | 0x2)
36#define V4L2_EVENT_OMAP3ISP_HIST (V4L2_EVENT_OMAP3ISP_CLASS | 0x3)
37struct omap3isp_stat_event_status {
38/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
39 __u32 frame_number;
40 __u16 config_counter;
41 __u8 buf_err;
42};
43/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
44#define OMAP3ISP_AEWB_MAX_SATURATION_LIM 1023
45#define OMAP3ISP_AEWB_MIN_WIN_H 2
46#define OMAP3ISP_AEWB_MAX_WIN_H 256
47#define OMAP3ISP_AEWB_MIN_WIN_W 6
48/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
49#define OMAP3ISP_AEWB_MAX_WIN_W 256
50#define OMAP3ISP_AEWB_MIN_WINVC 1
51#define OMAP3ISP_AEWB_MIN_WINHC 1
52#define OMAP3ISP_AEWB_MAX_WINVC 128
53/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
54#define OMAP3ISP_AEWB_MAX_WINHC 36
55#define OMAP3ISP_AEWB_MAX_WINSTART 4095
56#define OMAP3ISP_AEWB_MIN_SUB_INC 2
57#define OMAP3ISP_AEWB_MAX_SUB_INC 32
58/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
59#define OMAP3ISP_AEWB_MAX_BUF_SIZE 83600
60#define OMAP3ISP_AF_IIRSH_MIN 0
61#define OMAP3ISP_AF_IIRSH_MAX 4095
62#define OMAP3ISP_AF_PAXEL_HORIZONTAL_COUNT_MIN 1
63/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
64#define OMAP3ISP_AF_PAXEL_HORIZONTAL_COUNT_MAX 36
65#define OMAP3ISP_AF_PAXEL_VERTICAL_COUNT_MIN 1
66#define OMAP3ISP_AF_PAXEL_VERTICAL_COUNT_MAX 128
67#define OMAP3ISP_AF_PAXEL_INCREMENT_MIN 2
68/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
69#define OMAP3ISP_AF_PAXEL_INCREMENT_MAX 32
70#define OMAP3ISP_AF_PAXEL_HEIGHT_MIN 2
71#define OMAP3ISP_AF_PAXEL_HEIGHT_MAX 256
72#define OMAP3ISP_AF_PAXEL_WIDTH_MIN 16
73/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
74#define OMAP3ISP_AF_PAXEL_WIDTH_MAX 256
75#define OMAP3ISP_AF_PAXEL_HZSTART_MIN 1
76#define OMAP3ISP_AF_PAXEL_HZSTART_MAX 4095
77#define OMAP3ISP_AF_PAXEL_VTSTART_MIN 0
78/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
79#define OMAP3ISP_AF_PAXEL_VTSTART_MAX 4095
80#define OMAP3ISP_AF_THRESHOLD_MAX 255
81#define OMAP3ISP_AF_COEF_MAX 4095
82#define OMAP3ISP_AF_PAXEL_SIZE 48
83/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
84#define OMAP3ISP_AF_MAX_BUF_SIZE 221184
85struct omap3isp_h3a_aewb_config {
86 __u32 buf_size;
87 __u16 config_counter;
88/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
89 __u16 saturation_limit;
90 __u16 win_height;
91 __u16 win_width;
92 __u16 ver_win_count;
93/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
94 __u16 hor_win_count;
95 __u16 ver_win_start;
96 __u16 hor_win_start;
97 __u16 blk_ver_win_start;
98/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
99 __u16 blk_win_height;
100 __u16 subsample_ver_inc;
101 __u16 subsample_hor_inc;
102 __u8 alaw_enable;
103/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
104};
105struct omap3isp_stat_data {
106 struct timeval ts;
107 void __user *buf;
108/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
109 __u32 buf_size;
110 __u16 frame_number;
111 __u16 cur_frame;
112 __u16 config_counter;
113/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
114};
115#define OMAP3ISP_HIST_BINS_32 0
116#define OMAP3ISP_HIST_BINS_64 1
117#define OMAP3ISP_HIST_BINS_128 2
118/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
119#define OMAP3ISP_HIST_BINS_256 3
120#define OMAP3ISP_HIST_MEM_SIZE_BINS(n) ((1 << ((n)+5))*4*4)
121#define OMAP3ISP_HIST_MEM_SIZE 1024
122#define OMAP3ISP_HIST_MIN_REGIONS 1
123/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
124#define OMAP3ISP_HIST_MAX_REGIONS 4
125#define OMAP3ISP_HIST_MAX_WB_GAIN 255
126#define OMAP3ISP_HIST_MIN_WB_GAIN 0
127#define OMAP3ISP_HIST_MAX_BIT_WIDTH 14
128/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
129#define OMAP3ISP_HIST_MIN_BIT_WIDTH 8
130#define OMAP3ISP_HIST_MAX_WG 4
131#define OMAP3ISP_HIST_MAX_BUF_SIZE 4096
132#define OMAP3ISP_HIST_SOURCE_CCDC 0
133/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
134#define OMAP3ISP_HIST_SOURCE_MEM 1
135#define OMAP3ISP_HIST_CFA_BAYER 0
136#define OMAP3ISP_HIST_CFA_FOVEONX3 1
137struct omap3isp_hist_region {
138/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
139 __u16 h_start;
140 __u16 h_end;
141 __u16 v_start;
142 __u16 v_end;
143/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
144};
145struct omap3isp_hist_config {
146 __u32 buf_size;
147 __u16 config_counter;
148/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
149 __u8 num_acc_frames;
150 __u16 hist_bins;
151 __u8 cfa;
152 __u8 wg[OMAP3ISP_HIST_MAX_WG];
153/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
154 __u8 num_regions;
155 struct omap3isp_hist_region region[OMAP3ISP_HIST_MAX_REGIONS];
156};
157#define OMAP3ISP_AF_NUM_COEF 11
158/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
159enum omap3isp_h3a_af_fvmode {
160 OMAP3ISP_AF_MODE_SUMMED = 0,
161 OMAP3ISP_AF_MODE_PEAK = 1
162};
163/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
164enum omap3isp_h3a_af_rgbpos {
165 OMAP3ISP_AF_GR_GB_BAYER = 0,
166 OMAP3ISP_AF_RG_GB_BAYER = 1,
167 OMAP3ISP_AF_GR_BG_BAYER = 2,
168/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
169 OMAP3ISP_AF_RG_BG_BAYER = 3,
170 OMAP3ISP_AF_GG_RB_CUSTOM = 4,
171 OMAP3ISP_AF_RB_GG_CUSTOM = 5
172};
173/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
174struct omap3isp_h3a_af_hmf {
175 __u8 enable;
176 __u8 threshold;
177};
178/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
179struct omap3isp_h3a_af_iir {
180 __u16 h_start;
181 __u16 coeff_set0[OMAP3ISP_AF_NUM_COEF];
182 __u16 coeff_set1[OMAP3ISP_AF_NUM_COEF];
183/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
184};
185struct omap3isp_h3a_af_paxel {
186 __u16 h_start;
187 __u16 v_start;
188/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
189 __u8 width;
190 __u8 height;
191 __u8 h_cnt;
192 __u8 v_cnt;
193/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
194 __u8 line_inc;
195};
196struct omap3isp_h3a_af_config {
197 __u32 buf_size;
198/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
199 __u16 config_counter;
200 struct omap3isp_h3a_af_hmf hmf;
201 struct omap3isp_h3a_af_iir iir;
202 struct omap3isp_h3a_af_paxel paxel;
203/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
204 enum omap3isp_h3a_af_rgbpos rgb_pos;
205 enum omap3isp_h3a_af_fvmode fvmode;
206 __u8 alaw_enable;
207};
208/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
209#define OMAP3ISP_CCDC_ALAW (1 << 0)
210#define OMAP3ISP_CCDC_LPF (1 << 1)
211#define OMAP3ISP_CCDC_BLCLAMP (1 << 2)
212#define OMAP3ISP_CCDC_BCOMP (1 << 3)
213/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
214#define OMAP3ISP_CCDC_FPC (1 << 4)
215#define OMAP3ISP_CCDC_CULL (1 << 5)
216#define OMAP3ISP_CCDC_CONFIG_LSC (1 << 7)
217#define OMAP3ISP_CCDC_TBL_LSC (1 << 8)
218/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
219#define OMAP3ISP_RGB_MAX 3
220enum omap3isp_alaw_ipwidth {
221 OMAP3ISP_ALAW_BIT12_3 = 0x3,
222 OMAP3ISP_ALAW_BIT11_2 = 0x4,
223/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
224 OMAP3ISP_ALAW_BIT10_1 = 0x5,
225 OMAP3ISP_ALAW_BIT9_0 = 0x6
226};
227struct omap3isp_ccdc_lsc_config {
228/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
229 __u16 offset;
230 __u8 gain_mode_n;
231 __u8 gain_mode_m;
232 __u8 gain_format;
233/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
234 __u16 fmtsph;
235 __u16 fmtlnh;
236 __u16 fmtslv;
237 __u16 fmtlnv;
238/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
239 __u8 initial_x;
240 __u8 initial_y;
241 __u32 size;
242};
243/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
244struct omap3isp_ccdc_bclamp {
245 __u8 obgain;
246 __u8 obstpixel;
247 __u8 oblines;
248/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
249 __u8 oblen;
250 __u16 dcsubval;
251};
252struct omap3isp_ccdc_fpc {
253/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
254 __u16 fpnum;
255 __u32 fpcaddr;
256};
257struct omap3isp_ccdc_blcomp {
258/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
259 __u8 b_mg;
260 __u8 gb_g;
261 __u8 gr_cy;
262 __u8 r_ye;
263/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
264};
265struct omap3isp_ccdc_culling {
266 __u8 v_pattern;
267 __u16 h_odd;
268/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
269 __u16 h_even;
270};
271struct omap3isp_ccdc_update_config {
272 __u16 update;
273/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
274 __u16 flag;
275 enum omap3isp_alaw_ipwidth alawip;
276 struct omap3isp_ccdc_bclamp __user *bclamp;
277 struct omap3isp_ccdc_blcomp __user *blcomp;
278/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
279 struct omap3isp_ccdc_fpc __user *fpc;
280 struct omap3isp_ccdc_lsc_config __user *lsc_cfg;
281 struct omap3isp_ccdc_culling __user *cull;
282 __u8 __user *lsc;
283/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
284};
285#define OMAP3ISP_PREV_LUMAENH (1 << 0)
286#define OMAP3ISP_PREV_INVALAW (1 << 1)
287#define OMAP3ISP_PREV_HRZ_MED (1 << 2)
288/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
289#define OMAP3ISP_PREV_CFA (1 << 3)
290#define OMAP3ISP_PREV_CHROMA_SUPP (1 << 4)
291#define OMAP3ISP_PREV_WB (1 << 5)
292#define OMAP3ISP_PREV_BLKADJ (1 << 6)
293/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
294#define OMAP3ISP_PREV_RGB2RGB (1 << 7)
295#define OMAP3ISP_PREV_COLOR_CONV (1 << 8)
296#define OMAP3ISP_PREV_YC_LIMIT (1 << 9)
297#define OMAP3ISP_PREV_DEFECT_COR (1 << 10)
298/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
299#define OMAP3ISP_PREV_DRK_FRM_CAPTURE (1 << 12)
300#define OMAP3ISP_PREV_DRK_FRM_SUBTRACT (1 << 13)
301#define OMAP3ISP_PREV_LENS_SHADING (1 << 14)
302#define OMAP3ISP_PREV_NF (1 << 15)
303/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
304#define OMAP3ISP_PREV_GAMMA (1 << 16)
305#define OMAP3ISP_PREV_NF_TBL_SIZE 64
306#define OMAP3ISP_PREV_CFA_TBL_SIZE 576
307#define OMAP3ISP_PREV_CFA_BLK_SIZE (OMAP3ISP_PREV_CFA_TBL_SIZE / 4)
308/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
309#define OMAP3ISP_PREV_GAMMA_TBL_SIZE 1024
310#define OMAP3ISP_PREV_YENH_TBL_SIZE 128
311#define OMAP3ISP_PREV_DETECT_CORRECT_CHANNELS 4
312struct omap3isp_prev_hmed {
313/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
314 __u8 odddist;
315 __u8 evendist;
316 __u8 thres;
317};
318/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
319enum omap3isp_cfa_fmt {
320 OMAP3ISP_CFAFMT_BAYER,
321 OMAP3ISP_CFAFMT_SONYVGA,
322 OMAP3ISP_CFAFMT_RGBFOVEON,
323/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
324 OMAP3ISP_CFAFMT_DNSPL,
325 OMAP3ISP_CFAFMT_HONEYCOMB,
326 OMAP3ISP_CFAFMT_RRGGBBFOVEON
327};
328/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
329struct omap3isp_prev_cfa {
330 enum omap3isp_cfa_fmt format;
331 __u8 gradthrs_vert;
332 __u8 gradthrs_horz;
333/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
334 __u32 table[4][OMAP3ISP_PREV_CFA_BLK_SIZE];
335};
336struct omap3isp_prev_csup {
337 __u8 gain;
338/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
339 __u8 thres;
340 __u8 hypf_en;
341};
342struct omap3isp_prev_wbal {
343/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
344 __u16 dgain;
345 __u8 coef3;
346 __u8 coef2;
347 __u8 coef1;
348/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
349 __u8 coef0;
350};
351struct omap3isp_prev_blkadj {
352 __u8 red;
353/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
354 __u8 green;
355 __u8 blue;
356};
357struct omap3isp_prev_rgbtorgb {
358/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
359 __u16 matrix[OMAP3ISP_RGB_MAX][OMAP3ISP_RGB_MAX];
360 __u16 offset[OMAP3ISP_RGB_MAX];
361};
362struct omap3isp_prev_csc {
363/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
364 __u16 matrix[OMAP3ISP_RGB_MAX][OMAP3ISP_RGB_MAX];
365 __s16 offset[OMAP3ISP_RGB_MAX];
366};
367struct omap3isp_prev_yclimit {
368/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
369 __u8 minC;
370 __u8 maxC;
371 __u8 minY;
372 __u8 maxY;
373/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
374};
375struct omap3isp_prev_dcor {
376 __u8 couplet_mode_en;
377 __u32 detect_correct[OMAP3ISP_PREV_DETECT_CORRECT_CHANNELS];
378/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
379};
380struct omap3isp_prev_nf {
381 __u8 spread;
382 __u32 table[OMAP3ISP_PREV_NF_TBL_SIZE];
383/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
384};
385struct omap3isp_prev_gtables {
386 __u32 red[OMAP3ISP_PREV_GAMMA_TBL_SIZE];
387 __u32 green[OMAP3ISP_PREV_GAMMA_TBL_SIZE];
388/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
389 __u32 blue[OMAP3ISP_PREV_GAMMA_TBL_SIZE];
390};
391struct omap3isp_prev_luma {
392 __u32 table[OMAP3ISP_PREV_YENH_TBL_SIZE];
393/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
394};
395struct omap3isp_prev_update_config {
396 __u32 update;
397 __u32 flag;
398/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
399 __u32 shading_shift;
400 struct omap3isp_prev_luma __user *luma;
401 struct omap3isp_prev_hmed __user *hmed;
402 struct omap3isp_prev_cfa __user *cfa;
403/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
404 struct omap3isp_prev_csup __user *csup;
405 struct omap3isp_prev_wbal __user *wbal;
406 struct omap3isp_prev_blkadj __user *blkadj;
407 struct omap3isp_prev_rgbtorgb __user *rgb2rgb;
408/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
409 struct omap3isp_prev_csc __user *csc;
410 struct omap3isp_prev_yclimit __user *yclimit;
411 struct omap3isp_prev_dcor __user *dcor;
412 struct omap3isp_prev_nf __user *nf;
413/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
414 struct omap3isp_prev_gtables __user *gamma;
415};
416#endif
417