1 /* SPDX-License-Identifier: ((GPL-2.0+ WITH Linux-syscall-note) OR BSD-3-Clause) */
2 /*
3  *  Video for Linux Two controls header file
4  *
5  *  Copyright (C) 1999-2012 the contributors
6  *
7  *  This program is free software; you can redistribute it and/or modify
8  *  it under the terms of the GNU General Public License as published by
9  *  the Free Software Foundation; either version 2 of the License, or
10  *  (at your option) any later version.
11  *
12  *  This program is distributed in the hope that it will be useful,
13  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
14  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  *  GNU General Public License for more details.
16  *
17  *  Alternatively you can redistribute this file under the terms of the
18  *  BSD license as stated below:
19  *
20  *  Redistribution and use in source and binary forms, with or without
21  *  modification, are permitted provided that the following conditions
22  *  are met:
23  *  1. Redistributions of source code must retain the above copyright
24  *     notice, this list of conditions and the following disclaimer.
25  *  2. Redistributions in binary form must reproduce the above copyright
26  *     notice, this list of conditions and the following disclaimer in
27  *     the documentation and/or other materials provided with the
28  *     distribution.
29  *  3. The names of its contributors may not be used to endorse or promote
30  *     products derived from this software without specific prior written
31  *     permission.
32  *
33  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
34  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
35  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
36  *  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
37  *  OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
38  *  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
39  *  TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
40  *  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
41  *  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
42  *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
43  *  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
44  *
45  *  The contents of this header was split off from videodev2.h. All control
46  *  definitions should be added to this header, which is included by
47  *  videodev2.h.
48  */
49 
50 #ifndef __LINUX_V4L2_CONTROLS_H
51 #define __LINUX_V4L2_CONTROLS_H
52 
53 #include <linux/types.h>
54 
55 /* Control classes */
56 #define V4L2_CTRL_CLASS_USER		0x00980000	/* Old-style 'user' controls */
57 #define V4L2_CTRL_CLASS_CODEC		0x00990000	/* Stateful codec controls */
58 #define V4L2_CTRL_CLASS_CAMERA		0x009a0000	/* Camera class controls */
59 #define V4L2_CTRL_CLASS_FM_TX		0x009b0000	/* FM Modulator controls */
60 #define V4L2_CTRL_CLASS_FLASH		0x009c0000	/* Camera flash controls */
61 #define V4L2_CTRL_CLASS_JPEG		0x009d0000	/* JPEG-compression controls */
62 #define V4L2_CTRL_CLASS_IMAGE_SOURCE	0x009e0000	/* Image source controls */
63 #define V4L2_CTRL_CLASS_IMAGE_PROC	0x009f0000	/* Image processing controls */
64 #define V4L2_CTRL_CLASS_DV		0x00a00000	/* Digital Video controls */
65 #define V4L2_CTRL_CLASS_FM_RX		0x00a10000	/* FM Receiver controls */
66 #define V4L2_CTRL_CLASS_RF_TUNER	0x00a20000	/* RF tuner controls */
67 #define V4L2_CTRL_CLASS_DETECT		0x00a30000	/* Detection controls */
68 #define V4L2_CTRL_CLASS_CODEC_STATELESS 0x00a40000	/* Stateless codecs controls */
69 
70 /* User-class control IDs */
71 
72 #define V4L2_CID_BASE			(V4L2_CTRL_CLASS_USER | 0x900)
73 #define V4L2_CID_USER_BASE		V4L2_CID_BASE
74 #define V4L2_CID_USER_CLASS		(V4L2_CTRL_CLASS_USER | 1)
75 #define V4L2_CID_BRIGHTNESS		(V4L2_CID_BASE+0)
76 #define V4L2_CID_CONTRAST		(V4L2_CID_BASE+1)
77 #define V4L2_CID_SATURATION		(V4L2_CID_BASE+2)
78 #define V4L2_CID_HUE			(V4L2_CID_BASE+3)
79 #define V4L2_CID_AUDIO_VOLUME		(V4L2_CID_BASE+5)
80 #define V4L2_CID_AUDIO_BALANCE		(V4L2_CID_BASE+6)
81 #define V4L2_CID_AUDIO_BASS		(V4L2_CID_BASE+7)
82 #define V4L2_CID_AUDIO_TREBLE		(V4L2_CID_BASE+8)
83 #define V4L2_CID_AUDIO_MUTE		(V4L2_CID_BASE+9)
84 #define V4L2_CID_AUDIO_LOUDNESS		(V4L2_CID_BASE+10)
85 #define V4L2_CID_BLACK_LEVEL		(V4L2_CID_BASE+11) /* Deprecated */
86 #define V4L2_CID_AUTO_WHITE_BALANCE	(V4L2_CID_BASE+12)
87 #define V4L2_CID_DO_WHITE_BALANCE	(V4L2_CID_BASE+13)
88 #define V4L2_CID_RED_BALANCE		(V4L2_CID_BASE+14)
89 #define V4L2_CID_BLUE_BALANCE		(V4L2_CID_BASE+15)
90 #define V4L2_CID_GAMMA			(V4L2_CID_BASE+16)
91 #define V4L2_CID_WHITENESS		(V4L2_CID_GAMMA) /* Deprecated */
92 #define V4L2_CID_EXPOSURE		(V4L2_CID_BASE+17)
93 #define V4L2_CID_AUTOGAIN		(V4L2_CID_BASE+18)
94 #define V4L2_CID_GAIN			(V4L2_CID_BASE+19)
95 #define V4L2_CID_HFLIP			(V4L2_CID_BASE+20)
96 #define V4L2_CID_VFLIP			(V4L2_CID_BASE+21)
97 
98 #define V4L2_CID_POWER_LINE_FREQUENCY	(V4L2_CID_BASE+24)
99 enum v4l2_power_line_frequency {
100 	V4L2_CID_POWER_LINE_FREQUENCY_DISABLED	= 0,
101 	V4L2_CID_POWER_LINE_FREQUENCY_50HZ	= 1,
102 	V4L2_CID_POWER_LINE_FREQUENCY_60HZ	= 2,
103 	V4L2_CID_POWER_LINE_FREQUENCY_AUTO	= 3,
104 };
105 #define V4L2_CID_HUE_AUTO			(V4L2_CID_BASE+25)
106 #define V4L2_CID_WHITE_BALANCE_TEMPERATURE	(V4L2_CID_BASE+26)
107 #define V4L2_CID_SHARPNESS			(V4L2_CID_BASE+27)
108 #define V4L2_CID_BACKLIGHT_COMPENSATION		(V4L2_CID_BASE+28)
109 #define V4L2_CID_CHROMA_AGC                     (V4L2_CID_BASE+29)
110 #define V4L2_CID_COLOR_KILLER                   (V4L2_CID_BASE+30)
111 #define V4L2_CID_COLORFX			(V4L2_CID_BASE+31)
112 enum v4l2_colorfx {
113 	V4L2_COLORFX_NONE			= 0,
114 	V4L2_COLORFX_BW				= 1,
115 	V4L2_COLORFX_SEPIA			= 2,
116 	V4L2_COLORFX_NEGATIVE			= 3,
117 	V4L2_COLORFX_EMBOSS			= 4,
118 	V4L2_COLORFX_SKETCH			= 5,
119 	V4L2_COLORFX_SKY_BLUE			= 6,
120 	V4L2_COLORFX_GRASS_GREEN		= 7,
121 	V4L2_COLORFX_SKIN_WHITEN		= 8,
122 	V4L2_COLORFX_VIVID			= 9,
123 	V4L2_COLORFX_AQUA			= 10,
124 	V4L2_COLORFX_ART_FREEZE			= 11,
125 	V4L2_COLORFX_SILHOUETTE			= 12,
126 	V4L2_COLORFX_SOLARIZATION		= 13,
127 	V4L2_COLORFX_ANTIQUE			= 14,
128 	V4L2_COLORFX_SET_CBCR			= 15,
129 };
130 #define V4L2_CID_AUTOBRIGHTNESS			(V4L2_CID_BASE+32)
131 #define V4L2_CID_BAND_STOP_FILTER		(V4L2_CID_BASE+33)
132 
133 #define V4L2_CID_ROTATE				(V4L2_CID_BASE+34)
134 #define V4L2_CID_BG_COLOR			(V4L2_CID_BASE+35)
135 
136 #define V4L2_CID_CHROMA_GAIN                    (V4L2_CID_BASE+36)
137 
138 #define V4L2_CID_ILLUMINATORS_1			(V4L2_CID_BASE+37)
139 #define V4L2_CID_ILLUMINATORS_2			(V4L2_CID_BASE+38)
140 
141 #define V4L2_CID_MIN_BUFFERS_FOR_CAPTURE	(V4L2_CID_BASE+39)
142 #define V4L2_CID_MIN_BUFFERS_FOR_OUTPUT		(V4L2_CID_BASE+40)
143 
144 #define V4L2_CID_ALPHA_COMPONENT		(V4L2_CID_BASE+41)
145 #define V4L2_CID_COLORFX_CBCR			(V4L2_CID_BASE+42)
146 
147 /* last CID + 1 */
148 #define V4L2_CID_LASTP1                         (V4L2_CID_BASE+43)
149 
150 /* USER-class private control IDs */
151 
152 /* The base for the meye driver controls. See linux/meye.h for the list
153  * of controls. We reserve 16 controls for this driver. */
154 #define V4L2_CID_USER_MEYE_BASE			(V4L2_CID_USER_BASE + 0x1000)
155 
156 /* The base for the bttv driver controls.
157  * We reserve 32 controls for this driver. */
158 #define V4L2_CID_USER_BTTV_BASE			(V4L2_CID_USER_BASE + 0x1010)
159 
160 
161 /* The base for the s2255 driver controls.
162  * We reserve 16 controls for this driver. */
163 #define V4L2_CID_USER_S2255_BASE		(V4L2_CID_USER_BASE + 0x1030)
164 
165 /*
166  * The base for the si476x driver controls. See include/media/drv-intf/si476x.h
167  * for the list of controls. Total of 16 controls is reserved for this driver
168  */
169 #define V4L2_CID_USER_SI476X_BASE		(V4L2_CID_USER_BASE + 0x1040)
170 
171 /* The base for the TI VPE driver controls. Total of 16 controls is reserved for
172  * this driver */
173 #define V4L2_CID_USER_TI_VPE_BASE		(V4L2_CID_USER_BASE + 0x1050)
174 
175 /* The base for the saa7134 driver controls.
176  * We reserve 16 controls for this driver. */
177 #define V4L2_CID_USER_SAA7134_BASE		(V4L2_CID_USER_BASE + 0x1060)
178 
179 /* The base for the adv7180 driver controls.
180  * We reserve 16 controls for this driver. */
181 #define V4L2_CID_USER_ADV7180_BASE		(V4L2_CID_USER_BASE + 0x1070)
182 
183 /* The base for the tc358743 driver controls.
184  * We reserve 16 controls for this driver. */
185 #define V4L2_CID_USER_TC358743_BASE		(V4L2_CID_USER_BASE + 0x1080)
186 
187 /* The base for the max217x driver controls.
188  * We reserve 32 controls for this driver
189  */
190 #define V4L2_CID_USER_MAX217X_BASE		(V4L2_CID_USER_BASE + 0x1090)
191 
192 /* The base for the imx driver controls.
193  * We reserve 16 controls for this driver. */
194 #define V4L2_CID_USER_IMX_BASE			(V4L2_CID_USER_BASE + 0x10b0)
195 
196 /*
197  * The base for the atmel isc driver controls.
198  * We reserve 32 controls for this driver.
199  */
200 #define V4L2_CID_USER_ATMEL_ISC_BASE		(V4L2_CID_USER_BASE + 0x10c0)
201 
202 /*
203  * The base for the CODA driver controls.
204  * We reserve 16 controls for this driver.
205  */
206 #define V4L2_CID_USER_CODA_BASE			(V4L2_CID_USER_BASE + 0x10e0)
207 /*
208  * The base for MIPI CCS driver controls.
209  * We reserve 128 controls for this driver.
210  */
211 #define V4L2_CID_USER_CCS_BASE			(V4L2_CID_USER_BASE + 0x10f0)
212 
213 /* MPEG-class control IDs */
214 /* The MPEG controls are applicable to all codec controls
215  * and the 'MPEG' part of the define is historical */
216 
217 #define V4L2_CID_CODEC_BASE			(V4L2_CTRL_CLASS_CODEC | 0x900)
218 #define V4L2_CID_CODEC_CLASS			(V4L2_CTRL_CLASS_CODEC | 1)
219 
220 /*  MPEG streams, specific to multiplexed streams */
221 #define V4L2_CID_MPEG_STREAM_TYPE		(V4L2_CID_CODEC_BASE+0)
222 enum v4l2_mpeg_stream_type {
223 	V4L2_MPEG_STREAM_TYPE_MPEG2_PS   = 0, /* MPEG-2 program stream */
224 	V4L2_MPEG_STREAM_TYPE_MPEG2_TS   = 1, /* MPEG-2 transport stream */
225 	V4L2_MPEG_STREAM_TYPE_MPEG1_SS   = 2, /* MPEG-1 system stream */
226 	V4L2_MPEG_STREAM_TYPE_MPEG2_DVD  = 3, /* MPEG-2 DVD-compatible stream */
227 	V4L2_MPEG_STREAM_TYPE_MPEG1_VCD  = 4, /* MPEG-1 VCD-compatible stream */
228 	V4L2_MPEG_STREAM_TYPE_MPEG2_SVCD = 5, /* MPEG-2 SVCD-compatible stream */
229 };
230 #define V4L2_CID_MPEG_STREAM_PID_PMT		(V4L2_CID_CODEC_BASE+1)
231 #define V4L2_CID_MPEG_STREAM_PID_AUDIO		(V4L2_CID_CODEC_BASE+2)
232 #define V4L2_CID_MPEG_STREAM_PID_VIDEO		(V4L2_CID_CODEC_BASE+3)
233 #define V4L2_CID_MPEG_STREAM_PID_PCR		(V4L2_CID_CODEC_BASE+4)
234 #define V4L2_CID_MPEG_STREAM_PES_ID_AUDIO	(V4L2_CID_CODEC_BASE+5)
235 #define V4L2_CID_MPEG_STREAM_PES_ID_VIDEO	(V4L2_CID_CODEC_BASE+6)
236 #define V4L2_CID_MPEG_STREAM_VBI_FMT		(V4L2_CID_CODEC_BASE+7)
237 enum v4l2_mpeg_stream_vbi_fmt {
238 	V4L2_MPEG_STREAM_VBI_FMT_NONE = 0,  /* No VBI in the MPEG stream */
239 	V4L2_MPEG_STREAM_VBI_FMT_IVTV = 1,  /* VBI in private packets, IVTV format */
240 };
241 
242 /*  MPEG audio controls specific to multiplexed streams  */
243 #define V4L2_CID_MPEG_AUDIO_SAMPLING_FREQ	(V4L2_CID_CODEC_BASE+100)
244 enum v4l2_mpeg_audio_sampling_freq {
245 	V4L2_MPEG_AUDIO_SAMPLING_FREQ_44100 = 0,
246 	V4L2_MPEG_AUDIO_SAMPLING_FREQ_48000 = 1,
247 	V4L2_MPEG_AUDIO_SAMPLING_FREQ_32000 = 2,
248 };
249 #define V4L2_CID_MPEG_AUDIO_ENCODING		(V4L2_CID_CODEC_BASE+101)
250 enum v4l2_mpeg_audio_encoding {
251 	V4L2_MPEG_AUDIO_ENCODING_LAYER_1 = 0,
252 	V4L2_MPEG_AUDIO_ENCODING_LAYER_2 = 1,
253 	V4L2_MPEG_AUDIO_ENCODING_LAYER_3 = 2,
254 	V4L2_MPEG_AUDIO_ENCODING_AAC     = 3,
255 	V4L2_MPEG_AUDIO_ENCODING_AC3     = 4,
256 };
257 #define V4L2_CID_MPEG_AUDIO_L1_BITRATE		(V4L2_CID_CODEC_BASE+102)
258 enum v4l2_mpeg_audio_l1_bitrate {
259 	V4L2_MPEG_AUDIO_L1_BITRATE_32K  = 0,
260 	V4L2_MPEG_AUDIO_L1_BITRATE_64K  = 1,
261 	V4L2_MPEG_AUDIO_L1_BITRATE_96K  = 2,
262 	V4L2_MPEG_AUDIO_L1_BITRATE_128K = 3,
263 	V4L2_MPEG_AUDIO_L1_BITRATE_160K = 4,
264 	V4L2_MPEG_AUDIO_L1_BITRATE_192K = 5,
265 	V4L2_MPEG_AUDIO_L1_BITRATE_224K = 6,
266 	V4L2_MPEG_AUDIO_L1_BITRATE_256K = 7,
267 	V4L2_MPEG_AUDIO_L1_BITRATE_288K = 8,
268 	V4L2_MPEG_AUDIO_L1_BITRATE_320K = 9,
269 	V4L2_MPEG_AUDIO_L1_BITRATE_352K = 10,
270 	V4L2_MPEG_AUDIO_L1_BITRATE_384K = 11,
271 	V4L2_MPEG_AUDIO_L1_BITRATE_416K = 12,
272 	V4L2_MPEG_AUDIO_L1_BITRATE_448K = 13,
273 };
274 #define V4L2_CID_MPEG_AUDIO_L2_BITRATE		(V4L2_CID_CODEC_BASE+103)
275 enum v4l2_mpeg_audio_l2_bitrate {
276 	V4L2_MPEG_AUDIO_L2_BITRATE_32K  = 0,
277 	V4L2_MPEG_AUDIO_L2_BITRATE_48K  = 1,
278 	V4L2_MPEG_AUDIO_L2_BITRATE_56K  = 2,
279 	V4L2_MPEG_AUDIO_L2_BITRATE_64K  = 3,
280 	V4L2_MPEG_AUDIO_L2_BITRATE_80K  = 4,
281 	V4L2_MPEG_AUDIO_L2_BITRATE_96K  = 5,
282 	V4L2_MPEG_AUDIO_L2_BITRATE_112K = 6,
283 	V4L2_MPEG_AUDIO_L2_BITRATE_128K = 7,
284 	V4L2_MPEG_AUDIO_L2_BITRATE_160K = 8,
285 	V4L2_MPEG_AUDIO_L2_BITRATE_192K = 9,
286 	V4L2_MPEG_AUDIO_L2_BITRATE_224K = 10,
287 	V4L2_MPEG_AUDIO_L2_BITRATE_256K = 11,
288 	V4L2_MPEG_AUDIO_L2_BITRATE_320K = 12,
289 	V4L2_MPEG_AUDIO_L2_BITRATE_384K = 13,
290 };
291 #define V4L2_CID_MPEG_AUDIO_L3_BITRATE		(V4L2_CID_CODEC_BASE+104)
292 enum v4l2_mpeg_audio_l3_bitrate {
293 	V4L2_MPEG_AUDIO_L3_BITRATE_32K  = 0,
294 	V4L2_MPEG_AUDIO_L3_BITRATE_40K  = 1,
295 	V4L2_MPEG_AUDIO_L3_BITRATE_48K  = 2,
296 	V4L2_MPEG_AUDIO_L3_BITRATE_56K  = 3,
297 	V4L2_MPEG_AUDIO_L3_BITRATE_64K  = 4,
298 	V4L2_MPEG_AUDIO_L3_BITRATE_80K  = 5,
299 	V4L2_MPEG_AUDIO_L3_BITRATE_96K  = 6,
300 	V4L2_MPEG_AUDIO_L3_BITRATE_112K = 7,
301 	V4L2_MPEG_AUDIO_L3_BITRATE_128K = 8,
302 	V4L2_MPEG_AUDIO_L3_BITRATE_160K = 9,
303 	V4L2_MPEG_AUDIO_L3_BITRATE_192K = 10,
304 	V4L2_MPEG_AUDIO_L3_BITRATE_224K = 11,
305 	V4L2_MPEG_AUDIO_L3_BITRATE_256K = 12,
306 	V4L2_MPEG_AUDIO_L3_BITRATE_320K = 13,
307 };
308 #define V4L2_CID_MPEG_AUDIO_MODE		(V4L2_CID_CODEC_BASE+105)
309 enum v4l2_mpeg_audio_mode {
310 	V4L2_MPEG_AUDIO_MODE_STEREO       = 0,
311 	V4L2_MPEG_AUDIO_MODE_JOINT_STEREO = 1,
312 	V4L2_MPEG_AUDIO_MODE_DUAL         = 2,
313 	V4L2_MPEG_AUDIO_MODE_MONO         = 3,
314 };
315 #define V4L2_CID_MPEG_AUDIO_MODE_EXTENSION	(V4L2_CID_CODEC_BASE+106)
316 enum v4l2_mpeg_audio_mode_extension {
317 	V4L2_MPEG_AUDIO_MODE_EXTENSION_BOUND_4  = 0,
318 	V4L2_MPEG_AUDIO_MODE_EXTENSION_BOUND_8  = 1,
319 	V4L2_MPEG_AUDIO_MODE_EXTENSION_BOUND_12 = 2,
320 	V4L2_MPEG_AUDIO_MODE_EXTENSION_BOUND_16 = 3,
321 };
322 #define V4L2_CID_MPEG_AUDIO_EMPHASIS		(V4L2_CID_CODEC_BASE+107)
323 enum v4l2_mpeg_audio_emphasis {
324 	V4L2_MPEG_AUDIO_EMPHASIS_NONE         = 0,
325 	V4L2_MPEG_AUDIO_EMPHASIS_50_DIV_15_uS = 1,
326 	V4L2_MPEG_AUDIO_EMPHASIS_CCITT_J17    = 2,
327 };
328 #define V4L2_CID_MPEG_AUDIO_CRC			(V4L2_CID_CODEC_BASE+108)
329 enum v4l2_mpeg_audio_crc {
330 	V4L2_MPEG_AUDIO_CRC_NONE  = 0,
331 	V4L2_MPEG_AUDIO_CRC_CRC16 = 1,
332 };
333 #define V4L2_CID_MPEG_AUDIO_MUTE		(V4L2_CID_CODEC_BASE+109)
334 #define V4L2_CID_MPEG_AUDIO_AAC_BITRATE		(V4L2_CID_CODEC_BASE+110)
335 #define V4L2_CID_MPEG_AUDIO_AC3_BITRATE		(V4L2_CID_CODEC_BASE+111)
336 enum v4l2_mpeg_audio_ac3_bitrate {
337 	V4L2_MPEG_AUDIO_AC3_BITRATE_32K  = 0,
338 	V4L2_MPEG_AUDIO_AC3_BITRATE_40K  = 1,
339 	V4L2_MPEG_AUDIO_AC3_BITRATE_48K  = 2,
340 	V4L2_MPEG_AUDIO_AC3_BITRATE_56K  = 3,
341 	V4L2_MPEG_AUDIO_AC3_BITRATE_64K  = 4,
342 	V4L2_MPEG_AUDIO_AC3_BITRATE_80K  = 5,
343 	V4L2_MPEG_AUDIO_AC3_BITRATE_96K  = 6,
344 	V4L2_MPEG_AUDIO_AC3_BITRATE_112K = 7,
345 	V4L2_MPEG_AUDIO_AC3_BITRATE_128K = 8,
346 	V4L2_MPEG_AUDIO_AC3_BITRATE_160K = 9,
347 	V4L2_MPEG_AUDIO_AC3_BITRATE_192K = 10,
348 	V4L2_MPEG_AUDIO_AC3_BITRATE_224K = 11,
349 	V4L2_MPEG_AUDIO_AC3_BITRATE_256K = 12,
350 	V4L2_MPEG_AUDIO_AC3_BITRATE_320K = 13,
351 	V4L2_MPEG_AUDIO_AC3_BITRATE_384K = 14,
352 	V4L2_MPEG_AUDIO_AC3_BITRATE_448K = 15,
353 	V4L2_MPEG_AUDIO_AC3_BITRATE_512K = 16,
354 	V4L2_MPEG_AUDIO_AC3_BITRATE_576K = 17,
355 	V4L2_MPEG_AUDIO_AC3_BITRATE_640K = 18,
356 };
357 #define V4L2_CID_MPEG_AUDIO_DEC_PLAYBACK	(V4L2_CID_CODEC_BASE+112)
358 enum v4l2_mpeg_audio_dec_playback {
359 	V4L2_MPEG_AUDIO_DEC_PLAYBACK_AUTO	    = 0,
360 	V4L2_MPEG_AUDIO_DEC_PLAYBACK_STEREO	    = 1,
361 	V4L2_MPEG_AUDIO_DEC_PLAYBACK_LEFT	    = 2,
362 	V4L2_MPEG_AUDIO_DEC_PLAYBACK_RIGHT	    = 3,
363 	V4L2_MPEG_AUDIO_DEC_PLAYBACK_MONO	    = 4,
364 	V4L2_MPEG_AUDIO_DEC_PLAYBACK_SWAPPED_STEREO = 5,
365 };
366 #define V4L2_CID_MPEG_AUDIO_DEC_MULTILINGUAL_PLAYBACK (V4L2_CID_CODEC_BASE+113)
367 
368 /*  MPEG video controls specific to multiplexed streams */
369 #define V4L2_CID_MPEG_VIDEO_ENCODING		(V4L2_CID_CODEC_BASE+200)
370 enum v4l2_mpeg_video_encoding {
371 	V4L2_MPEG_VIDEO_ENCODING_MPEG_1     = 0,
372 	V4L2_MPEG_VIDEO_ENCODING_MPEG_2     = 1,
373 	V4L2_MPEG_VIDEO_ENCODING_MPEG_4_AVC = 2,
374 };
375 #define V4L2_CID_MPEG_VIDEO_ASPECT		(V4L2_CID_CODEC_BASE+201)
376 enum v4l2_mpeg_video_aspect {
377 	V4L2_MPEG_VIDEO_ASPECT_1x1     = 0,
378 	V4L2_MPEG_VIDEO_ASPECT_4x3     = 1,
379 	V4L2_MPEG_VIDEO_ASPECT_16x9    = 2,
380 	V4L2_MPEG_VIDEO_ASPECT_221x100 = 3,
381 };
382 #define V4L2_CID_MPEG_VIDEO_B_FRAMES		(V4L2_CID_CODEC_BASE+202)
383 #define V4L2_CID_MPEG_VIDEO_GOP_SIZE		(V4L2_CID_CODEC_BASE+203)
384 #define V4L2_CID_MPEG_VIDEO_GOP_CLOSURE		(V4L2_CID_CODEC_BASE+204)
385 #define V4L2_CID_MPEG_VIDEO_PULLDOWN		(V4L2_CID_CODEC_BASE+205)
386 #define V4L2_CID_MPEG_VIDEO_BITRATE_MODE	(V4L2_CID_CODEC_BASE+206)
387 enum v4l2_mpeg_video_bitrate_mode {
388 	V4L2_MPEG_VIDEO_BITRATE_MODE_VBR = 0,
389 	V4L2_MPEG_VIDEO_BITRATE_MODE_CBR = 1,
390 	V4L2_MPEG_VIDEO_BITRATE_MODE_CQ  = 2,
391 };
392 #define V4L2_CID_MPEG_VIDEO_BITRATE		(V4L2_CID_CODEC_BASE+207)
393 #define V4L2_CID_MPEG_VIDEO_BITRATE_PEAK	(V4L2_CID_CODEC_BASE+208)
394 #define V4L2_CID_MPEG_VIDEO_TEMPORAL_DECIMATION (V4L2_CID_CODEC_BASE+209)
395 #define V4L2_CID_MPEG_VIDEO_MUTE		(V4L2_CID_CODEC_BASE+210)
396 #define V4L2_CID_MPEG_VIDEO_MUTE_YUV		(V4L2_CID_CODEC_BASE+211)
397 #define V4L2_CID_MPEG_VIDEO_DECODER_SLICE_INTERFACE		(V4L2_CID_CODEC_BASE+212)
398 #define V4L2_CID_MPEG_VIDEO_DECODER_MPEG4_DEBLOCK_FILTER	(V4L2_CID_CODEC_BASE+213)
399 #define V4L2_CID_MPEG_VIDEO_CYCLIC_INTRA_REFRESH_MB		(V4L2_CID_CODEC_BASE+214)
400 #define V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE			(V4L2_CID_CODEC_BASE+215)
401 #define V4L2_CID_MPEG_VIDEO_HEADER_MODE				(V4L2_CID_CODEC_BASE+216)
402 enum v4l2_mpeg_video_header_mode {
403 	V4L2_MPEG_VIDEO_HEADER_MODE_SEPARATE			= 0,
404 	V4L2_MPEG_VIDEO_HEADER_MODE_JOINED_WITH_1ST_FRAME	= 1,
405 
406 };
407 #define V4L2_CID_MPEG_VIDEO_MAX_REF_PIC			(V4L2_CID_CODEC_BASE+217)
408 #define V4L2_CID_MPEG_VIDEO_MB_RC_ENABLE		(V4L2_CID_CODEC_BASE+218)
409 #define V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_BYTES	(V4L2_CID_CODEC_BASE+219)
410 #define V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MAX_MB		(V4L2_CID_CODEC_BASE+220)
411 #define V4L2_CID_MPEG_VIDEO_MULTI_SLICE_MODE		(V4L2_CID_CODEC_BASE+221)
412 enum v4l2_mpeg_video_multi_slice_mode {
413 	V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_SINGLE		= 0,
414 	V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_MB		= 1,
415 	V4L2_MPEG_VIDEO_MULTI_SLICE_MODE_MAX_BYTES	= 2,
416 #ifndef __KERNEL__
417 	/* Kept for backwards compatibility reasons. Stupid typo... */
418 	V4L2_MPEG_VIDEO_MULTI_SICE_MODE_MAX_MB		= 1,
419 	V4L2_MPEG_VIDEO_MULTI_SICE_MODE_MAX_BYTES	= 2,
420 #endif
421 };
422 #define V4L2_CID_MPEG_VIDEO_VBV_SIZE			(V4L2_CID_CODEC_BASE+222)
423 #define V4L2_CID_MPEG_VIDEO_DEC_PTS			(V4L2_CID_CODEC_BASE+223)
424 #define V4L2_CID_MPEG_VIDEO_DEC_FRAME			(V4L2_CID_CODEC_BASE+224)
425 #define V4L2_CID_MPEG_VIDEO_VBV_DELAY			(V4L2_CID_CODEC_BASE+225)
426 #define V4L2_CID_MPEG_VIDEO_REPEAT_SEQ_HEADER		(V4L2_CID_CODEC_BASE+226)
427 #define V4L2_CID_MPEG_VIDEO_MV_H_SEARCH_RANGE		(V4L2_CID_CODEC_BASE+227)
428 #define V4L2_CID_MPEG_VIDEO_MV_V_SEARCH_RANGE		(V4L2_CID_CODEC_BASE+228)
429 #define V4L2_CID_MPEG_VIDEO_FORCE_KEY_FRAME		(V4L2_CID_CODEC_BASE+229)
430 
431 /* CIDs for the MPEG-2 Part 2 (H.262) codec */
432 #define V4L2_CID_MPEG_VIDEO_MPEG2_LEVEL			(V4L2_CID_CODEC_BASE+270)
433 enum v4l2_mpeg_video_mpeg2_level {
434 	V4L2_MPEG_VIDEO_MPEG2_LEVEL_LOW		= 0,
435 	V4L2_MPEG_VIDEO_MPEG2_LEVEL_MAIN	= 1,
436 	V4L2_MPEG_VIDEO_MPEG2_LEVEL_HIGH_1440	= 2,
437 	V4L2_MPEG_VIDEO_MPEG2_LEVEL_HIGH	= 3,
438 };
439 #define V4L2_CID_MPEG_VIDEO_MPEG2_PROFILE		(V4L2_CID_CODEC_BASE+271)
440 enum v4l2_mpeg_video_mpeg2_profile {
441 	V4L2_MPEG_VIDEO_MPEG2_PROFILE_SIMPLE				= 0,
442 	V4L2_MPEG_VIDEO_MPEG2_PROFILE_MAIN				= 1,
443 	V4L2_MPEG_VIDEO_MPEG2_PROFILE_SNR_SCALABLE			= 2,
444 	V4L2_MPEG_VIDEO_MPEG2_PROFILE_SPATIALLY_SCALABLE		= 3,
445 	V4L2_MPEG_VIDEO_MPEG2_PROFILE_HIGH				= 4,
446 	V4L2_MPEG_VIDEO_MPEG2_PROFILE_MULTIVIEW				= 5,
447 };
448 
449 /* CIDs for the FWHT codec as used by the vicodec driver. */
450 #define V4L2_CID_FWHT_I_FRAME_QP             (V4L2_CID_CODEC_BASE + 290)
451 #define V4L2_CID_FWHT_P_FRAME_QP             (V4L2_CID_CODEC_BASE + 291)
452 
453 #define V4L2_CID_MPEG_VIDEO_H263_I_FRAME_QP		(V4L2_CID_CODEC_BASE+300)
454 #define V4L2_CID_MPEG_VIDEO_H263_P_FRAME_QP		(V4L2_CID_CODEC_BASE+301)
455 #define V4L2_CID_MPEG_VIDEO_H263_B_FRAME_QP		(V4L2_CID_CODEC_BASE+302)
456 #define V4L2_CID_MPEG_VIDEO_H263_MIN_QP			(V4L2_CID_CODEC_BASE+303)
457 #define V4L2_CID_MPEG_VIDEO_H263_MAX_QP			(V4L2_CID_CODEC_BASE+304)
458 #define V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP		(V4L2_CID_CODEC_BASE+350)
459 #define V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP		(V4L2_CID_CODEC_BASE+351)
460 #define V4L2_CID_MPEG_VIDEO_H264_B_FRAME_QP		(V4L2_CID_CODEC_BASE+352)
461 #define V4L2_CID_MPEG_VIDEO_H264_MIN_QP			(V4L2_CID_CODEC_BASE+353)
462 #define V4L2_CID_MPEG_VIDEO_H264_MAX_QP			(V4L2_CID_CODEC_BASE+354)
463 #define V4L2_CID_MPEG_VIDEO_H264_8X8_TRANSFORM		(V4L2_CID_CODEC_BASE+355)
464 #define V4L2_CID_MPEG_VIDEO_H264_CPB_SIZE		(V4L2_CID_CODEC_BASE+356)
465 #define V4L2_CID_MPEG_VIDEO_H264_ENTROPY_MODE		(V4L2_CID_CODEC_BASE+357)
466 enum v4l2_mpeg_video_h264_entropy_mode {
467 	V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CAVLC	= 0,
468 	V4L2_MPEG_VIDEO_H264_ENTROPY_MODE_CABAC	= 1,
469 };
470 #define V4L2_CID_MPEG_VIDEO_H264_I_PERIOD		(V4L2_CID_CODEC_BASE+358)
471 #define V4L2_CID_MPEG_VIDEO_H264_LEVEL			(V4L2_CID_CODEC_BASE+359)
472 enum v4l2_mpeg_video_h264_level {
473 	V4L2_MPEG_VIDEO_H264_LEVEL_1_0	= 0,
474 	V4L2_MPEG_VIDEO_H264_LEVEL_1B	= 1,
475 	V4L2_MPEG_VIDEO_H264_LEVEL_1_1	= 2,
476 	V4L2_MPEG_VIDEO_H264_LEVEL_1_2	= 3,
477 	V4L2_MPEG_VIDEO_H264_LEVEL_1_3	= 4,
478 	V4L2_MPEG_VIDEO_H264_LEVEL_2_0	= 5,
479 	V4L2_MPEG_VIDEO_H264_LEVEL_2_1	= 6,
480 	V4L2_MPEG_VIDEO_H264_LEVEL_2_2	= 7,
481 	V4L2_MPEG_VIDEO_H264_LEVEL_3_0	= 8,
482 	V4L2_MPEG_VIDEO_H264_LEVEL_3_1	= 9,
483 	V4L2_MPEG_VIDEO_H264_LEVEL_3_2	= 10,
484 	V4L2_MPEG_VIDEO_H264_LEVEL_4_0	= 11,
485 	V4L2_MPEG_VIDEO_H264_LEVEL_4_1	= 12,
486 	V4L2_MPEG_VIDEO_H264_LEVEL_4_2	= 13,
487 	V4L2_MPEG_VIDEO_H264_LEVEL_5_0	= 14,
488 	V4L2_MPEG_VIDEO_H264_LEVEL_5_1	= 15,
489 	V4L2_MPEG_VIDEO_H264_LEVEL_5_2	= 16,
490 	V4L2_MPEG_VIDEO_H264_LEVEL_6_0	= 17,
491 	V4L2_MPEG_VIDEO_H264_LEVEL_6_1	= 18,
492 	V4L2_MPEG_VIDEO_H264_LEVEL_6_2	= 19,
493 };
494 #define V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_ALPHA	(V4L2_CID_CODEC_BASE+360)
495 #define V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_BETA	(V4L2_CID_CODEC_BASE+361)
496 #define V4L2_CID_MPEG_VIDEO_H264_LOOP_FILTER_MODE	(V4L2_CID_CODEC_BASE+362)
497 enum v4l2_mpeg_video_h264_loop_filter_mode {
498 	V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_ENABLED				= 0,
499 	V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_DISABLED				= 1,
500 	V4L2_MPEG_VIDEO_H264_LOOP_FILTER_MODE_DISABLED_AT_SLICE_BOUNDARY	= 2,
501 };
502 #define V4L2_CID_MPEG_VIDEO_H264_PROFILE		(V4L2_CID_CODEC_BASE+363)
503 enum v4l2_mpeg_video_h264_profile {
504 	V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE			= 0,
505 	V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_BASELINE	= 1,
506 	V4L2_MPEG_VIDEO_H264_PROFILE_MAIN			= 2,
507 	V4L2_MPEG_VIDEO_H264_PROFILE_EXTENDED			= 3,
508 	V4L2_MPEG_VIDEO_H264_PROFILE_HIGH			= 4,
509 	V4L2_MPEG_VIDEO_H264_PROFILE_HIGH_10			= 5,
510 	V4L2_MPEG_VIDEO_H264_PROFILE_HIGH_422			= 6,
511 	V4L2_MPEG_VIDEO_H264_PROFILE_HIGH_444_PREDICTIVE	= 7,
512 	V4L2_MPEG_VIDEO_H264_PROFILE_HIGH_10_INTRA		= 8,
513 	V4L2_MPEG_VIDEO_H264_PROFILE_HIGH_422_INTRA		= 9,
514 	V4L2_MPEG_VIDEO_H264_PROFILE_HIGH_444_INTRA		= 10,
515 	V4L2_MPEG_VIDEO_H264_PROFILE_CAVLC_444_INTRA		= 11,
516 	V4L2_MPEG_VIDEO_H264_PROFILE_SCALABLE_BASELINE		= 12,
517 	V4L2_MPEG_VIDEO_H264_PROFILE_SCALABLE_HIGH		= 13,
518 	V4L2_MPEG_VIDEO_H264_PROFILE_SCALABLE_HIGH_INTRA	= 14,
519 	V4L2_MPEG_VIDEO_H264_PROFILE_STEREO_HIGH		= 15,
520 	V4L2_MPEG_VIDEO_H264_PROFILE_MULTIVIEW_HIGH		= 16,
521 	V4L2_MPEG_VIDEO_H264_PROFILE_CONSTRAINED_HIGH		= 17,
522 };
523 #define V4L2_CID_MPEG_VIDEO_H264_VUI_EXT_SAR_HEIGHT	(V4L2_CID_CODEC_BASE+364)
524 #define V4L2_CID_MPEG_VIDEO_H264_VUI_EXT_SAR_WIDTH	(V4L2_CID_CODEC_BASE+365)
525 #define V4L2_CID_MPEG_VIDEO_H264_VUI_SAR_ENABLE		(V4L2_CID_CODEC_BASE+366)
526 #define V4L2_CID_MPEG_VIDEO_H264_VUI_SAR_IDC		(V4L2_CID_CODEC_BASE+367)
527 enum v4l2_mpeg_video_h264_vui_sar_idc {
528 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_UNSPECIFIED	= 0,
529 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_1x1		= 1,
530 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_12x11		= 2,
531 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_10x11		= 3,
532 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_16x11		= 4,
533 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_40x33		= 5,
534 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_24x11		= 6,
535 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_20x11		= 7,
536 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_32x11		= 8,
537 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_80x33		= 9,
538 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_18x11		= 10,
539 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_15x11		= 11,
540 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_64x33		= 12,
541 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_160x99		= 13,
542 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_4x3		= 14,
543 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_3x2		= 15,
544 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_2x1		= 16,
545 	V4L2_MPEG_VIDEO_H264_VUI_SAR_IDC_EXTENDED	= 17,
546 };
547 #define V4L2_CID_MPEG_VIDEO_H264_SEI_FRAME_PACKING		(V4L2_CID_CODEC_BASE+368)
548 #define V4L2_CID_MPEG_VIDEO_H264_SEI_FP_CURRENT_FRAME_0		(V4L2_CID_CODEC_BASE+369)
549 #define V4L2_CID_MPEG_VIDEO_H264_SEI_FP_ARRANGEMENT_TYPE	(V4L2_CID_CODEC_BASE+370)
550 enum v4l2_mpeg_video_h264_sei_fp_arrangement_type {
551 	V4L2_MPEG_VIDEO_H264_SEI_FP_ARRANGEMENT_TYPE_CHECKERBOARD	= 0,
552 	V4L2_MPEG_VIDEO_H264_SEI_FP_ARRANGEMENT_TYPE_COLUMN		= 1,
553 	V4L2_MPEG_VIDEO_H264_SEI_FP_ARRANGEMENT_TYPE_ROW		= 2,
554 	V4L2_MPEG_VIDEO_H264_SEI_FP_ARRANGEMENT_TYPE_SIDE_BY_SIDE	= 3,
555 	V4L2_MPEG_VIDEO_H264_SEI_FP_ARRANGEMENT_TYPE_TOP_BOTTOM		= 4,
556 	V4L2_MPEG_VIDEO_H264_SEI_FP_ARRANGEMENT_TYPE_TEMPORAL		= 5,
557 };
558 #define V4L2_CID_MPEG_VIDEO_H264_FMO			(V4L2_CID_CODEC_BASE+371)
559 #define V4L2_CID_MPEG_VIDEO_H264_FMO_MAP_TYPE		(V4L2_CID_CODEC_BASE+372)
560 enum v4l2_mpeg_video_h264_fmo_map_type {
561 	V4L2_MPEG_VIDEO_H264_FMO_MAP_TYPE_INTERLEAVED_SLICES		= 0,
562 	V4L2_MPEG_VIDEO_H264_FMO_MAP_TYPE_SCATTERED_SLICES		= 1,
563 	V4L2_MPEG_VIDEO_H264_FMO_MAP_TYPE_FOREGROUND_WITH_LEFT_OVER	= 2,
564 	V4L2_MPEG_VIDEO_H264_FMO_MAP_TYPE_BOX_OUT			= 3,
565 	V4L2_MPEG_VIDEO_H264_FMO_MAP_TYPE_RASTER_SCAN			= 4,
566 	V4L2_MPEG_VIDEO_H264_FMO_MAP_TYPE_WIPE_SCAN			= 5,
567 	V4L2_MPEG_VIDEO_H264_FMO_MAP_TYPE_EXPLICIT			= 6,
568 };
569 #define V4L2_CID_MPEG_VIDEO_H264_FMO_SLICE_GROUP	(V4L2_CID_CODEC_BASE+373)
570 #define V4L2_CID_MPEG_VIDEO_H264_FMO_CHANGE_DIRECTION	(V4L2_CID_CODEC_BASE+374)
571 enum v4l2_mpeg_video_h264_fmo_change_dir {
572 	V4L2_MPEG_VIDEO_H264_FMO_CHANGE_DIR_RIGHT	= 0,
573 	V4L2_MPEG_VIDEO_H264_FMO_CHANGE_DIR_LEFT	= 1,
574 };
575 #define V4L2_CID_MPEG_VIDEO_H264_FMO_CHANGE_RATE	(V4L2_CID_CODEC_BASE+375)
576 #define V4L2_CID_MPEG_VIDEO_H264_FMO_RUN_LENGTH		(V4L2_CID_CODEC_BASE+376)
577 #define V4L2_CID_MPEG_VIDEO_H264_ASO			(V4L2_CID_CODEC_BASE+377)
578 #define V4L2_CID_MPEG_VIDEO_H264_ASO_SLICE_ORDER	(V4L2_CID_CODEC_BASE+378)
579 #define V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING		(V4L2_CID_CODEC_BASE+379)
580 #define V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_TYPE	(V4L2_CID_CODEC_BASE+380)
581 enum v4l2_mpeg_video_h264_hierarchical_coding_type {
582 	V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_B	= 0,
583 	V4L2_MPEG_VIDEO_H264_HIERARCHICAL_CODING_P	= 1,
584 };
585 #define V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_LAYER	(V4L2_CID_CODEC_BASE+381)
586 #define V4L2_CID_MPEG_VIDEO_H264_HIERARCHICAL_CODING_LAYER_QP	(V4L2_CID_CODEC_BASE+382)
587 #define V4L2_CID_MPEG_VIDEO_H264_CONSTRAINED_INTRA_PREDICTION	(V4L2_CID_CODEC_BASE+383)
588 #define V4L2_CID_MPEG_VIDEO_H264_CHROMA_QP_INDEX_OFFSET		(V4L2_CID_CODEC_BASE+384)
589 #define V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MIN_QP	(V4L2_CID_CODEC_BASE+385)
590 #define V4L2_CID_MPEG_VIDEO_H264_I_FRAME_MAX_QP	(V4L2_CID_CODEC_BASE+386)
591 #define V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MIN_QP	(V4L2_CID_CODEC_BASE+387)
592 #define V4L2_CID_MPEG_VIDEO_H264_P_FRAME_MAX_QP	(V4L2_CID_CODEC_BASE+388)
593 #define V4L2_CID_MPEG_VIDEO_MPEG4_I_FRAME_QP	(V4L2_CID_CODEC_BASE+400)
594 #define V4L2_CID_MPEG_VIDEO_MPEG4_P_FRAME_QP	(V4L2_CID_CODEC_BASE+401)
595 #define V4L2_CID_MPEG_VIDEO_MPEG4_B_FRAME_QP	(V4L2_CID_CODEC_BASE+402)
596 #define V4L2_CID_MPEG_VIDEO_MPEG4_MIN_QP	(V4L2_CID_CODEC_BASE+403)
597 #define V4L2_CID_MPEG_VIDEO_MPEG4_MAX_QP	(V4L2_CID_CODEC_BASE+404)
598 #define V4L2_CID_MPEG_VIDEO_MPEG4_LEVEL		(V4L2_CID_CODEC_BASE+405)
599 enum v4l2_mpeg_video_mpeg4_level {
600 	V4L2_MPEG_VIDEO_MPEG4_LEVEL_0	= 0,
601 	V4L2_MPEG_VIDEO_MPEG4_LEVEL_0B	= 1,
602 	V4L2_MPEG_VIDEO_MPEG4_LEVEL_1	= 2,
603 	V4L2_MPEG_VIDEO_MPEG4_LEVEL_2	= 3,
604 	V4L2_MPEG_VIDEO_MPEG4_LEVEL_3	= 4,
605 	V4L2_MPEG_VIDEO_MPEG4_LEVEL_3B	= 5,
606 	V4L2_MPEG_VIDEO_MPEG4_LEVEL_4	= 6,
607 	V4L2_MPEG_VIDEO_MPEG4_LEVEL_5	= 7,
608 };
609 #define V4L2_CID_MPEG_VIDEO_MPEG4_PROFILE	(V4L2_CID_CODEC_BASE+406)
610 enum v4l2_mpeg_video_mpeg4_profile {
611 	V4L2_MPEG_VIDEO_MPEG4_PROFILE_SIMPLE				= 0,
612 	V4L2_MPEG_VIDEO_MPEG4_PROFILE_ADVANCED_SIMPLE			= 1,
613 	V4L2_MPEG_VIDEO_MPEG4_PROFILE_CORE				= 2,
614 	V4L2_MPEG_VIDEO_MPEG4_PROFILE_SIMPLE_SCALABLE			= 3,
615 	V4L2_MPEG_VIDEO_MPEG4_PROFILE_ADVANCED_CODING_EFFICIENCY	= 4,
616 };
617 #define V4L2_CID_MPEG_VIDEO_MPEG4_QPEL		(V4L2_CID_CODEC_BASE+407)
618 
619 /*  Control IDs for VP8 streams
620  *  Although VP8 is not part of MPEG we add these controls to the MPEG class
621  *  as that class is already handling other video compression standards
622  */
623 #define V4L2_CID_MPEG_VIDEO_VPX_NUM_PARTITIONS		(V4L2_CID_CODEC_BASE+500)
624 enum v4l2_vp8_num_partitions {
625 	V4L2_CID_MPEG_VIDEO_VPX_1_PARTITION	= 0,
626 	V4L2_CID_MPEG_VIDEO_VPX_2_PARTITIONS	= 1,
627 	V4L2_CID_MPEG_VIDEO_VPX_4_PARTITIONS	= 2,
628 	V4L2_CID_MPEG_VIDEO_VPX_8_PARTITIONS	= 3,
629 };
630 #define V4L2_CID_MPEG_VIDEO_VPX_IMD_DISABLE_4X4		(V4L2_CID_CODEC_BASE+501)
631 #define V4L2_CID_MPEG_VIDEO_VPX_NUM_REF_FRAMES		(V4L2_CID_CODEC_BASE+502)
632 enum v4l2_vp8_num_ref_frames {
633 	V4L2_CID_MPEG_VIDEO_VPX_1_REF_FRAME	= 0,
634 	V4L2_CID_MPEG_VIDEO_VPX_2_REF_FRAME	= 1,
635 	V4L2_CID_MPEG_VIDEO_VPX_3_REF_FRAME	= 2,
636 };
637 #define V4L2_CID_MPEG_VIDEO_VPX_FILTER_LEVEL		(V4L2_CID_CODEC_BASE+503)
638 #define V4L2_CID_MPEG_VIDEO_VPX_FILTER_SHARPNESS	(V4L2_CID_CODEC_BASE+504)
639 #define V4L2_CID_MPEG_VIDEO_VPX_GOLDEN_FRAME_REF_PERIOD	(V4L2_CID_CODEC_BASE+505)
640 #define V4L2_CID_MPEG_VIDEO_VPX_GOLDEN_FRAME_SEL	(V4L2_CID_CODEC_BASE+506)
641 enum v4l2_vp8_golden_frame_sel {
642 	V4L2_CID_MPEG_VIDEO_VPX_GOLDEN_FRAME_USE_PREV		= 0,
643 	V4L2_CID_MPEG_VIDEO_VPX_GOLDEN_FRAME_USE_REF_PERIOD	= 1,
644 };
645 #define V4L2_CID_MPEG_VIDEO_VPX_MIN_QP			(V4L2_CID_CODEC_BASE+507)
646 #define V4L2_CID_MPEG_VIDEO_VPX_MAX_QP			(V4L2_CID_CODEC_BASE+508)
647 #define V4L2_CID_MPEG_VIDEO_VPX_I_FRAME_QP		(V4L2_CID_CODEC_BASE+509)
648 #define V4L2_CID_MPEG_VIDEO_VPX_P_FRAME_QP		(V4L2_CID_CODEC_BASE+510)
649 
650 #define V4L2_CID_MPEG_VIDEO_VP8_PROFILE			(V4L2_CID_CODEC_BASE+511)
651 enum v4l2_mpeg_video_vp8_profile {
652 	V4L2_MPEG_VIDEO_VP8_PROFILE_0				= 0,
653 	V4L2_MPEG_VIDEO_VP8_PROFILE_1				= 1,
654 	V4L2_MPEG_VIDEO_VP8_PROFILE_2				= 2,
655 	V4L2_MPEG_VIDEO_VP8_PROFILE_3				= 3,
656 };
657 /* Deprecated alias for compatibility reasons. */
658 #define V4L2_CID_MPEG_VIDEO_VPX_PROFILE	V4L2_CID_MPEG_VIDEO_VP8_PROFILE
659 #define V4L2_CID_MPEG_VIDEO_VP9_PROFILE			(V4L2_CID_CODEC_BASE+512)
660 enum v4l2_mpeg_video_vp9_profile {
661 	V4L2_MPEG_VIDEO_VP9_PROFILE_0				= 0,
662 	V4L2_MPEG_VIDEO_VP9_PROFILE_1				= 1,
663 	V4L2_MPEG_VIDEO_VP9_PROFILE_2				= 2,
664 	V4L2_MPEG_VIDEO_VP9_PROFILE_3				= 3,
665 };
666 #define V4L2_CID_MPEG_VIDEO_VP9_LEVEL			(V4L2_CID_CODEC_BASE+513)
667 enum v4l2_mpeg_video_vp9_level {
668 	V4L2_MPEG_VIDEO_VP9_LEVEL_1_0	= 0,
669 	V4L2_MPEG_VIDEO_VP9_LEVEL_1_1	= 1,
670 	V4L2_MPEG_VIDEO_VP9_LEVEL_2_0	= 2,
671 	V4L2_MPEG_VIDEO_VP9_LEVEL_2_1	= 3,
672 	V4L2_MPEG_VIDEO_VP9_LEVEL_3_0	= 4,
673 	V4L2_MPEG_VIDEO_VP9_LEVEL_3_1	= 5,
674 	V4L2_MPEG_VIDEO_VP9_LEVEL_4_0	= 6,
675 	V4L2_MPEG_VIDEO_VP9_LEVEL_4_1	= 7,
676 	V4L2_MPEG_VIDEO_VP9_LEVEL_5_0	= 8,
677 	V4L2_MPEG_VIDEO_VP9_LEVEL_5_1	= 9,
678 	V4L2_MPEG_VIDEO_VP9_LEVEL_5_2	= 10,
679 	V4L2_MPEG_VIDEO_VP9_LEVEL_6_0	= 11,
680 	V4L2_MPEG_VIDEO_VP9_LEVEL_6_1	= 12,
681 	V4L2_MPEG_VIDEO_VP9_LEVEL_6_2	= 13,
682 };
683 
684 /* CIDs for HEVC encoding. */
685 
686 #define V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP		(V4L2_CID_CODEC_BASE + 600)
687 #define V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP		(V4L2_CID_CODEC_BASE + 601)
688 #define V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_QP	(V4L2_CID_CODEC_BASE + 602)
689 #define V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_QP	(V4L2_CID_CODEC_BASE + 603)
690 #define V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_QP	(V4L2_CID_CODEC_BASE + 604)
691 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_QP	(V4L2_CID_CODEC_BASE + 605)
692 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_TYPE (V4L2_CID_CODEC_BASE + 606)
693 enum v4l2_mpeg_video_hevc_hier_coding_type {
694 	V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_B	= 0,
695 	V4L2_MPEG_VIDEO_HEVC_HIERARCHICAL_CODING_P	= 1,
696 };
697 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_LAYER	(V4L2_CID_CODEC_BASE + 607)
698 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L0_QP	(V4L2_CID_CODEC_BASE + 608)
699 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L1_QP	(V4L2_CID_CODEC_BASE + 609)
700 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L2_QP	(V4L2_CID_CODEC_BASE + 610)
701 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L3_QP	(V4L2_CID_CODEC_BASE + 611)
702 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L4_QP	(V4L2_CID_CODEC_BASE + 612)
703 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L5_QP	(V4L2_CID_CODEC_BASE + 613)
704 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L6_QP	(V4L2_CID_CODEC_BASE + 614)
705 #define V4L2_CID_MPEG_VIDEO_HEVC_PROFILE	(V4L2_CID_CODEC_BASE + 615)
706 enum v4l2_mpeg_video_hevc_profile {
707 	V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN = 0,
708 	V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE = 1,
709 	V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10 = 2,
710 };
711 #define V4L2_CID_MPEG_VIDEO_HEVC_LEVEL		(V4L2_CID_CODEC_BASE + 616)
712 enum v4l2_mpeg_video_hevc_level {
713 	V4L2_MPEG_VIDEO_HEVC_LEVEL_1	= 0,
714 	V4L2_MPEG_VIDEO_HEVC_LEVEL_2	= 1,
715 	V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1	= 2,
716 	V4L2_MPEG_VIDEO_HEVC_LEVEL_3	= 3,
717 	V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1	= 4,
718 	V4L2_MPEG_VIDEO_HEVC_LEVEL_4	= 5,
719 	V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1	= 6,
720 	V4L2_MPEG_VIDEO_HEVC_LEVEL_5	= 7,
721 	V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1	= 8,
722 	V4L2_MPEG_VIDEO_HEVC_LEVEL_5_2	= 9,
723 	V4L2_MPEG_VIDEO_HEVC_LEVEL_6	= 10,
724 	V4L2_MPEG_VIDEO_HEVC_LEVEL_6_1	= 11,
725 	V4L2_MPEG_VIDEO_HEVC_LEVEL_6_2	= 12,
726 };
727 #define V4L2_CID_MPEG_VIDEO_HEVC_FRAME_RATE_RESOLUTION	(V4L2_CID_CODEC_BASE + 617)
728 #define V4L2_CID_MPEG_VIDEO_HEVC_TIER			(V4L2_CID_CODEC_BASE + 618)
729 enum v4l2_mpeg_video_hevc_tier {
730 	V4L2_MPEG_VIDEO_HEVC_TIER_MAIN = 0,
731 	V4L2_MPEG_VIDEO_HEVC_TIER_HIGH = 1,
732 };
733 #define V4L2_CID_MPEG_VIDEO_HEVC_MAX_PARTITION_DEPTH	(V4L2_CID_CODEC_BASE + 619)
734 #define V4L2_CID_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE	(V4L2_CID_CODEC_BASE + 620)
735 enum v4l2_cid_mpeg_video_hevc_loop_filter_mode {
736 	V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED			 = 0,
737 	V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_ENABLED			 = 1,
738 	V4L2_MPEG_VIDEO_HEVC_LOOP_FILTER_MODE_DISABLED_AT_SLICE_BOUNDARY = 2,
739 };
740 #define V4L2_CID_MPEG_VIDEO_HEVC_LF_BETA_OFFSET_DIV2	(V4L2_CID_CODEC_BASE + 621)
741 #define V4L2_CID_MPEG_VIDEO_HEVC_LF_TC_OFFSET_DIV2	(V4L2_CID_CODEC_BASE + 622)
742 #define V4L2_CID_MPEG_VIDEO_HEVC_REFRESH_TYPE		(V4L2_CID_CODEC_BASE + 623)
743 enum v4l2_cid_mpeg_video_hevc_refresh_type {
744 	V4L2_MPEG_VIDEO_HEVC_REFRESH_NONE		= 0,
745 	V4L2_MPEG_VIDEO_HEVC_REFRESH_CRA		= 1,
746 	V4L2_MPEG_VIDEO_HEVC_REFRESH_IDR		= 2,
747 };
748 #define V4L2_CID_MPEG_VIDEO_HEVC_REFRESH_PERIOD		(V4L2_CID_CODEC_BASE + 624)
749 #define V4L2_CID_MPEG_VIDEO_HEVC_LOSSLESS_CU		(V4L2_CID_CODEC_BASE + 625)
750 #define V4L2_CID_MPEG_VIDEO_HEVC_CONST_INTRA_PRED	(V4L2_CID_CODEC_BASE + 626)
751 #define V4L2_CID_MPEG_VIDEO_HEVC_WAVEFRONT		(V4L2_CID_CODEC_BASE + 627)
752 #define V4L2_CID_MPEG_VIDEO_HEVC_GENERAL_PB		(V4L2_CID_CODEC_BASE + 628)
753 #define V4L2_CID_MPEG_VIDEO_HEVC_TEMPORAL_ID		(V4L2_CID_CODEC_BASE + 629)
754 #define V4L2_CID_MPEG_VIDEO_HEVC_STRONG_SMOOTHING	(V4L2_CID_CODEC_BASE + 630)
755 #define V4L2_CID_MPEG_VIDEO_HEVC_MAX_NUM_MERGE_MV_MINUS1	(V4L2_CID_CODEC_BASE + 631)
756 #define V4L2_CID_MPEG_VIDEO_HEVC_INTRA_PU_SPLIT		(V4L2_CID_CODEC_BASE + 632)
757 #define V4L2_CID_MPEG_VIDEO_HEVC_TMV_PREDICTION		(V4L2_CID_CODEC_BASE + 633)
758 #define V4L2_CID_MPEG_VIDEO_HEVC_WITHOUT_STARTCODE	(V4L2_CID_CODEC_BASE + 634)
759 #define V4L2_CID_MPEG_VIDEO_HEVC_SIZE_OF_LENGTH_FIELD	(V4L2_CID_CODEC_BASE + 635)
760 enum v4l2_cid_mpeg_video_hevc_size_of_length_field {
761 	V4L2_MPEG_VIDEO_HEVC_SIZE_0		= 0,
762 	V4L2_MPEG_VIDEO_HEVC_SIZE_1		= 1,
763 	V4L2_MPEG_VIDEO_HEVC_SIZE_2		= 2,
764 	V4L2_MPEG_VIDEO_HEVC_SIZE_4		= 3,
765 };
766 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L0_BR	(V4L2_CID_CODEC_BASE + 636)
767 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L1_BR	(V4L2_CID_CODEC_BASE + 637)
768 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L2_BR	(V4L2_CID_CODEC_BASE + 638)
769 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L3_BR	(V4L2_CID_CODEC_BASE + 639)
770 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L4_BR	(V4L2_CID_CODEC_BASE + 640)
771 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L5_BR	(V4L2_CID_CODEC_BASE + 641)
772 #define V4L2_CID_MPEG_VIDEO_HEVC_HIER_CODING_L6_BR	(V4L2_CID_CODEC_BASE + 642)
773 #define V4L2_CID_MPEG_VIDEO_REF_NUMBER_FOR_PFRAMES	(V4L2_CID_CODEC_BASE + 643)
774 #define V4L2_CID_MPEG_VIDEO_PREPEND_SPSPPS_TO_IDR	(V4L2_CID_CODEC_BASE + 644)
775 #define V4L2_CID_MPEG_VIDEO_CONSTANT_QUALITY		(V4L2_CID_CODEC_BASE + 645)
776 #define V4L2_CID_MPEG_VIDEO_FRAME_SKIP_MODE		(V4L2_CID_CODEC_BASE + 646)
777 enum v4l2_mpeg_video_frame_skip_mode {
778 	V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_DISABLED	= 0,
779 	V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_LEVEL_LIMIT	= 1,
780 	V4L2_MPEG_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT	= 2,
781 };
782 
783 /*  MPEG-class control IDs specific to the CX2341x driver as defined by V4L2 */
784 #define V4L2_CID_CODEC_CX2341X_BASE				(V4L2_CTRL_CLASS_CODEC | 0x1000)
785 #define V4L2_CID_MPEG_CX2341X_VIDEO_SPATIAL_FILTER_MODE		(V4L2_CID_CODEC_CX2341X_BASE+0)
786 enum v4l2_mpeg_cx2341x_video_spatial_filter_mode {
787 	V4L2_MPEG_CX2341X_VIDEO_SPATIAL_FILTER_MODE_MANUAL = 0,
788 	V4L2_MPEG_CX2341X_VIDEO_SPATIAL_FILTER_MODE_AUTO   = 1,
789 };
790 #define V4L2_CID_MPEG_CX2341X_VIDEO_SPATIAL_FILTER		(V4L2_CID_CODEC_CX2341X_BASE+1)
791 #define V4L2_CID_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE	(V4L2_CID_CODEC_CX2341X_BASE+2)
792 enum v4l2_mpeg_cx2341x_video_luma_spatial_filter_type {
793 	V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_OFF                  = 0,
794 	V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_1D_HOR               = 1,
795 	V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_1D_VERT              = 2,
796 	V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_2D_HV_SEPARABLE      = 3,
797 	V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_2D_SYM_NON_SEPARABLE = 4,
798 };
799 #define V4L2_CID_MPEG_CX2341X_VIDEO_CHROMA_SPATIAL_FILTER_TYPE	(V4L2_CID_CODEC_CX2341X_BASE+3)
800 enum v4l2_mpeg_cx2341x_video_chroma_spatial_filter_type {
801 	V4L2_MPEG_CX2341X_VIDEO_CHROMA_SPATIAL_FILTER_TYPE_OFF    = 0,
802 	V4L2_MPEG_CX2341X_VIDEO_CHROMA_SPATIAL_FILTER_TYPE_1D_HOR = 1,
803 };
804 #define V4L2_CID_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER_MODE	(V4L2_CID_CODEC_CX2341X_BASE+4)
805 enum v4l2_mpeg_cx2341x_video_temporal_filter_mode {
806 	V4L2_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER_MODE_MANUAL = 0,
807 	V4L2_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER_MODE_AUTO   = 1,
808 };
809 #define V4L2_CID_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER		(V4L2_CID_CODEC_CX2341X_BASE+5)
810 #define V4L2_CID_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE		(V4L2_CID_CODEC_CX2341X_BASE+6)
811 enum v4l2_mpeg_cx2341x_video_median_filter_type {
812 	V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_OFF      = 0,
813 	V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_HOR      = 1,
814 	V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_VERT     = 2,
815 	V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_HOR_VERT = 3,
816 	V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_DIAG     = 4,
817 };
818 #define V4L2_CID_MPEG_CX2341X_VIDEO_LUMA_MEDIAN_FILTER_BOTTOM	(V4L2_CID_CODEC_CX2341X_BASE+7)
819 #define V4L2_CID_MPEG_CX2341X_VIDEO_LUMA_MEDIAN_FILTER_TOP	(V4L2_CID_CODEC_CX2341X_BASE+8)
820 #define V4L2_CID_MPEG_CX2341X_VIDEO_CHROMA_MEDIAN_FILTER_BOTTOM	(V4L2_CID_CODEC_CX2341X_BASE+9)
821 #define V4L2_CID_MPEG_CX2341X_VIDEO_CHROMA_MEDIAN_FILTER_TOP	(V4L2_CID_CODEC_CX2341X_BASE+10)
822 #define V4L2_CID_MPEG_CX2341X_STREAM_INSERT_NAV_PACKETS		(V4L2_CID_CODEC_CX2341X_BASE+11)
823 
824 /*  MPEG-class control IDs specific to the Samsung MFC 5.1 driver as defined by V4L2 */
825 #define V4L2_CID_CODEC_MFC51_BASE				(V4L2_CTRL_CLASS_CODEC | 0x1100)
826 
827 #define V4L2_CID_MPEG_MFC51_VIDEO_DECODER_H264_DISPLAY_DELAY		(V4L2_CID_CODEC_MFC51_BASE+0)
828 #define V4L2_CID_MPEG_MFC51_VIDEO_DECODER_H264_DISPLAY_DELAY_ENABLE	(V4L2_CID_CODEC_MFC51_BASE+1)
829 #define V4L2_CID_MPEG_MFC51_VIDEO_FRAME_SKIP_MODE			(V4L2_CID_CODEC_MFC51_BASE+2)
830 enum v4l2_mpeg_mfc51_video_frame_skip_mode {
831 	V4L2_MPEG_MFC51_VIDEO_FRAME_SKIP_MODE_DISABLED		= 0,
832 	V4L2_MPEG_MFC51_VIDEO_FRAME_SKIP_MODE_LEVEL_LIMIT	= 1,
833 	V4L2_MPEG_MFC51_VIDEO_FRAME_SKIP_MODE_BUF_LIMIT		= 2,
834 };
835 #define V4L2_CID_MPEG_MFC51_VIDEO_FORCE_FRAME_TYPE			(V4L2_CID_CODEC_MFC51_BASE+3)
836 enum v4l2_mpeg_mfc51_video_force_frame_type {
837 	V4L2_MPEG_MFC51_VIDEO_FORCE_FRAME_TYPE_DISABLED		= 0,
838 	V4L2_MPEG_MFC51_VIDEO_FORCE_FRAME_TYPE_I_FRAME		= 1,
839 	V4L2_MPEG_MFC51_VIDEO_FORCE_FRAME_TYPE_NOT_CODED	= 2,
840 };
841 #define V4L2_CID_MPEG_MFC51_VIDEO_PADDING				(V4L2_CID_CODEC_MFC51_BASE+4)
842 #define V4L2_CID_MPEG_MFC51_VIDEO_PADDING_YUV				(V4L2_CID_CODEC_MFC51_BASE+5)
843 #define V4L2_CID_MPEG_MFC51_VIDEO_RC_FIXED_TARGET_BIT			(V4L2_CID_CODEC_MFC51_BASE+6)
844 #define V4L2_CID_MPEG_MFC51_VIDEO_RC_REACTION_COEFF			(V4L2_CID_CODEC_MFC51_BASE+7)
845 #define V4L2_CID_MPEG_MFC51_VIDEO_H264_ADAPTIVE_RC_ACTIVITY		(V4L2_CID_CODEC_MFC51_BASE+50)
846 #define V4L2_CID_MPEG_MFC51_VIDEO_H264_ADAPTIVE_RC_DARK			(V4L2_CID_CODEC_MFC51_BASE+51)
847 #define V4L2_CID_MPEG_MFC51_VIDEO_H264_ADAPTIVE_RC_SMOOTH		(V4L2_CID_CODEC_MFC51_BASE+52)
848 #define V4L2_CID_MPEG_MFC51_VIDEO_H264_ADAPTIVE_RC_STATIC		(V4L2_CID_CODEC_MFC51_BASE+53)
849 #define V4L2_CID_MPEG_MFC51_VIDEO_H264_NUM_REF_PIC_FOR_P		(V4L2_CID_CODEC_MFC51_BASE+54)
850 
851 /*  Camera class control IDs */
852 
853 #define V4L2_CID_CAMERA_CLASS_BASE	(V4L2_CTRL_CLASS_CAMERA | 0x900)
854 #define V4L2_CID_CAMERA_CLASS		(V4L2_CTRL_CLASS_CAMERA | 1)
855 
856 #define V4L2_CID_EXPOSURE_AUTO			(V4L2_CID_CAMERA_CLASS_BASE+1)
857 enum  v4l2_exposure_auto_type {
858 	V4L2_EXPOSURE_AUTO = 0,
859 	V4L2_EXPOSURE_MANUAL = 1,
860 	V4L2_EXPOSURE_SHUTTER_PRIORITY = 2,
861 	V4L2_EXPOSURE_APERTURE_PRIORITY = 3
862 };
863 #define V4L2_CID_EXPOSURE_ABSOLUTE		(V4L2_CID_CAMERA_CLASS_BASE+2)
864 #define V4L2_CID_EXPOSURE_AUTO_PRIORITY		(V4L2_CID_CAMERA_CLASS_BASE+3)
865 
866 #define V4L2_CID_PAN_RELATIVE			(V4L2_CID_CAMERA_CLASS_BASE+4)
867 #define V4L2_CID_TILT_RELATIVE			(V4L2_CID_CAMERA_CLASS_BASE+5)
868 #define V4L2_CID_PAN_RESET			(V4L2_CID_CAMERA_CLASS_BASE+6)
869 #define V4L2_CID_TILT_RESET			(V4L2_CID_CAMERA_CLASS_BASE+7)
870 
871 #define V4L2_CID_PAN_ABSOLUTE			(V4L2_CID_CAMERA_CLASS_BASE+8)
872 #define V4L2_CID_TILT_ABSOLUTE			(V4L2_CID_CAMERA_CLASS_BASE+9)
873 
874 #define V4L2_CID_FOCUS_ABSOLUTE			(V4L2_CID_CAMERA_CLASS_BASE+10)
875 #define V4L2_CID_FOCUS_RELATIVE			(V4L2_CID_CAMERA_CLASS_BASE+11)
876 #define V4L2_CID_FOCUS_AUTO			(V4L2_CID_CAMERA_CLASS_BASE+12)
877 
878 #define V4L2_CID_ZOOM_ABSOLUTE			(V4L2_CID_CAMERA_CLASS_BASE+13)
879 #define V4L2_CID_ZOOM_RELATIVE			(V4L2_CID_CAMERA_CLASS_BASE+14)
880 #define V4L2_CID_ZOOM_CONTINUOUS		(V4L2_CID_CAMERA_CLASS_BASE+15)
881 
882 #define V4L2_CID_PRIVACY			(V4L2_CID_CAMERA_CLASS_BASE+16)
883 
884 #define V4L2_CID_IRIS_ABSOLUTE			(V4L2_CID_CAMERA_CLASS_BASE+17)
885 #define V4L2_CID_IRIS_RELATIVE			(V4L2_CID_CAMERA_CLASS_BASE+18)
886 
887 #define V4L2_CID_AUTO_EXPOSURE_BIAS		(V4L2_CID_CAMERA_CLASS_BASE+19)
888 
889 #define V4L2_CID_AUTO_N_PRESET_WHITE_BALANCE	(V4L2_CID_CAMERA_CLASS_BASE+20)
890 enum v4l2_auto_n_preset_white_balance {
891 	V4L2_WHITE_BALANCE_MANUAL		= 0,
892 	V4L2_WHITE_BALANCE_AUTO			= 1,
893 	V4L2_WHITE_BALANCE_INCANDESCENT		= 2,
894 	V4L2_WHITE_BALANCE_FLUORESCENT		= 3,
895 	V4L2_WHITE_BALANCE_FLUORESCENT_H	= 4,
896 	V4L2_WHITE_BALANCE_HORIZON		= 5,
897 	V4L2_WHITE_BALANCE_DAYLIGHT		= 6,
898 	V4L2_WHITE_BALANCE_FLASH		= 7,
899 	V4L2_WHITE_BALANCE_CLOUDY		= 8,
900 	V4L2_WHITE_BALANCE_SHADE		= 9,
901 };
902 
903 #define V4L2_CID_WIDE_DYNAMIC_RANGE		(V4L2_CID_CAMERA_CLASS_BASE+21)
904 #define V4L2_CID_IMAGE_STABILIZATION		(V4L2_CID_CAMERA_CLASS_BASE+22)
905 
906 #define V4L2_CID_ISO_SENSITIVITY		(V4L2_CID_CAMERA_CLASS_BASE+23)
907 #define V4L2_CID_ISO_SENSITIVITY_AUTO		(V4L2_CID_CAMERA_CLASS_BASE+24)
908 enum v4l2_iso_sensitivity_auto_type {
909 	V4L2_ISO_SENSITIVITY_MANUAL		= 0,
910 	V4L2_ISO_SENSITIVITY_AUTO		= 1,
911 };
912 
913 #define V4L2_CID_EXPOSURE_METERING		(V4L2_CID_CAMERA_CLASS_BASE+25)
914 enum v4l2_exposure_metering {
915 	V4L2_EXPOSURE_METERING_AVERAGE		= 0,
916 	V4L2_EXPOSURE_METERING_CENTER_WEIGHTED	= 1,
917 	V4L2_EXPOSURE_METERING_SPOT		= 2,
918 	V4L2_EXPOSURE_METERING_MATRIX		= 3,
919 };
920 
921 #define V4L2_CID_SCENE_MODE			(V4L2_CID_CAMERA_CLASS_BASE+26)
922 enum v4l2_scene_mode {
923 	V4L2_SCENE_MODE_NONE			= 0,
924 	V4L2_SCENE_MODE_BACKLIGHT		= 1,
925 	V4L2_SCENE_MODE_BEACH_SNOW		= 2,
926 	V4L2_SCENE_MODE_CANDLE_LIGHT		= 3,
927 	V4L2_SCENE_MODE_DAWN_DUSK		= 4,
928 	V4L2_SCENE_MODE_FALL_COLORS		= 5,
929 	V4L2_SCENE_MODE_FIREWORKS		= 6,
930 	V4L2_SCENE_MODE_LANDSCAPE		= 7,
931 	V4L2_SCENE_MODE_NIGHT			= 8,
932 	V4L2_SCENE_MODE_PARTY_INDOOR		= 9,
933 	V4L2_SCENE_MODE_PORTRAIT		= 10,
934 	V4L2_SCENE_MODE_SPORTS			= 11,
935 	V4L2_SCENE_MODE_SUNSET			= 12,
936 	V4L2_SCENE_MODE_TEXT			= 13,
937 };
938 
939 #define V4L2_CID_3A_LOCK			(V4L2_CID_CAMERA_CLASS_BASE+27)
940 #define V4L2_LOCK_EXPOSURE			(1 << 0)
941 #define V4L2_LOCK_WHITE_BALANCE			(1 << 1)
942 #define V4L2_LOCK_FOCUS				(1 << 2)
943 
944 #define V4L2_CID_AUTO_FOCUS_START		(V4L2_CID_CAMERA_CLASS_BASE+28)
945 #define V4L2_CID_AUTO_FOCUS_STOP		(V4L2_CID_CAMERA_CLASS_BASE+29)
946 #define V4L2_CID_AUTO_FOCUS_STATUS		(V4L2_CID_CAMERA_CLASS_BASE+30)
947 #define V4L2_AUTO_FOCUS_STATUS_IDLE		(0 << 0)
948 #define V4L2_AUTO_FOCUS_STATUS_BUSY		(1 << 0)
949 #define V4L2_AUTO_FOCUS_STATUS_REACHED		(1 << 1)
950 #define V4L2_AUTO_FOCUS_STATUS_FAILED		(1 << 2)
951 
952 #define V4L2_CID_AUTO_FOCUS_RANGE		(V4L2_CID_CAMERA_CLASS_BASE+31)
953 enum v4l2_auto_focus_range {
954 	V4L2_AUTO_FOCUS_RANGE_AUTO		= 0,
955 	V4L2_AUTO_FOCUS_RANGE_NORMAL		= 1,
956 	V4L2_AUTO_FOCUS_RANGE_MACRO		= 2,
957 	V4L2_AUTO_FOCUS_RANGE_INFINITY		= 3,
958 };
959 
960 #define V4L2_CID_PAN_SPEED			(V4L2_CID_CAMERA_CLASS_BASE+32)
961 #define V4L2_CID_TILT_SPEED			(V4L2_CID_CAMERA_CLASS_BASE+33)
962 
963 #define V4L2_CID_CAMERA_ORIENTATION		(V4L2_CID_CAMERA_CLASS_BASE+34)
964 #define V4L2_CAMERA_ORIENTATION_FRONT		0
965 #define V4L2_CAMERA_ORIENTATION_BACK		1
966 #define V4L2_CAMERA_ORIENTATION_EXTERNAL	2
967 
968 #define V4L2_CID_CAMERA_SENSOR_ROTATION		(V4L2_CID_CAMERA_CLASS_BASE+35)
969 
970 /* FM Modulator class control IDs */
971 
972 #define V4L2_CID_FM_TX_CLASS_BASE		(V4L2_CTRL_CLASS_FM_TX | 0x900)
973 #define V4L2_CID_FM_TX_CLASS			(V4L2_CTRL_CLASS_FM_TX | 1)
974 
975 #define V4L2_CID_RDS_TX_DEVIATION		(V4L2_CID_FM_TX_CLASS_BASE + 1)
976 #define V4L2_CID_RDS_TX_PI			(V4L2_CID_FM_TX_CLASS_BASE + 2)
977 #define V4L2_CID_RDS_TX_PTY			(V4L2_CID_FM_TX_CLASS_BASE + 3)
978 #define V4L2_CID_RDS_TX_PS_NAME			(V4L2_CID_FM_TX_CLASS_BASE + 5)
979 #define V4L2_CID_RDS_TX_RADIO_TEXT		(V4L2_CID_FM_TX_CLASS_BASE + 6)
980 #define V4L2_CID_RDS_TX_MONO_STEREO		(V4L2_CID_FM_TX_CLASS_BASE + 7)
981 #define V4L2_CID_RDS_TX_ARTIFICIAL_HEAD		(V4L2_CID_FM_TX_CLASS_BASE + 8)
982 #define V4L2_CID_RDS_TX_COMPRESSED		(V4L2_CID_FM_TX_CLASS_BASE + 9)
983 #define V4L2_CID_RDS_TX_DYNAMIC_PTY		(V4L2_CID_FM_TX_CLASS_BASE + 10)
984 #define V4L2_CID_RDS_TX_TRAFFIC_ANNOUNCEMENT	(V4L2_CID_FM_TX_CLASS_BASE + 11)
985 #define V4L2_CID_RDS_TX_TRAFFIC_PROGRAM		(V4L2_CID_FM_TX_CLASS_BASE + 12)
986 #define V4L2_CID_RDS_TX_MUSIC_SPEECH		(V4L2_CID_FM_TX_CLASS_BASE + 13)
987 #define V4L2_CID_RDS_TX_ALT_FREQS_ENABLE	(V4L2_CID_FM_TX_CLASS_BASE + 14)
988 #define V4L2_CID_RDS_TX_ALT_FREQS		(V4L2_CID_FM_TX_CLASS_BASE + 15)
989 
990 #define V4L2_CID_AUDIO_LIMITER_ENABLED		(V4L2_CID_FM_TX_CLASS_BASE + 64)
991 #define V4L2_CID_AUDIO_LIMITER_RELEASE_TIME	(V4L2_CID_FM_TX_CLASS_BASE + 65)
992 #define V4L2_CID_AUDIO_LIMITER_DEVIATION	(V4L2_CID_FM_TX_CLASS_BASE + 66)
993 
994 #define V4L2_CID_AUDIO_COMPRESSION_ENABLED	(V4L2_CID_FM_TX_CLASS_BASE + 80)
995 #define V4L2_CID_AUDIO_COMPRESSION_GAIN		(V4L2_CID_FM_TX_CLASS_BASE + 81)
996 #define V4L2_CID_AUDIO_COMPRESSION_THRESHOLD	(V4L2_CID_FM_TX_CLASS_BASE + 82)
997 #define V4L2_CID_AUDIO_COMPRESSION_ATTACK_TIME	(V4L2_CID_FM_TX_CLASS_BASE + 83)
998 #define V4L2_CID_AUDIO_COMPRESSION_RELEASE_TIME	(V4L2_CID_FM_TX_CLASS_BASE + 84)
999 
1000 #define V4L2_CID_PILOT_TONE_ENABLED		(V4L2_CID_FM_TX_CLASS_BASE + 96)
1001 #define V4L2_CID_PILOT_TONE_DEVIATION		(V4L2_CID_FM_TX_CLASS_BASE + 97)
1002 #define V4L2_CID_PILOT_TONE_FREQUENCY		(V4L2_CID_FM_TX_CLASS_BASE + 98)
1003 
1004 #define V4L2_CID_TUNE_PREEMPHASIS		(V4L2_CID_FM_TX_CLASS_BASE + 112)
1005 enum v4l2_preemphasis {
1006 	V4L2_PREEMPHASIS_DISABLED	= 0,
1007 	V4L2_PREEMPHASIS_50_uS		= 1,
1008 	V4L2_PREEMPHASIS_75_uS		= 2,
1009 };
1010 #define V4L2_CID_TUNE_POWER_LEVEL		(V4L2_CID_FM_TX_CLASS_BASE + 113)
1011 #define V4L2_CID_TUNE_ANTENNA_CAPACITOR		(V4L2_CID_FM_TX_CLASS_BASE + 114)
1012 
1013 
1014 /* Flash and privacy (indicator) light controls */
1015 
1016 #define V4L2_CID_FLASH_CLASS_BASE		(V4L2_CTRL_CLASS_FLASH | 0x900)
1017 #define V4L2_CID_FLASH_CLASS			(V4L2_CTRL_CLASS_FLASH | 1)
1018 
1019 #define V4L2_CID_FLASH_LED_MODE			(V4L2_CID_FLASH_CLASS_BASE + 1)
1020 enum v4l2_flash_led_mode {
1021 	V4L2_FLASH_LED_MODE_NONE,
1022 	V4L2_FLASH_LED_MODE_FLASH,
1023 	V4L2_FLASH_LED_MODE_TORCH,
1024 };
1025 
1026 #define V4L2_CID_FLASH_STROBE_SOURCE		(V4L2_CID_FLASH_CLASS_BASE + 2)
1027 enum v4l2_flash_strobe_source {
1028 	V4L2_FLASH_STROBE_SOURCE_SOFTWARE,
1029 	V4L2_FLASH_STROBE_SOURCE_EXTERNAL,
1030 };
1031 
1032 #define V4L2_CID_FLASH_STROBE			(V4L2_CID_FLASH_CLASS_BASE + 3)
1033 #define V4L2_CID_FLASH_STROBE_STOP		(V4L2_CID_FLASH_CLASS_BASE + 4)
1034 #define V4L2_CID_FLASH_STROBE_STATUS		(V4L2_CID_FLASH_CLASS_BASE + 5)
1035 
1036 #define V4L2_CID_FLASH_TIMEOUT			(V4L2_CID_FLASH_CLASS_BASE + 6)
1037 #define V4L2_CID_FLASH_INTENSITY		(V4L2_CID_FLASH_CLASS_BASE + 7)
1038 #define V4L2_CID_FLASH_TORCH_INTENSITY		(V4L2_CID_FLASH_CLASS_BASE + 8)
1039 #define V4L2_CID_FLASH_INDICATOR_INTENSITY	(V4L2_CID_FLASH_CLASS_BASE + 9)
1040 
1041 #define V4L2_CID_FLASH_FAULT			(V4L2_CID_FLASH_CLASS_BASE + 10)
1042 #define V4L2_FLASH_FAULT_OVER_VOLTAGE		(1 << 0)
1043 #define V4L2_FLASH_FAULT_TIMEOUT		(1 << 1)
1044 #define V4L2_FLASH_FAULT_OVER_TEMPERATURE	(1 << 2)
1045 #define V4L2_FLASH_FAULT_SHORT_CIRCUIT		(1 << 3)
1046 #define V4L2_FLASH_FAULT_OVER_CURRENT		(1 << 4)
1047 #define V4L2_FLASH_FAULT_INDICATOR		(1 << 5)
1048 #define V4L2_FLASH_FAULT_UNDER_VOLTAGE		(1 << 6)
1049 #define V4L2_FLASH_FAULT_INPUT_VOLTAGE		(1 << 7)
1050 #define V4L2_FLASH_FAULT_LED_OVER_TEMPERATURE	(1 << 8)
1051 
1052 #define V4L2_CID_FLASH_CHARGE			(V4L2_CID_FLASH_CLASS_BASE + 11)
1053 #define V4L2_CID_FLASH_READY			(V4L2_CID_FLASH_CLASS_BASE + 12)
1054 
1055 
1056 /* JPEG-class control IDs */
1057 
1058 #define V4L2_CID_JPEG_CLASS_BASE		(V4L2_CTRL_CLASS_JPEG | 0x900)
1059 #define V4L2_CID_JPEG_CLASS			(V4L2_CTRL_CLASS_JPEG | 1)
1060 
1061 #define	V4L2_CID_JPEG_CHROMA_SUBSAMPLING	(V4L2_CID_JPEG_CLASS_BASE + 1)
1062 enum v4l2_jpeg_chroma_subsampling {
1063 	V4L2_JPEG_CHROMA_SUBSAMPLING_444	= 0,
1064 	V4L2_JPEG_CHROMA_SUBSAMPLING_422	= 1,
1065 	V4L2_JPEG_CHROMA_SUBSAMPLING_420	= 2,
1066 	V4L2_JPEG_CHROMA_SUBSAMPLING_411	= 3,
1067 	V4L2_JPEG_CHROMA_SUBSAMPLING_410	= 4,
1068 	V4L2_JPEG_CHROMA_SUBSAMPLING_GRAY	= 5,
1069 };
1070 #define	V4L2_CID_JPEG_RESTART_INTERVAL		(V4L2_CID_JPEG_CLASS_BASE + 2)
1071 #define	V4L2_CID_JPEG_COMPRESSION_QUALITY	(V4L2_CID_JPEG_CLASS_BASE + 3)
1072 
1073 #define	V4L2_CID_JPEG_ACTIVE_MARKER		(V4L2_CID_JPEG_CLASS_BASE + 4)
1074 #define	V4L2_JPEG_ACTIVE_MARKER_APP0		(1 << 0)
1075 #define	V4L2_JPEG_ACTIVE_MARKER_APP1		(1 << 1)
1076 #define	V4L2_JPEG_ACTIVE_MARKER_COM		(1 << 16)
1077 #define	V4L2_JPEG_ACTIVE_MARKER_DQT		(1 << 17)
1078 #define	V4L2_JPEG_ACTIVE_MARKER_DHT		(1 << 18)
1079 
1080 
1081 /* Image source controls */
1082 #define V4L2_CID_IMAGE_SOURCE_CLASS_BASE	(V4L2_CTRL_CLASS_IMAGE_SOURCE | 0x900)
1083 #define V4L2_CID_IMAGE_SOURCE_CLASS		(V4L2_CTRL_CLASS_IMAGE_SOURCE | 1)
1084 
1085 #define V4L2_CID_VBLANK				(V4L2_CID_IMAGE_SOURCE_CLASS_BASE + 1)
1086 #define V4L2_CID_HBLANK				(V4L2_CID_IMAGE_SOURCE_CLASS_BASE + 2)
1087 #define V4L2_CID_ANALOGUE_GAIN			(V4L2_CID_IMAGE_SOURCE_CLASS_BASE + 3)
1088 #define V4L2_CID_TEST_PATTERN_RED		(V4L2_CID_IMAGE_SOURCE_CLASS_BASE + 4)
1089 #define V4L2_CID_TEST_PATTERN_GREENR		(V4L2_CID_IMAGE_SOURCE_CLASS_BASE + 5)
1090 #define V4L2_CID_TEST_PATTERN_BLUE		(V4L2_CID_IMAGE_SOURCE_CLASS_BASE + 6)
1091 #define V4L2_CID_TEST_PATTERN_GREENB		(V4L2_CID_IMAGE_SOURCE_CLASS_BASE + 7)
1092 #define V4L2_CID_UNIT_CELL_SIZE			(V4L2_CID_IMAGE_SOURCE_CLASS_BASE + 8)
1093 
1094 
1095 /* Image processing controls */
1096 
1097 #define V4L2_CID_IMAGE_PROC_CLASS_BASE		(V4L2_CTRL_CLASS_IMAGE_PROC | 0x900)
1098 #define V4L2_CID_IMAGE_PROC_CLASS		(V4L2_CTRL_CLASS_IMAGE_PROC | 1)
1099 
1100 #define V4L2_CID_LINK_FREQ			(V4L2_CID_IMAGE_PROC_CLASS_BASE + 1)
1101 #define V4L2_CID_PIXEL_RATE			(V4L2_CID_IMAGE_PROC_CLASS_BASE + 2)
1102 #define V4L2_CID_TEST_PATTERN			(V4L2_CID_IMAGE_PROC_CLASS_BASE + 3)
1103 #define V4L2_CID_DEINTERLACING_MODE		(V4L2_CID_IMAGE_PROC_CLASS_BASE + 4)
1104 #define V4L2_CID_DIGITAL_GAIN			(V4L2_CID_IMAGE_PROC_CLASS_BASE + 5)
1105 
1106 /*  DV-class control IDs defined by V4L2 */
1107 #define V4L2_CID_DV_CLASS_BASE			(V4L2_CTRL_CLASS_DV | 0x900)
1108 #define V4L2_CID_DV_CLASS			(V4L2_CTRL_CLASS_DV | 1)
1109 
1110 #define	V4L2_CID_DV_TX_HOTPLUG			(V4L2_CID_DV_CLASS_BASE + 1)
1111 #define	V4L2_CID_DV_TX_RXSENSE			(V4L2_CID_DV_CLASS_BASE + 2)
1112 #define	V4L2_CID_DV_TX_EDID_PRESENT		(V4L2_CID_DV_CLASS_BASE + 3)
1113 #define	V4L2_CID_DV_TX_MODE			(V4L2_CID_DV_CLASS_BASE + 4)
1114 enum v4l2_dv_tx_mode {
1115 	V4L2_DV_TX_MODE_DVI_D	= 0,
1116 	V4L2_DV_TX_MODE_HDMI	= 1,
1117 };
1118 #define V4L2_CID_DV_TX_RGB_RANGE		(V4L2_CID_DV_CLASS_BASE + 5)
1119 enum v4l2_dv_rgb_range {
1120 	V4L2_DV_RGB_RANGE_AUTO	  = 0,
1121 	V4L2_DV_RGB_RANGE_LIMITED = 1,
1122 	V4L2_DV_RGB_RANGE_FULL	  = 2,
1123 };
1124 
1125 #define V4L2_CID_DV_TX_IT_CONTENT_TYPE		(V4L2_CID_DV_CLASS_BASE + 6)
1126 enum v4l2_dv_it_content_type {
1127 	V4L2_DV_IT_CONTENT_TYPE_GRAPHICS  = 0,
1128 	V4L2_DV_IT_CONTENT_TYPE_PHOTO	  = 1,
1129 	V4L2_DV_IT_CONTENT_TYPE_CINEMA	  = 2,
1130 	V4L2_DV_IT_CONTENT_TYPE_GAME	  = 3,
1131 	V4L2_DV_IT_CONTENT_TYPE_NO_ITC	  = 4,
1132 };
1133 
1134 #define	V4L2_CID_DV_RX_POWER_PRESENT		(V4L2_CID_DV_CLASS_BASE + 100)
1135 #define V4L2_CID_DV_RX_RGB_RANGE		(V4L2_CID_DV_CLASS_BASE + 101)
1136 #define V4L2_CID_DV_RX_IT_CONTENT_TYPE		(V4L2_CID_DV_CLASS_BASE + 102)
1137 
1138 #define V4L2_CID_FM_RX_CLASS_BASE		(V4L2_CTRL_CLASS_FM_RX | 0x900)
1139 #define V4L2_CID_FM_RX_CLASS			(V4L2_CTRL_CLASS_FM_RX | 1)
1140 
1141 #define V4L2_CID_TUNE_DEEMPHASIS		(V4L2_CID_FM_RX_CLASS_BASE + 1)
1142 enum v4l2_deemphasis {
1143 	V4L2_DEEMPHASIS_DISABLED	= V4L2_PREEMPHASIS_DISABLED,
1144 	V4L2_DEEMPHASIS_50_uS		= V4L2_PREEMPHASIS_50_uS,
1145 	V4L2_DEEMPHASIS_75_uS		= V4L2_PREEMPHASIS_75_uS,
1146 };
1147 
1148 #define V4L2_CID_RDS_RECEPTION			(V4L2_CID_FM_RX_CLASS_BASE + 2)
1149 #define V4L2_CID_RDS_RX_PTY			(V4L2_CID_FM_RX_CLASS_BASE + 3)
1150 #define V4L2_CID_RDS_RX_PS_NAME			(V4L2_CID_FM_RX_CLASS_BASE + 4)
1151 #define V4L2_CID_RDS_RX_RADIO_TEXT		(V4L2_CID_FM_RX_CLASS_BASE + 5)
1152 #define V4L2_CID_RDS_RX_TRAFFIC_ANNOUNCEMENT	(V4L2_CID_FM_RX_CLASS_BASE + 6)
1153 #define V4L2_CID_RDS_RX_TRAFFIC_PROGRAM		(V4L2_CID_FM_RX_CLASS_BASE + 7)
1154 #define V4L2_CID_RDS_RX_MUSIC_SPEECH		(V4L2_CID_FM_RX_CLASS_BASE + 8)
1155 
1156 #define V4L2_CID_RF_TUNER_CLASS_BASE		(V4L2_CTRL_CLASS_RF_TUNER | 0x900)
1157 #define V4L2_CID_RF_TUNER_CLASS			(V4L2_CTRL_CLASS_RF_TUNER | 1)
1158 
1159 #define V4L2_CID_RF_TUNER_BANDWIDTH_AUTO	(V4L2_CID_RF_TUNER_CLASS_BASE + 11)
1160 #define V4L2_CID_RF_TUNER_BANDWIDTH		(V4L2_CID_RF_TUNER_CLASS_BASE + 12)
1161 #define V4L2_CID_RF_TUNER_RF_GAIN		(V4L2_CID_RF_TUNER_CLASS_BASE + 32)
1162 #define V4L2_CID_RF_TUNER_LNA_GAIN_AUTO		(V4L2_CID_RF_TUNER_CLASS_BASE + 41)
1163 #define V4L2_CID_RF_TUNER_LNA_GAIN		(V4L2_CID_RF_TUNER_CLASS_BASE + 42)
1164 #define V4L2_CID_RF_TUNER_MIXER_GAIN_AUTO	(V4L2_CID_RF_TUNER_CLASS_BASE + 51)
1165 #define V4L2_CID_RF_TUNER_MIXER_GAIN		(V4L2_CID_RF_TUNER_CLASS_BASE + 52)
1166 #define V4L2_CID_RF_TUNER_IF_GAIN_AUTO		(V4L2_CID_RF_TUNER_CLASS_BASE + 61)
1167 #define V4L2_CID_RF_TUNER_IF_GAIN		(V4L2_CID_RF_TUNER_CLASS_BASE + 62)
1168 #define V4L2_CID_RF_TUNER_PLL_LOCK			(V4L2_CID_RF_TUNER_CLASS_BASE + 91)
1169 
1170 
1171 /*  Detection-class control IDs defined by V4L2 */
1172 #define V4L2_CID_DETECT_CLASS_BASE		(V4L2_CTRL_CLASS_DETECT | 0x900)
1173 #define V4L2_CID_DETECT_CLASS			(V4L2_CTRL_CLASS_DETECT | 1)
1174 
1175 #define V4L2_CID_DETECT_MD_MODE			(V4L2_CID_DETECT_CLASS_BASE + 1)
1176 enum v4l2_detect_md_mode {
1177 	V4L2_DETECT_MD_MODE_DISABLED		= 0,
1178 	V4L2_DETECT_MD_MODE_GLOBAL		= 1,
1179 	V4L2_DETECT_MD_MODE_THRESHOLD_GRID	= 2,
1180 	V4L2_DETECT_MD_MODE_REGION_GRID		= 3,
1181 };
1182 #define V4L2_CID_DETECT_MD_GLOBAL_THRESHOLD	(V4L2_CID_DETECT_CLASS_BASE + 2)
1183 #define V4L2_CID_DETECT_MD_THRESHOLD_GRID	(V4L2_CID_DETECT_CLASS_BASE + 3)
1184 #define V4L2_CID_DETECT_MD_REGION_GRID		(V4L2_CID_DETECT_CLASS_BASE + 4)
1185 
1186 
1187 /*  Stateless CODECs controls */
1188 #define V4L2_CID_CODEC_STATELESS_BASE          (V4L2_CTRL_CLASS_CODEC_STATELESS | 0x900)
1189 #define V4L2_CID_CODEC_STATELESS_CLASS         (V4L2_CTRL_CLASS_CODEC_STATELESS | 1)
1190 
1191 #define V4L2_CID_STATELESS_H264_DECODE_MODE	(V4L2_CID_CODEC_STATELESS_BASE + 0)
1192 /**
1193  * enum v4l2_stateless_h264_decode_mode - Decoding mode
1194  *
1195  * @V4L2_STATELESS_H264_DECODE_MODE_SLICE_BASED: indicates that decoding
1196  * is performed one slice at a time. In this mode,
1197  * V4L2_CID_STATELESS_H264_SLICE_PARAMS must contain the parsed slice
1198  * parameters and the OUTPUT buffer must contain a single slice.
1199  * V4L2_BUF_CAP_SUPPORTS_M2M_HOLD_CAPTURE_BUF feature is used
1200  * in order to support multislice frames.
1201  * @V4L2_STATELESS_H264_DECODE_MODE_FRAME_BASED: indicates that
1202  * decoding is performed per frame. The OUTPUT buffer must contain
1203  * all slices and also both fields. This mode is typically supported
1204  * by device drivers that are able to parse the slice(s) header(s)
1205  * in hardware. When this mode is selected,
1206  * V4L2_CID_STATELESS_H264_SLICE_PARAMS is not used.
1207  */
1208 enum v4l2_stateless_h264_decode_mode {
1209 	V4L2_STATELESS_H264_DECODE_MODE_SLICE_BASED,
1210 	V4L2_STATELESS_H264_DECODE_MODE_FRAME_BASED,
1211 };
1212 
1213 #define V4L2_CID_STATELESS_H264_START_CODE	(V4L2_CID_CODEC_STATELESS_BASE + 1)
1214 /**
1215  * enum v4l2_stateless_h264_start_code - Start code
1216  *
1217  * @V4L2_STATELESS_H264_START_CODE_NONE: slices are passed
1218  * to the driver without any start code.
1219  * @V4L2_STATELESS_H264_START_CODE_ANNEX_B: slices are passed
1220  * to the driver with an Annex B start code prefix
1221  * (legal start codes can be 3-bytes 0x000001 or 4-bytes 0x00000001).
1222  * This mode is typically supported by device drivers that parse
1223  * the start code in hardware.
1224  */
1225 enum v4l2_stateless_h264_start_code {
1226 	V4L2_STATELESS_H264_START_CODE_NONE,
1227 	V4L2_STATELESS_H264_START_CODE_ANNEX_B,
1228 };
1229 
1230 #define V4L2_H264_SPS_CONSTRAINT_SET0_FLAG			0x01
1231 #define V4L2_H264_SPS_CONSTRAINT_SET1_FLAG			0x02
1232 #define V4L2_H264_SPS_CONSTRAINT_SET2_FLAG			0x04
1233 #define V4L2_H264_SPS_CONSTRAINT_SET3_FLAG			0x08
1234 #define V4L2_H264_SPS_CONSTRAINT_SET4_FLAG			0x10
1235 #define V4L2_H264_SPS_CONSTRAINT_SET5_FLAG			0x20
1236 
1237 #define V4L2_H264_SPS_FLAG_SEPARATE_COLOUR_PLANE		0x01
1238 #define V4L2_H264_SPS_FLAG_QPPRIME_Y_ZERO_TRANSFORM_BYPASS	0x02
1239 #define V4L2_H264_SPS_FLAG_DELTA_PIC_ORDER_ALWAYS_ZERO		0x04
1240 #define V4L2_H264_SPS_FLAG_GAPS_IN_FRAME_NUM_VALUE_ALLOWED	0x08
1241 #define V4L2_H264_SPS_FLAG_FRAME_MBS_ONLY			0x10
1242 #define V4L2_H264_SPS_FLAG_MB_ADAPTIVE_FRAME_FIELD		0x20
1243 #define V4L2_H264_SPS_FLAG_DIRECT_8X8_INFERENCE			0x40
1244 
1245 #define V4L2_H264_SPS_HAS_CHROMA_FORMAT(sps) \
1246 	((sps)->profile_idc == 100 || (sps)->profile_idc == 110 || \
1247 	 (sps)->profile_idc == 122 || (sps)->profile_idc == 244 || \
1248 	 (sps)->profile_idc == 44  || (sps)->profile_idc == 83  || \
1249 	 (sps)->profile_idc == 86  || (sps)->profile_idc == 118 || \
1250 	 (sps)->profile_idc == 128 || (sps)->profile_idc == 138 || \
1251 	 (sps)->profile_idc == 139 || (sps)->profile_idc == 134 || \
1252 	 (sps)->profile_idc == 135)
1253 
1254 #define V4L2_CID_STATELESS_H264_SPS		(V4L2_CID_CODEC_STATELESS_BASE + 2)
1255 /**
1256  * struct v4l2_ctrl_h264_sps - H264 sequence parameter set
1257  *
1258  * All the members on this sequence parameter set structure match the
1259  * sequence parameter set syntax as specified by the H264 specification.
1260  *
1261  * @profile_idc: see H264 specification.
1262  * @constraint_set_flags: see H264 specification.
1263  * @level_idc: see H264 specification.
1264  * @seq_parameter_set_id: see H264 specification.
1265  * @chroma_format_idc: see H264 specification.
1266  * @bit_depth_luma_minus8: see H264 specification.
1267  * @bit_depth_chroma_minus8: see H264 specification.
1268  * @log2_max_frame_num_minus4: see H264 specification.
1269  * @pic_order_cnt_type: see H264 specification.
1270  * @log2_max_pic_order_cnt_lsb_minus4: see H264 specification.
1271  * @max_num_ref_frames: see H264 specification.
1272  * @num_ref_frames_in_pic_order_cnt_cycle: see H264 specification.
1273  * @offset_for_ref_frame: see H264 specification.
1274  * @offset_for_non_ref_pic: see H264 specification.
1275  * @offset_for_top_to_bottom_field: see H264 specification.
1276  * @pic_width_in_mbs_minus1: see H264 specification.
1277  * @pic_height_in_map_units_minus1: see H264 specification.
1278  * @flags: see V4L2_H264_SPS_FLAG_{}.
1279  */
1280 struct v4l2_ctrl_h264_sps {
1281 	__u8 profile_idc;
1282 	__u8 constraint_set_flags;
1283 	__u8 level_idc;
1284 	__u8 seq_parameter_set_id;
1285 	__u8 chroma_format_idc;
1286 	__u8 bit_depth_luma_minus8;
1287 	__u8 bit_depth_chroma_minus8;
1288 	__u8 log2_max_frame_num_minus4;
1289 	__u8 pic_order_cnt_type;
1290 	__u8 log2_max_pic_order_cnt_lsb_minus4;
1291 	__u8 max_num_ref_frames;
1292 	__u8 num_ref_frames_in_pic_order_cnt_cycle;
1293 	__s32 offset_for_ref_frame[255];
1294 	__s32 offset_for_non_ref_pic;
1295 	__s32 offset_for_top_to_bottom_field;
1296 	__u16 pic_width_in_mbs_minus1;
1297 	__u16 pic_height_in_map_units_minus1;
1298 	__u32 flags;
1299 };
1300 
1301 #define V4L2_H264_PPS_FLAG_ENTROPY_CODING_MODE				0x0001
1302 #define V4L2_H264_PPS_FLAG_BOTTOM_FIELD_PIC_ORDER_IN_FRAME_PRESENT	0x0002
1303 #define V4L2_H264_PPS_FLAG_WEIGHTED_PRED				0x0004
1304 #define V4L2_H264_PPS_FLAG_DEBLOCKING_FILTER_CONTROL_PRESENT		0x0008
1305 #define V4L2_H264_PPS_FLAG_CONSTRAINED_INTRA_PRED			0x0010
1306 #define V4L2_H264_PPS_FLAG_REDUNDANT_PIC_CNT_PRESENT			0x0020
1307 #define V4L2_H264_PPS_FLAG_TRANSFORM_8X8_MODE				0x0040
1308 #define V4L2_H264_PPS_FLAG_SCALING_MATRIX_PRESENT			0x0080
1309 
1310 #define V4L2_CID_STATELESS_H264_PPS		(V4L2_CID_CODEC_STATELESS_BASE + 3)
1311 /**
1312  * struct v4l2_ctrl_h264_pps - H264 picture parameter set
1313  *
1314  * Except where noted, all the members on this picture parameter set
1315  * structure match the sequence parameter set syntax as specified
1316  * by the H264 specification.
1317  *
1318  * In particular, V4L2_H264_PPS_FLAG_SCALING_MATRIX_PRESENT flag
1319  * has a specific meaning. This flag should be set if a non-flat
1320  * scaling matrix applies to the picture. In this case, applications
1321  * are expected to use V4L2_CID_STATELESS_H264_SCALING_MATRIX,
1322  * to pass the values of the non-flat matrices.
1323  *
1324  * @pic_parameter_set_id: see H264 specification.
1325  * @seq_parameter_set_id: see H264 specification.
1326  * @num_slice_groups_minus1: see H264 specification.
1327  * @num_ref_idx_l0_default_active_minus1: see H264 specification.
1328  * @num_ref_idx_l1_default_active_minus1: see H264 specification.
1329  * @weighted_bipred_idc: see H264 specification.
1330  * @pic_init_qp_minus26: see H264 specification.
1331  * @pic_init_qs_minus26: see H264 specification.
1332  * @chroma_qp_index_offset: see H264 specification.
1333  * @second_chroma_qp_index_offset: see H264 specification.
1334  * @flags: see V4L2_H264_PPS_FLAG_{}.
1335  */
1336 struct v4l2_ctrl_h264_pps {
1337 	__u8 pic_parameter_set_id;
1338 	__u8 seq_parameter_set_id;
1339 	__u8 num_slice_groups_minus1;
1340 	__u8 num_ref_idx_l0_default_active_minus1;
1341 	__u8 num_ref_idx_l1_default_active_minus1;
1342 	__u8 weighted_bipred_idc;
1343 	__s8 pic_init_qp_minus26;
1344 	__s8 pic_init_qs_minus26;
1345 	__s8 chroma_qp_index_offset;
1346 	__s8 second_chroma_qp_index_offset;
1347 	__u16 flags;
1348 };
1349 
1350 #define V4L2_CID_STATELESS_H264_SCALING_MATRIX	(V4L2_CID_CODEC_STATELESS_BASE + 4)
1351 /**
1352  * struct v4l2_ctrl_h264_scaling_matrix - H264 scaling matrices
1353  *
1354  * @scaling_list_4x4: scaling matrix after applying the inverse
1355  * scanning process. Expected list order is Intra Y, Intra Cb,
1356  * Intra Cr, Inter Y, Inter Cb, Inter Cr. The values on each
1357  * scaling list are expected in raster scan order.
1358  * @scaling_list_8x8: scaling matrix after applying the inverse
1359  * scanning process. Expected list order is Intra Y, Inter Y,
1360  * Intra Cb, Inter Cb, Intra Cr, Inter Cr. The values on each
1361  * scaling list are expected in raster scan order.
1362  *
1363  * Note that the list order is different for the 4x4 and 8x8
1364  * matrices as per the H264 specification, see table 7-2 "Assignment
1365  * of mnemonic names to scaling list indices and specification of
1366  * fall-back rule".
1367  */
1368 struct v4l2_ctrl_h264_scaling_matrix {
1369 	__u8 scaling_list_4x4[6][16];
1370 	__u8 scaling_list_8x8[6][64];
1371 };
1372 
1373 struct v4l2_h264_weight_factors {
1374 	__s16 luma_weight[32];
1375 	__s16 luma_offset[32];
1376 	__s16 chroma_weight[32][2];
1377 	__s16 chroma_offset[32][2];
1378 };
1379 
1380 #define V4L2_H264_CTRL_PRED_WEIGHTS_REQUIRED(pps, slice) \
1381 	((((pps)->flags & V4L2_H264_PPS_FLAG_WEIGHTED_PRED) && \
1382 	 ((slice)->slice_type == V4L2_H264_SLICE_TYPE_P || \
1383 	  (slice)->slice_type == V4L2_H264_SLICE_TYPE_SP)) || \
1384 	 ((pps)->weighted_bipred_idc == 1 && \
1385 	  (slice)->slice_type == V4L2_H264_SLICE_TYPE_B))
1386 
1387 #define V4L2_CID_STATELESS_H264_PRED_WEIGHTS	(V4L2_CID_CODEC_STATELESS_BASE + 5)
1388 /**
1389  * struct v4l2_ctrl_h264_pred_weights - Prediction weight table
1390  *
1391  * Prediction weight table, which matches the syntax specified
1392  * by the H264 specification.
1393  *
1394  * @luma_log2_weight_denom: see H264 specification.
1395  * @chroma_log2_weight_denom: see H264 specification.
1396  * @weight_factors: luma and chroma weight factors.
1397  */
1398 struct v4l2_ctrl_h264_pred_weights {
1399 	__u16 luma_log2_weight_denom;
1400 	__u16 chroma_log2_weight_denom;
1401 	struct v4l2_h264_weight_factors weight_factors[2];
1402 };
1403 
1404 #define V4L2_H264_SLICE_TYPE_P				0
1405 #define V4L2_H264_SLICE_TYPE_B				1
1406 #define V4L2_H264_SLICE_TYPE_I				2
1407 #define V4L2_H264_SLICE_TYPE_SP				3
1408 #define V4L2_H264_SLICE_TYPE_SI				4
1409 
1410 #define V4L2_H264_SLICE_FLAG_DIRECT_SPATIAL_MV_PRED	0x01
1411 #define V4L2_H264_SLICE_FLAG_SP_FOR_SWITCH		0x02
1412 
1413 #define V4L2_H264_TOP_FIELD_REF				0x1
1414 #define V4L2_H264_BOTTOM_FIELD_REF			0x2
1415 #define V4L2_H264_FRAME_REF				0x3
1416 
1417 /**
1418  * struct v4l2_h264_reference - H264 picture reference
1419  *
1420  * @fields: indicates how the picture is referenced.
1421  * Valid values are V4L2_H264_{}_REF.
1422  * @index: index into v4l2_ctrl_h264_decode_params.dpb[].
1423  */
1424 struct v4l2_h264_reference {
1425 	__u8 fields;
1426 	__u8 index;
1427 };
1428 
1429 /*
1430  * Maximum DPB size, as specified by section 'A.3.1 Level limits
1431  * common to the Baseline, Main, and Extended profiles'.
1432  */
1433 #define V4L2_H264_NUM_DPB_ENTRIES 16
1434 #define V4L2_H264_REF_LIST_LEN (2 * V4L2_H264_NUM_DPB_ENTRIES)
1435 
1436 #define V4L2_CID_STATELESS_H264_SLICE_PARAMS	(V4L2_CID_CODEC_STATELESS_BASE + 6)
1437 /**
1438  * struct v4l2_ctrl_h264_slice_params - H264 slice parameters
1439  *
1440  * This structure holds the H264 syntax elements that are specified
1441  * as non-invariant for the slices in a given frame.
1442  *
1443  * Slice invariant syntax elements are contained in struct
1444  * v4l2_ctrl_h264_decode_params. This is done to reduce the API surface
1445  * on frame-based decoders, where slice header parsing is done by the
1446  * hardware.
1447  *
1448  * Slice invariant syntax elements are specified in specification section
1449  * "7.4.3 Slice header semantics".
1450  *
1451  * Except where noted, the members on this struct match the slice header syntax.
1452  *
1453  * @header_bit_size: offset in bits to slice_data() from the beginning of this slice.
1454  * @first_mb_in_slice: see H264 specification.
1455  * @slice_type: see H264 specification.
1456  * @colour_plane_id: see H264 specification.
1457  * @redundant_pic_cnt: see H264 specification.
1458  * @cabac_init_idc: see H264 specification.
1459  * @slice_qp_delta: see H264 specification.
1460  * @slice_qs_delta: see H264 specification.
1461  * @disable_deblocking_filter_idc: see H264 specification.
1462  * @slice_alpha_c0_offset_div2: see H264 specification.
1463  * @slice_beta_offset_div2: see H264 specification.
1464  * @num_ref_idx_l0_active_minus1: see H264 specification.
1465  * @num_ref_idx_l1_active_minus1: see H264 specification.
1466  * @reserved: padding field. Should be zeroed by applications.
1467  * @ref_pic_list0: reference picture list 0 after applying the per-slice modifications.
1468  * @ref_pic_list1: reference picture list 1 after applying the per-slice modifications.
1469  * @flags: see V4L2_H264_SLICE_FLAG_{}.
1470  */
1471 struct v4l2_ctrl_h264_slice_params {
1472 	__u32 header_bit_size;
1473 	__u32 first_mb_in_slice;
1474 	__u8 slice_type;
1475 	__u8 colour_plane_id;
1476 	__u8 redundant_pic_cnt;
1477 	__u8 cabac_init_idc;
1478 	__s8 slice_qp_delta;
1479 	__s8 slice_qs_delta;
1480 	__u8 disable_deblocking_filter_idc;
1481 	__s8 slice_alpha_c0_offset_div2;
1482 	__s8 slice_beta_offset_div2;
1483 	__u8 num_ref_idx_l0_active_minus1;
1484 	__u8 num_ref_idx_l1_active_minus1;
1485 
1486 	__u8 reserved;
1487 
1488 	struct v4l2_h264_reference ref_pic_list0[V4L2_H264_REF_LIST_LEN];
1489 	struct v4l2_h264_reference ref_pic_list1[V4L2_H264_REF_LIST_LEN];
1490 
1491 	__u32 flags;
1492 };
1493 
1494 #define V4L2_H264_DPB_ENTRY_FLAG_VALID		0x01
1495 #define V4L2_H264_DPB_ENTRY_FLAG_ACTIVE		0x02
1496 #define V4L2_H264_DPB_ENTRY_FLAG_LONG_TERM	0x04
1497 #define V4L2_H264_DPB_ENTRY_FLAG_FIELD		0x08
1498 
1499 /**
1500  * struct v4l2_h264_dpb_entry - H264 decoded picture buffer entry
1501  *
1502  * @reference_ts: timestamp of the V4L2 capture buffer to use as reference.
1503  * The timestamp refers to the timestamp field in struct v4l2_buffer.
1504  * Use v4l2_timeval_to_ns() to convert the struct timeval to a __u64.
1505  * @pic_num: matches PicNum variable assigned during the reference
1506  * picture lists construction process.
1507  * @frame_num: frame identifier which matches frame_num syntax element.
1508  * @fields: indicates how the DPB entry is referenced. Valid values are
1509  * V4L2_H264_{}_REF.
1510  * @reserved: padding field. Should be zeroed by applications.
1511  * @top_field_order_cnt: matches TopFieldOrderCnt picture value.
1512  * @bottom_field_order_cnt: matches BottomFieldOrderCnt picture value.
1513  * Note that picture field is indicated by v4l2_buffer.field.
1514  * @flags: see V4L2_H264_DPB_ENTRY_FLAG_{}.
1515  */
1516 struct v4l2_h264_dpb_entry {
1517 	__u64 reference_ts;
1518 	__u32 pic_num;
1519 	__u16 frame_num;
1520 	__u8 fields;
1521 	__u8 reserved[5];
1522 	__s32 top_field_order_cnt;
1523 	__s32 bottom_field_order_cnt;
1524 	__u32 flags;
1525 };
1526 
1527 #define V4L2_H264_DECODE_PARAM_FLAG_IDR_PIC		0x01
1528 #define V4L2_H264_DECODE_PARAM_FLAG_FIELD_PIC		0x02
1529 #define V4L2_H264_DECODE_PARAM_FLAG_BOTTOM_FIELD	0x04
1530 
1531 #define V4L2_CID_STATELESS_H264_DECODE_PARAMS	(V4L2_CID_CODEC_STATELESS_BASE + 7)
1532 /**
1533  * struct v4l2_ctrl_h264_decode_params - H264 decoding parameters
1534  *
1535  * @dpb: decoded picture buffer.
1536  * @nal_ref_idc: slice header syntax element.
1537  * @frame_num: slice header syntax element.
1538  * @top_field_order_cnt: matches TopFieldOrderCnt picture value.
1539  * @bottom_field_order_cnt: matches BottomFieldOrderCnt picture value.
1540  * Note that picture field is indicated by v4l2_buffer.field.
1541  * @idr_pic_id: slice header syntax element.
1542  * @pic_order_cnt_lsb: slice header syntax element.
1543  * @delta_pic_order_cnt_bottom: slice header syntax element.
1544  * @delta_pic_order_cnt0: slice header syntax element.
1545  * @delta_pic_order_cnt1: slice header syntax element.
1546  * @dec_ref_pic_marking_bit_size: size in bits of dec_ref_pic_marking()
1547  * syntax element.
1548  * @pic_order_cnt_bit_size: size in bits of pic order count syntax.
1549  * @slice_group_change_cycle: slice header syntax element.
1550  * @reserved: padding field. Should be zeroed by applications.
1551  * @flags: see V4L2_H264_DECODE_PARAM_FLAG_{}.
1552  */
1553 struct v4l2_ctrl_h264_decode_params {
1554 	struct v4l2_h264_dpb_entry dpb[V4L2_H264_NUM_DPB_ENTRIES];
1555 	__u16 nal_ref_idc;
1556 	__u16 frame_num;
1557 	__s32 top_field_order_cnt;
1558 	__s32 bottom_field_order_cnt;
1559 	__u16 idr_pic_id;
1560 	__u16 pic_order_cnt_lsb;
1561 	__s32 delta_pic_order_cnt_bottom;
1562 	__s32 delta_pic_order_cnt0;
1563 	__s32 delta_pic_order_cnt1;
1564 	__u32 dec_ref_pic_marking_bit_size;
1565 	__u32 pic_order_cnt_bit_size;
1566 	__u32 slice_group_change_cycle;
1567 
1568 	__u32 reserved;
1569 	__u32 flags;
1570 };
1571 
1572 
1573 /* Stateless FWHT control, used by the vicodec driver */
1574 
1575 /* Current FWHT version */
1576 #define V4L2_FWHT_VERSION			3
1577 
1578 /* Set if this is an interlaced format */
1579 #define V4L2_FWHT_FL_IS_INTERLACED		BIT(0)
1580 /* Set if this is a bottom-first (NTSC) interlaced format */
1581 #define V4L2_FWHT_FL_IS_BOTTOM_FIRST		BIT(1)
1582 /* Set if each 'frame' contains just one field */
1583 #define V4L2_FWHT_FL_IS_ALTERNATE		BIT(2)
1584 /*
1585  * If V4L2_FWHT_FL_IS_ALTERNATE was set, then this is set if this
1586  * 'frame' is the bottom field, else it is the top field.
1587  */
1588 #define V4L2_FWHT_FL_IS_BOTTOM_FIELD		BIT(3)
1589 /* Set if the Y' plane is uncompressed */
1590 #define V4L2_FWHT_FL_LUMA_IS_UNCOMPRESSED	BIT(4)
1591 /* Set if the Cb plane is uncompressed */
1592 #define V4L2_FWHT_FL_CB_IS_UNCOMPRESSED		BIT(5)
1593 /* Set if the Cr plane is uncompressed */
1594 #define V4L2_FWHT_FL_CR_IS_UNCOMPRESSED		BIT(6)
1595 /* Set if the chroma plane is full height, if cleared it is half height */
1596 #define V4L2_FWHT_FL_CHROMA_FULL_HEIGHT		BIT(7)
1597 /* Set if the chroma plane is full width, if cleared it is half width */
1598 #define V4L2_FWHT_FL_CHROMA_FULL_WIDTH		BIT(8)
1599 /* Set if the alpha plane is uncompressed */
1600 #define V4L2_FWHT_FL_ALPHA_IS_UNCOMPRESSED	BIT(9)
1601 /* Set if this is an I Frame */
1602 #define V4L2_FWHT_FL_I_FRAME			BIT(10)
1603 
1604 /* A 4-values flag - the number of components - 1 */
1605 #define V4L2_FWHT_FL_COMPONENTS_NUM_MSK		GENMASK(18, 16)
1606 #define V4L2_FWHT_FL_COMPONENTS_NUM_OFFSET	16
1607 
1608 /* A 4-values flag - the pixel encoding type */
1609 #define V4L2_FWHT_FL_PIXENC_MSK			GENMASK(20, 19)
1610 #define V4L2_FWHT_FL_PIXENC_OFFSET		19
1611 #define V4L2_FWHT_FL_PIXENC_YUV			(1 << V4L2_FWHT_FL_PIXENC_OFFSET)
1612 #define V4L2_FWHT_FL_PIXENC_RGB			(2 << V4L2_FWHT_FL_PIXENC_OFFSET)
1613 #define V4L2_FWHT_FL_PIXENC_HSV			(3 << V4L2_FWHT_FL_PIXENC_OFFSET)
1614 
1615 #define V4L2_CID_STATELESS_FWHT_PARAMS		(V4L2_CID_CODEC_STATELESS_BASE + 100)
1616 /**
1617  * struct v4l2_ctrl_fwht_params - FWHT parameters
1618  *
1619  * @backward_ref_ts: timestamp of the V4L2 capture buffer to use as reference.
1620  * The timestamp refers to the timestamp field in struct v4l2_buffer.
1621  * Use v4l2_timeval_to_ns() to convert the struct timeval to a __u64.
1622  * @version: must be V4L2_FWHT_VERSION.
1623  * @width: width of frame.
1624  * @height: height of frame.
1625  * @flags: FWHT flags (see V4L2_FWHT_FL_*).
1626  * @colorspace: the colorspace (enum v4l2_colorspace).
1627  * @xfer_func: the transfer function (enum v4l2_xfer_func).
1628  * @ycbcr_enc: the Y'CbCr encoding (enum v4l2_ycbcr_encoding).
1629  * @quantization: the quantization (enum v4l2_quantization).
1630  */
1631 struct v4l2_ctrl_fwht_params {
1632 	__u64 backward_ref_ts;
1633 	__u32 version;
1634 	__u32 width;
1635 	__u32 height;
1636 	__u32 flags;
1637 	__u32 colorspace;
1638 	__u32 xfer_func;
1639 	__u32 ycbcr_enc;
1640 	__u32 quantization;
1641 };
1642 
1643 /* MPEG-compression definitions kept for backwards compatibility */
1644 #ifndef __KERNEL__
1645 #define V4L2_CTRL_CLASS_MPEG            V4L2_CTRL_CLASS_CODEC
1646 #define V4L2_CID_MPEG_CLASS             V4L2_CID_CODEC_CLASS
1647 #define V4L2_CID_MPEG_BASE              V4L2_CID_CODEC_BASE
1648 #define V4L2_CID_MPEG_CX2341X_BASE      V4L2_CID_CODEC_CX2341X_BASE
1649 #define V4L2_CID_MPEG_MFC51_BASE        V4L2_CID_CODEC_MFC51_BASE
1650 #endif
1651 
1652 #endif
1653