xref: /aosp_15_r20/bionic/libc/kernel/uapi/linux/am437x-vpfe.h (revision 8d67ca893c1523eb926b9080dbe4e2ffd2a27ba1)
1*8d67ca89SAndroid Build Coastguard Worker /*
2*8d67ca89SAndroid Build Coastguard Worker  * This file is auto-generated. Modifications will be lost.
3*8d67ca89SAndroid Build Coastguard Worker  *
4*8d67ca89SAndroid Build Coastguard Worker  * See https://android.googlesource.com/platform/bionic/+/master/libc/kernel/
5*8d67ca89SAndroid Build Coastguard Worker  * for more information.
6*8d67ca89SAndroid Build Coastguard Worker  */
7*8d67ca89SAndroid Build Coastguard Worker #ifndef AM437X_VPFE_USER_H
8*8d67ca89SAndroid Build Coastguard Worker #define AM437X_VPFE_USER_H
9*8d67ca89SAndroid Build Coastguard Worker #include <linux/videodev2.h>
10*8d67ca89SAndroid Build Coastguard Worker enum vpfe_ccdc_data_size {
11*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_DATA_16BITS = 0,
12*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_DATA_15BITS,
13*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_DATA_14BITS,
14*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_DATA_13BITS,
15*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_DATA_12BITS,
16*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_DATA_11BITS,
17*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_DATA_10BITS,
18*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_DATA_8BITS,
19*8d67ca89SAndroid Build Coastguard Worker };
20*8d67ca89SAndroid Build Coastguard Worker enum vpfe_ccdc_sample_length {
21*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_1PIXELS = 0,
22*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_2PIXELS,
23*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_4PIXELS,
24*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_8PIXELS,
25*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_16PIXELS,
26*8d67ca89SAndroid Build Coastguard Worker };
27*8d67ca89SAndroid Build Coastguard Worker enum vpfe_ccdc_sample_line {
28*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_1LINES = 0,
29*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_2LINES,
30*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_4LINES,
31*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_8LINES,
32*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_SAMPLE_16LINES,
33*8d67ca89SAndroid Build Coastguard Worker };
34*8d67ca89SAndroid Build Coastguard Worker enum vpfe_ccdc_gamma_width {
35*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_GAMMA_BITS_15_6 = 0,
36*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_GAMMA_BITS_14_5,
37*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_GAMMA_BITS_13_4,
38*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_GAMMA_BITS_12_3,
39*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_GAMMA_BITS_11_2,
40*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_GAMMA_BITS_10_1,
41*8d67ca89SAndroid Build Coastguard Worker   VPFE_CCDC_GAMMA_BITS_09_0,
42*8d67ca89SAndroid Build Coastguard Worker };
43*8d67ca89SAndroid Build Coastguard Worker struct vpfe_ccdc_a_law {
44*8d67ca89SAndroid Build Coastguard Worker   unsigned char enable;
45*8d67ca89SAndroid Build Coastguard Worker   enum vpfe_ccdc_gamma_width gamma_wd;
46*8d67ca89SAndroid Build Coastguard Worker };
47*8d67ca89SAndroid Build Coastguard Worker struct vpfe_ccdc_black_clamp {
48*8d67ca89SAndroid Build Coastguard Worker   unsigned char enable;
49*8d67ca89SAndroid Build Coastguard Worker   enum vpfe_ccdc_sample_length sample_pixel;
50*8d67ca89SAndroid Build Coastguard Worker   enum vpfe_ccdc_sample_line sample_ln;
51*8d67ca89SAndroid Build Coastguard Worker   unsigned short start_pixel;
52*8d67ca89SAndroid Build Coastguard Worker   unsigned short sgain;
53*8d67ca89SAndroid Build Coastguard Worker   unsigned short dc_sub;
54*8d67ca89SAndroid Build Coastguard Worker };
55*8d67ca89SAndroid Build Coastguard Worker struct vpfe_ccdc_black_compensation {
56*8d67ca89SAndroid Build Coastguard Worker   char r;
57*8d67ca89SAndroid Build Coastguard Worker   char gr;
58*8d67ca89SAndroid Build Coastguard Worker   char b;
59*8d67ca89SAndroid Build Coastguard Worker   char gb;
60*8d67ca89SAndroid Build Coastguard Worker };
61*8d67ca89SAndroid Build Coastguard Worker struct vpfe_ccdc_config_params_raw {
62*8d67ca89SAndroid Build Coastguard Worker   enum vpfe_ccdc_data_size data_sz;
63*8d67ca89SAndroid Build Coastguard Worker   struct vpfe_ccdc_a_law alaw;
64*8d67ca89SAndroid Build Coastguard Worker   struct vpfe_ccdc_black_clamp blk_clamp;
65*8d67ca89SAndroid Build Coastguard Worker   struct vpfe_ccdc_black_compensation blk_comp;
66*8d67ca89SAndroid Build Coastguard Worker };
67*8d67ca89SAndroid Build Coastguard Worker #define VIDIOC_AM437X_CCDC_CFG _IOW('V', BASE_VIDIOC_PRIVATE + 1, void *)
68*8d67ca89SAndroid Build Coastguard Worker #endif
69