diff options
Diffstat (limited to 'Documentation/DocBook/v4l/videodev2.h.xml')
-rw-r--r-- | Documentation/DocBook/v4l/videodev2.h.xml | 1639 |
1 files changed, 1639 insertions, 0 deletions
diff --git a/Documentation/DocBook/v4l/videodev2.h.xml b/Documentation/DocBook/v4l/videodev2.h.xml new file mode 100644 index 000000000000..6a8e13940699 --- /dev/null +++ b/Documentation/DocBook/v4l/videodev2.h.xml | |||
@@ -0,0 +1,1639 @@ | |||
1 | <programlisting> | ||
2 | /* | ||
3 | * Video for Linux Two header file | ||
4 | * | ||
5 | * Copyright (C) 1999-2007 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 | * Header file for v4l or V4L2 drivers and applications | ||
46 | * with public API. | ||
47 | * All kernel-specific stuff were moved to media/v4l2-dev.h, so | ||
48 | * no #if __KERNEL tests are allowed here | ||
49 | * | ||
50 | * See http://linuxtv.org for more info | ||
51 | * | ||
52 | * Author: Bill Dirks <bill@thedirks.org> | ||
53 | * Justin Schoeman | ||
54 | * Hans Verkuil <hverkuil@xs4all.nl> | ||
55 | * et al. | ||
56 | */ | ||
57 | #ifndef __LINUX_VIDEODEV2_H | ||
58 | #define __LINUX_VIDEODEV2_H | ||
59 | |||
60 | #ifdef __KERNEL__ | ||
61 | #include <linux/time.h> /* need struct timeval */ | ||
62 | #else | ||
63 | #include <sys/time.h> | ||
64 | #endif | ||
65 | #include <linux/compiler.h> | ||
66 | #include <linux/ioctl.h> | ||
67 | #include <linux/types.h> | ||
68 | |||
69 | /* | ||
70 | * Common stuff for both V4L1 and V4L2 | ||
71 | * Moved from videodev.h | ||
72 | */ | ||
73 | #define VIDEO_MAX_FRAME 32 | ||
74 | |||
75 | #ifndef __KERNEL__ | ||
76 | |||
77 | /* These defines are V4L1 specific and should not be used with the V4L2 API! | ||
78 | They will be removed from this header in the future. */ | ||
79 | |||
80 | #define VID_TYPE_CAPTURE 1 /* Can capture */ | ||
81 | #define VID_TYPE_TUNER 2 /* Can tune */ | ||
82 | #define VID_TYPE_TELETEXT 4 /* Does teletext */ | ||
83 | #define VID_TYPE_OVERLAY 8 /* Overlay onto frame buffer */ | ||
84 | #define VID_TYPE_CHROMAKEY 16 /* Overlay by chromakey */ | ||
85 | #define VID_TYPE_CLIPPING 32 /* Can clip */ | ||
86 | #define VID_TYPE_FRAMERAM 64 /* Uses the frame buffer memory */ | ||
87 | #define VID_TYPE_SCALES 128 /* Scalable */ | ||
88 | #define VID_TYPE_MONOCHROME 256 /* Monochrome only */ | ||
89 | #define VID_TYPE_SUBCAPTURE 512 /* Can capture subareas of the image */ | ||
90 | #define VID_TYPE_MPEG_DECODER 1024 /* Can decode MPEG streams */ | ||
91 | #define VID_TYPE_MPEG_ENCODER 2048 /* Can encode MPEG streams */ | ||
92 | #define VID_TYPE_MJPEG_DECODER 4096 /* Can decode MJPEG streams */ | ||
93 | #define VID_TYPE_MJPEG_ENCODER 8192 /* Can encode MJPEG streams */ | ||
94 | #endif | ||
95 | |||
96 | /* | ||
97 | * M I S C E L L A N E O U S | ||
98 | */ | ||
99 | |||
100 | /* Four-character-code (FOURCC) */ | ||
101 | #define v4l2_fourcc(a, b, c, d)\ | ||
102 | ((__u32)(a) | ((__u32)(b) << 8) | ((__u32)(c) << 16) | ((__u32)(d) << 24)) | ||
103 | |||
104 | /* | ||
105 | * E N U M S | ||
106 | */ | ||
107 | enum <link linkend="v4l2-field">v4l2_field</link> { | ||
108 | V4L2_FIELD_ANY = 0, /* driver can choose from none, | ||
109 | top, bottom, interlaced | ||
110 | depending on whatever it thinks | ||
111 | is approximate ... */ | ||
112 | V4L2_FIELD_NONE = 1, /* this device has no fields ... */ | ||
113 | V4L2_FIELD_TOP = 2, /* top field only */ | ||
114 | V4L2_FIELD_BOTTOM = 3, /* bottom field only */ | ||
115 | V4L2_FIELD_INTERLACED = 4, /* both fields interlaced */ | ||
116 | V4L2_FIELD_SEQ_TB = 5, /* both fields sequential into one | ||
117 | buffer, top-bottom order */ | ||
118 | V4L2_FIELD_SEQ_BT = 6, /* same as above + bottom-top order */ | ||
119 | V4L2_FIELD_ALTERNATE = 7, /* both fields alternating into | ||
120 | separate buffers */ | ||
121 | V4L2_FIELD_INTERLACED_TB = 8, /* both fields interlaced, top field | ||
122 | first and the top field is | ||
123 | transmitted first */ | ||
124 | V4L2_FIELD_INTERLACED_BT = 9, /* both fields interlaced, top field | ||
125 | first and the bottom field is | ||
126 | transmitted first */ | ||
127 | }; | ||
128 | #define V4L2_FIELD_HAS_TOP(field) \ | ||
129 | ((field) == V4L2_FIELD_TOP ||\ | ||
130 | (field) == V4L2_FIELD_INTERLACED ||\ | ||
131 | (field) == V4L2_FIELD_INTERLACED_TB ||\ | ||
132 | (field) == V4L2_FIELD_INTERLACED_BT ||\ | ||
133 | (field) == V4L2_FIELD_SEQ_TB ||\ | ||
134 | (field) == V4L2_FIELD_SEQ_BT) | ||
135 | #define V4L2_FIELD_HAS_BOTTOM(field) \ | ||
136 | ((field) == V4L2_FIELD_BOTTOM ||\ | ||
137 | (field) == V4L2_FIELD_INTERLACED ||\ | ||
138 | (field) == V4L2_FIELD_INTERLACED_TB ||\ | ||
139 | (field) == V4L2_FIELD_INTERLACED_BT ||\ | ||
140 | (field) == V4L2_FIELD_SEQ_TB ||\ | ||
141 | (field) == V4L2_FIELD_SEQ_BT) | ||
142 | #define V4L2_FIELD_HAS_BOTH(field) \ | ||
143 | ((field) == V4L2_FIELD_INTERLACED ||\ | ||
144 | (field) == V4L2_FIELD_INTERLACED_TB ||\ | ||
145 | (field) == V4L2_FIELD_INTERLACED_BT ||\ | ||
146 | (field) == V4L2_FIELD_SEQ_TB ||\ | ||
147 | (field) == V4L2_FIELD_SEQ_BT) | ||
148 | |||
149 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> { | ||
150 | V4L2_BUF_TYPE_VIDEO_CAPTURE = 1, | ||
151 | V4L2_BUF_TYPE_VIDEO_OUTPUT = 2, | ||
152 | V4L2_BUF_TYPE_VIDEO_OVERLAY = 3, | ||
153 | V4L2_BUF_TYPE_VBI_CAPTURE = 4, | ||
154 | V4L2_BUF_TYPE_VBI_OUTPUT = 5, | ||
155 | V4L2_BUF_TYPE_SLICED_VBI_CAPTURE = 6, | ||
156 | V4L2_BUF_TYPE_SLICED_VBI_OUTPUT = 7, | ||
157 | #if 1 /*KEEP*/ | ||
158 | /* Experimental */ | ||
159 | V4L2_BUF_TYPE_VIDEO_OUTPUT_OVERLAY = 8, | ||
160 | #endif | ||
161 | V4L2_BUF_TYPE_PRIVATE = 0x80, | ||
162 | }; | ||
163 | |||
164 | enum <link linkend="v4l2-ctrl-type">v4l2_ctrl_type</link> { | ||
165 | V4L2_CTRL_TYPE_INTEGER = 1, | ||
166 | V4L2_CTRL_TYPE_BOOLEAN = 2, | ||
167 | V4L2_CTRL_TYPE_MENU = 3, | ||
168 | V4L2_CTRL_TYPE_BUTTON = 4, | ||
169 | V4L2_CTRL_TYPE_INTEGER64 = 5, | ||
170 | V4L2_CTRL_TYPE_CTRL_CLASS = 6, | ||
171 | V4L2_CTRL_TYPE_STRING = 7, | ||
172 | }; | ||
173 | |||
174 | enum <link linkend="v4l2-tuner-type">v4l2_tuner_type</link> { | ||
175 | V4L2_TUNER_RADIO = 1, | ||
176 | V4L2_TUNER_ANALOG_TV = 2, | ||
177 | V4L2_TUNER_DIGITAL_TV = 3, | ||
178 | }; | ||
179 | |||
180 | enum <link linkend="v4l2-memory">v4l2_memory</link> { | ||
181 | V4L2_MEMORY_MMAP = 1, | ||
182 | V4L2_MEMORY_USERPTR = 2, | ||
183 | V4L2_MEMORY_OVERLAY = 3, | ||
184 | }; | ||
185 | |||
186 | /* see also http://vektor.theorem.ca/graphics/ycbcr/ */ | ||
187 | enum <link linkend="v4l2-colorspace">v4l2_colorspace</link> { | ||
188 | /* ITU-R 601 -- broadcast NTSC/PAL */ | ||
189 | V4L2_COLORSPACE_SMPTE170M = 1, | ||
190 | |||
191 | /* 1125-Line (US) HDTV */ | ||
192 | V4L2_COLORSPACE_SMPTE240M = 2, | ||
193 | |||
194 | /* HD and modern captures. */ | ||
195 | V4L2_COLORSPACE_REC709 = 3, | ||
196 | |||
197 | /* broken BT878 extents (601, luma range 16-253 instead of 16-235) */ | ||
198 | V4L2_COLORSPACE_BT878 = 4, | ||
199 | |||
200 | /* These should be useful. Assume 601 extents. */ | ||
201 | V4L2_COLORSPACE_470_SYSTEM_M = 5, | ||
202 | V4L2_COLORSPACE_470_SYSTEM_BG = 6, | ||
203 | |||
204 | /* I know there will be cameras that send this. So, this is | ||
205 | * unspecified chromaticities and full 0-255 on each of the | ||
206 | * Y'CbCr components | ||
207 | */ | ||
208 | V4L2_COLORSPACE_JPEG = 7, | ||
209 | |||
210 | /* For RGB colourspaces, this is probably a good start. */ | ||
211 | V4L2_COLORSPACE_SRGB = 8, | ||
212 | }; | ||
213 | |||
214 | enum <link linkend="v4l2-priority">v4l2_priority</link> { | ||
215 | V4L2_PRIORITY_UNSET = 0, /* not initialized */ | ||
216 | V4L2_PRIORITY_BACKGROUND = 1, | ||
217 | V4L2_PRIORITY_INTERACTIVE = 2, | ||
218 | V4L2_PRIORITY_RECORD = 3, | ||
219 | V4L2_PRIORITY_DEFAULT = V4L2_PRIORITY_INTERACTIVE, | ||
220 | }; | ||
221 | |||
222 | struct <link linkend="v4l2-rect">v4l2_rect</link> { | ||
223 | __s32 left; | ||
224 | __s32 top; | ||
225 | __s32 width; | ||
226 | __s32 height; | ||
227 | }; | ||
228 | |||
229 | struct <link linkend="v4l2-fract">v4l2_fract</link> { | ||
230 | __u32 numerator; | ||
231 | __u32 denominator; | ||
232 | }; | ||
233 | |||
234 | /* | ||
235 | * D R I V E R C A P A B I L I T I E S | ||
236 | */ | ||
237 | struct <link linkend="v4l2-capability">v4l2_capability</link> { | ||
238 | __u8 driver[16]; /* i.e.ie; "bttv" */ | ||
239 | __u8 card[32]; /* i.e.ie; "Hauppauge WinTV" */ | ||
240 | __u8 bus_info[32]; /* "PCI:" + pci_name(pci_dev) */ | ||
241 | __u32 version; /* should use KERNEL_VERSION() */ | ||
242 | __u32 capabilities; /* Device capabilities */ | ||
243 | __u32 reserved[4]; | ||
244 | }; | ||
245 | |||
246 | /* Values for 'capabilities' field */ | ||
247 | #define V4L2_CAP_VIDEO_CAPTURE 0x00000001 /* Is a video capture device */ | ||
248 | #define V4L2_CAP_VIDEO_OUTPUT 0x00000002 /* Is a video output device */ | ||
249 | #define V4L2_CAP_VIDEO_OVERLAY 0x00000004 /* Can do video overlay */ | ||
250 | #define V4L2_CAP_VBI_CAPTURE 0x00000010 /* Is a raw VBI capture device */ | ||
251 | #define V4L2_CAP_VBI_OUTPUT 0x00000020 /* Is a raw VBI output device */ | ||
252 | #define V4L2_CAP_SLICED_VBI_CAPTURE 0x00000040 /* Is a sliced VBI capture device */ | ||
253 | #define V4L2_CAP_SLICED_VBI_OUTPUT 0x00000080 /* Is a sliced VBI output device */ | ||
254 | #define V4L2_CAP_RDS_CAPTURE 0x00000100 /* RDS data capture */ | ||
255 | #define V4L2_CAP_VIDEO_OUTPUT_OVERLAY 0x00000200 /* Can do video output overlay */ | ||
256 | #define V4L2_CAP_HW_FREQ_SEEK 0x00000400 /* Can do hardware frequency seek */ | ||
257 | #define V4L2_CAP_RDS_OUTPUT 0x00000800 /* Is an RDS encoder */ | ||
258 | |||
259 | #define V4L2_CAP_TUNER 0x00010000 /* has a tuner */ | ||
260 | #define V4L2_CAP_AUDIO 0x00020000 /* has audio support */ | ||
261 | #define V4L2_CAP_RADIO 0x00040000 /* is a radio device */ | ||
262 | #define V4L2_CAP_MODULATOR 0x00080000 /* has a modulator */ | ||
263 | |||
264 | #define V4L2_CAP_READWRITE 0x01000000 /* read/write systemcalls */ | ||
265 | #define V4L2_CAP_ASYNCIO 0x02000000 /* async I/O */ | ||
266 | #define V4L2_CAP_STREAMING 0x04000000 /* streaming I/O ioctls */ | ||
267 | |||
268 | /* | ||
269 | * V I D E O I M A G E F O R M A T | ||
270 | */ | ||
271 | struct <link linkend="v4l2-pix-format">v4l2_pix_format</link> { | ||
272 | __u32 width; | ||
273 | __u32 height; | ||
274 | __u32 pixelformat; | ||
275 | enum <link linkend="v4l2-field">v4l2_field</link> field; | ||
276 | __u32 bytesperline; /* for padding, zero if unused */ | ||
277 | __u32 sizeimage; | ||
278 | enum <link linkend="v4l2-colorspace">v4l2_colorspace</link> colorspace; | ||
279 | __u32 priv; /* private data, depends on pixelformat */ | ||
280 | }; | ||
281 | |||
282 | /* Pixel format FOURCC depth Description */ | ||
283 | |||
284 | /* RGB formats */ | ||
285 | #define <link linkend="V4L2-PIX-FMT-RGB332">V4L2_PIX_FMT_RGB332</link> v4l2_fourcc('R', 'G', 'B', '1') /* 8 RGB-3-3-2 */ | ||
286 | #define <link linkend="V4L2-PIX-FMT-RGB444">V4L2_PIX_FMT_RGB444</link> v4l2_fourcc('R', '4', '4', '4') /* 16 xxxxrrrr ggggbbbb */ | ||
287 | #define <link linkend="V4L2-PIX-FMT-RGB555">V4L2_PIX_FMT_RGB555</link> v4l2_fourcc('R', 'G', 'B', 'O') /* 16 RGB-5-5-5 */ | ||
288 | #define <link linkend="V4L2-PIX-FMT-RGB565">V4L2_PIX_FMT_RGB565</link> v4l2_fourcc('R', 'G', 'B', 'P') /* 16 RGB-5-6-5 */ | ||
289 | #define <link linkend="V4L2-PIX-FMT-RGB555X">V4L2_PIX_FMT_RGB555X</link> v4l2_fourcc('R', 'G', 'B', 'Q') /* 16 RGB-5-5-5 BE */ | ||
290 | #define <link linkend="V4L2-PIX-FMT-RGB565X">V4L2_PIX_FMT_RGB565X</link> v4l2_fourcc('R', 'G', 'B', 'R') /* 16 RGB-5-6-5 BE */ | ||
291 | #define <link linkend="V4L2-PIX-FMT-BGR24">V4L2_PIX_FMT_BGR24</link> v4l2_fourcc('B', 'G', 'R', '3') /* 24 BGR-8-8-8 */ | ||
292 | #define <link linkend="V4L2-PIX-FMT-RGB24">V4L2_PIX_FMT_RGB24</link> v4l2_fourcc('R', 'G', 'B', '3') /* 24 RGB-8-8-8 */ | ||
293 | #define <link linkend="V4L2-PIX-FMT-BGR32">V4L2_PIX_FMT_BGR32</link> v4l2_fourcc('B', 'G', 'R', '4') /* 32 BGR-8-8-8-8 */ | ||
294 | #define <link linkend="V4L2-PIX-FMT-RGB32">V4L2_PIX_FMT_RGB32</link> v4l2_fourcc('R', 'G', 'B', '4') /* 32 RGB-8-8-8-8 */ | ||
295 | |||
296 | /* Grey formats */ | ||
297 | #define <link linkend="V4L2-PIX-FMT-GREY">V4L2_PIX_FMT_GREY</link> v4l2_fourcc('G', 'R', 'E', 'Y') /* 8 Greyscale */ | ||
298 | #define <link linkend="V4L2-PIX-FMT-Y16">V4L2_PIX_FMT_Y16</link> v4l2_fourcc('Y', '1', '6', ' ') /* 16 Greyscale */ | ||
299 | |||
300 | /* Palette formats */ | ||
301 | #define <link linkend="V4L2-PIX-FMT-PAL8">V4L2_PIX_FMT_PAL8</link> v4l2_fourcc('P', 'A', 'L', '8') /* 8 8-bit palette */ | ||
302 | |||
303 | /* Luminance+Chrominance formats */ | ||
304 | #define <link linkend="V4L2-PIX-FMT-YVU410">V4L2_PIX_FMT_YVU410</link> v4l2_fourcc('Y', 'V', 'U', '9') /* 9 YVU 4:1:0 */ | ||
305 | #define <link linkend="V4L2-PIX-FMT-YVU420">V4L2_PIX_FMT_YVU420</link> v4l2_fourcc('Y', 'V', '1', '2') /* 12 YVU 4:2:0 */ | ||
306 | #define <link linkend="V4L2-PIX-FMT-YUYV">V4L2_PIX_FMT_YUYV</link> v4l2_fourcc('Y', 'U', 'Y', 'V') /* 16 YUV 4:2:2 */ | ||
307 | #define <link linkend="V4L2-PIX-FMT-YYUV">V4L2_PIX_FMT_YYUV</link> v4l2_fourcc('Y', 'Y', 'U', 'V') /* 16 YUV 4:2:2 */ | ||
308 | #define <link linkend="V4L2-PIX-FMT-YVYU">V4L2_PIX_FMT_YVYU</link> v4l2_fourcc('Y', 'V', 'Y', 'U') /* 16 YVU 4:2:2 */ | ||
309 | #define <link linkend="V4L2-PIX-FMT-UYVY">V4L2_PIX_FMT_UYVY</link> v4l2_fourcc('U', 'Y', 'V', 'Y') /* 16 YUV 4:2:2 */ | ||
310 | #define <link linkend="V4L2-PIX-FMT-VYUY">V4L2_PIX_FMT_VYUY</link> v4l2_fourcc('V', 'Y', 'U', 'Y') /* 16 YUV 4:2:2 */ | ||
311 | #define <link linkend="V4L2-PIX-FMT-YUV422P">V4L2_PIX_FMT_YUV422P</link> v4l2_fourcc('4', '2', '2', 'P') /* 16 YVU422 planar */ | ||
312 | #define <link linkend="V4L2-PIX-FMT-YUV411P">V4L2_PIX_FMT_YUV411P</link> v4l2_fourcc('4', '1', '1', 'P') /* 16 YVU411 planar */ | ||
313 | #define <link linkend="V4L2-PIX-FMT-Y41P">V4L2_PIX_FMT_Y41P</link> v4l2_fourcc('Y', '4', '1', 'P') /* 12 YUV 4:1:1 */ | ||
314 | #define <link linkend="V4L2-PIX-FMT-YUV444">V4L2_PIX_FMT_YUV444</link> v4l2_fourcc('Y', '4', '4', '4') /* 16 xxxxyyyy uuuuvvvv */ | ||
315 | #define <link linkend="V4L2-PIX-FMT-YUV555">V4L2_PIX_FMT_YUV555</link> v4l2_fourcc('Y', 'U', 'V', 'O') /* 16 YUV-5-5-5 */ | ||
316 | #define <link linkend="V4L2-PIX-FMT-YUV565">V4L2_PIX_FMT_YUV565</link> v4l2_fourcc('Y', 'U', 'V', 'P') /* 16 YUV-5-6-5 */ | ||
317 | #define <link linkend="V4L2-PIX-FMT-YUV32">V4L2_PIX_FMT_YUV32</link> v4l2_fourcc('Y', 'U', 'V', '4') /* 32 YUV-8-8-8-8 */ | ||
318 | #define <link linkend="V4L2-PIX-FMT-YUV410">V4L2_PIX_FMT_YUV410</link> v4l2_fourcc('Y', 'U', 'V', '9') /* 9 YUV 4:1:0 */ | ||
319 | #define <link linkend="V4L2-PIX-FMT-YUV420">V4L2_PIX_FMT_YUV420</link> v4l2_fourcc('Y', 'U', '1', '2') /* 12 YUV 4:2:0 */ | ||
320 | #define <link linkend="V4L2-PIX-FMT-HI240">V4L2_PIX_FMT_HI240</link> v4l2_fourcc('H', 'I', '2', '4') /* 8 8-bit color */ | ||
321 | #define <link linkend="V4L2-PIX-FMT-HM12">V4L2_PIX_FMT_HM12</link> v4l2_fourcc('H', 'M', '1', '2') /* 8 YUV 4:2:0 16x16 macroblocks */ | ||
322 | |||
323 | /* two planes -- one Y, one Cr + Cb interleaved */ | ||
324 | #define <link linkend="V4L2-PIX-FMT-NV12">V4L2_PIX_FMT_NV12</link> v4l2_fourcc('N', 'V', '1', '2') /* 12 Y/CbCr 4:2:0 */ | ||
325 | #define <link linkend="V4L2-PIX-FMT-NV21">V4L2_PIX_FMT_NV21</link> v4l2_fourcc('N', 'V', '2', '1') /* 12 Y/CrCb 4:2:0 */ | ||
326 | #define <link linkend="V4L2-PIX-FMT-NV16">V4L2_PIX_FMT_NV16</link> v4l2_fourcc('N', 'V', '1', '6') /* 16 Y/CbCr 4:2:2 */ | ||
327 | #define <link linkend="V4L2-PIX-FMT-NV61">V4L2_PIX_FMT_NV61</link> v4l2_fourcc('N', 'V', '6', '1') /* 16 Y/CrCb 4:2:2 */ | ||
328 | |||
329 | /* Bayer formats - see http://www.siliconimaging.com/RGB%20Bayer.htm */ | ||
330 | #define <link linkend="V4L2-PIX-FMT-SBGGR8">V4L2_PIX_FMT_SBGGR8</link> v4l2_fourcc('B', 'A', '8', '1') /* 8 BGBG.. GRGR.. */ | ||
331 | #define <link linkend="V4L2-PIX-FMT-SGBRG8">V4L2_PIX_FMT_SGBRG8</link> v4l2_fourcc('G', 'B', 'R', 'G') /* 8 GBGB.. RGRG.. */ | ||
332 | #define <link linkend="V4L2-PIX-FMT-SGRBG8">V4L2_PIX_FMT_SGRBG8</link> v4l2_fourcc('G', 'R', 'B', 'G') /* 8 GRGR.. BGBG.. */ | ||
333 | #define <link linkend="V4L2-PIX-FMT-SGRBG10">V4L2_PIX_FMT_SGRBG10</link> v4l2_fourcc('B', 'A', '1', '0') /* 10bit raw bayer */ | ||
334 | /* 10bit raw bayer DPCM compressed to 8 bits */ | ||
335 | #define <link linkend="V4L2-PIX-FMT-SGRBG10DPCM8">V4L2_PIX_FMT_SGRBG10DPCM8</link> v4l2_fourcc('B', 'D', '1', '0') | ||
336 | /* | ||
337 | * 10bit raw bayer, expanded to 16 bits | ||
338 | * xxxxrrrrrrrrrrxxxxgggggggggg xxxxggggggggggxxxxbbbbbbbbbb... | ||
339 | */ | ||
340 | #define <link linkend="V4L2-PIX-FMT-SBGGR16">V4L2_PIX_FMT_SBGGR16</link> v4l2_fourcc('B', 'Y', 'R', '2') /* 16 BGBG.. GRGR.. */ | ||
341 | |||
342 | /* compressed formats */ | ||
343 | #define <link linkend="V4L2-PIX-FMT-MJPEG">V4L2_PIX_FMT_MJPEG</link> v4l2_fourcc('M', 'J', 'P', 'G') /* Motion-JPEG */ | ||
344 | #define <link linkend="V4L2-PIX-FMT-JPEG">V4L2_PIX_FMT_JPEG</link> v4l2_fourcc('J', 'P', 'E', 'G') /* JFIF JPEG */ | ||
345 | #define <link linkend="V4L2-PIX-FMT-DV">V4L2_PIX_FMT_DV</link> v4l2_fourcc('d', 'v', 's', 'd') /* 1394 */ | ||
346 | #define <link linkend="V4L2-PIX-FMT-MPEG">V4L2_PIX_FMT_MPEG</link> v4l2_fourcc('M', 'P', 'E', 'G') /* MPEG-1/2/4 */ | ||
347 | |||
348 | /* Vendor-specific formats */ | ||
349 | #define <link linkend="V4L2-PIX-FMT-WNVA">V4L2_PIX_FMT_WNVA</link> v4l2_fourcc('W', 'N', 'V', 'A') /* Winnov hw compress */ | ||
350 | #define <link linkend="V4L2-PIX-FMT-SN9C10X">V4L2_PIX_FMT_SN9C10X</link> v4l2_fourcc('S', '9', '1', '0') /* SN9C10x compression */ | ||
351 | #define <link linkend="V4L2-PIX-FMT-SN9C20X-I420">V4L2_PIX_FMT_SN9C20X_I420</link> v4l2_fourcc('S', '9', '2', '0') /* SN9C20x YUV 4:2:0 */ | ||
352 | #define <link linkend="V4L2-PIX-FMT-PWC1">V4L2_PIX_FMT_PWC1</link> v4l2_fourcc('P', 'W', 'C', '1') /* pwc older webcam */ | ||
353 | #define <link linkend="V4L2-PIX-FMT-PWC2">V4L2_PIX_FMT_PWC2</link> v4l2_fourcc('P', 'W', 'C', '2') /* pwc newer webcam */ | ||
354 | #define <link linkend="V4L2-PIX-FMT-ET61X251">V4L2_PIX_FMT_ET61X251</link> v4l2_fourcc('E', '6', '2', '5') /* ET61X251 compression */ | ||
355 | #define <link linkend="V4L2-PIX-FMT-SPCA501">V4L2_PIX_FMT_SPCA501</link> v4l2_fourcc('S', '5', '0', '1') /* YUYV per line */ | ||
356 | #define <link linkend="V4L2-PIX-FMT-SPCA505">V4L2_PIX_FMT_SPCA505</link> v4l2_fourcc('S', '5', '0', '5') /* YYUV per line */ | ||
357 | #define <link linkend="V4L2-PIX-FMT-SPCA508">V4L2_PIX_FMT_SPCA508</link> v4l2_fourcc('S', '5', '0', '8') /* YUVY per line */ | ||
358 | #define <link linkend="V4L2-PIX-FMT-SPCA561">V4L2_PIX_FMT_SPCA561</link> v4l2_fourcc('S', '5', '6', '1') /* compressed GBRG bayer */ | ||
359 | #define <link linkend="V4L2-PIX-FMT-PAC207">V4L2_PIX_FMT_PAC207</link> v4l2_fourcc('P', '2', '0', '7') /* compressed BGGR bayer */ | ||
360 | #define <link linkend="V4L2-PIX-FMT-MR97310A">V4L2_PIX_FMT_MR97310A</link> v4l2_fourcc('M', '3', '1', '0') /* compressed BGGR bayer */ | ||
361 | #define <link linkend="V4L2-PIX-FMT-SQ905C">V4L2_PIX_FMT_SQ905C</link> v4l2_fourcc('9', '0', '5', 'C') /* compressed RGGB bayer */ | ||
362 | #define <link linkend="V4L2-PIX-FMT-PJPG">V4L2_PIX_FMT_PJPG</link> v4l2_fourcc('P', 'J', 'P', 'G') /* Pixart 73xx JPEG */ | ||
363 | #define <link linkend="V4L2-PIX-FMT-OV511">V4L2_PIX_FMT_OV511</link> v4l2_fourcc('O', '5', '1', '1') /* ov511 JPEG */ | ||
364 | #define <link linkend="V4L2-PIX-FMT-OV518">V4L2_PIX_FMT_OV518</link> v4l2_fourcc('O', '5', '1', '8') /* ov518 JPEG */ | ||
365 | |||
366 | /* | ||
367 | * F O R M A T E N U M E R A T I O N | ||
368 | */ | ||
369 | struct <link linkend="v4l2-fmtdesc">v4l2_fmtdesc</link> { | ||
370 | __u32 index; /* Format number */ | ||
371 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> type; /* buffer type */ | ||
372 | __u32 flags; | ||
373 | __u8 description[32]; /* Description string */ | ||
374 | __u32 pixelformat; /* Format fourcc */ | ||
375 | __u32 reserved[4]; | ||
376 | }; | ||
377 | |||
378 | #define V4L2_FMT_FLAG_COMPRESSED 0x0001 | ||
379 | #define V4L2_FMT_FLAG_EMULATED 0x0002 | ||
380 | |||
381 | #if 1 /*KEEP*/ | ||
382 | /* Experimental Frame Size and frame rate enumeration */ | ||
383 | /* | ||
384 | * F R A M E S I Z E E N U M E R A T I O N | ||
385 | */ | ||
386 | enum <link linkend="v4l2-frmsizetypes">v4l2_frmsizetypes</link> { | ||
387 | V4L2_FRMSIZE_TYPE_DISCRETE = 1, | ||
388 | V4L2_FRMSIZE_TYPE_CONTINUOUS = 2, | ||
389 | V4L2_FRMSIZE_TYPE_STEPWISE = 3, | ||
390 | }; | ||
391 | |||
392 | struct <link linkend="v4l2-frmsize-discrete">v4l2_frmsize_discrete</link> { | ||
393 | __u32 width; /* Frame width [pixel] */ | ||
394 | __u32 height; /* Frame height [pixel] */ | ||
395 | }; | ||
396 | |||
397 | struct <link linkend="v4l2-frmsize-stepwise">v4l2_frmsize_stepwise</link> { | ||
398 | __u32 min_width; /* Minimum frame width [pixel] */ | ||
399 | __u32 max_width; /* Maximum frame width [pixel] */ | ||
400 | __u32 step_width; /* Frame width step size [pixel] */ | ||
401 | __u32 min_height; /* Minimum frame height [pixel] */ | ||
402 | __u32 max_height; /* Maximum frame height [pixel] */ | ||
403 | __u32 step_height; /* Frame height step size [pixel] */ | ||
404 | }; | ||
405 | |||
406 | struct <link linkend="v4l2-frmsizeenum">v4l2_frmsizeenum</link> { | ||
407 | __u32 index; /* Frame size number */ | ||
408 | __u32 pixel_format; /* Pixel format */ | ||
409 | __u32 type; /* Frame size type the device supports. */ | ||
410 | |||
411 | union { /* Frame size */ | ||
412 | struct <link linkend="v4l2-frmsize-discrete">v4l2_frmsize_discrete</link> discrete; | ||
413 | struct <link linkend="v4l2-frmsize-stepwise">v4l2_frmsize_stepwise</link> stepwise; | ||
414 | }; | ||
415 | |||
416 | __u32 reserved[2]; /* Reserved space for future use */ | ||
417 | }; | ||
418 | |||
419 | /* | ||
420 | * F R A M E R A T E E N U M E R A T I O N | ||
421 | */ | ||
422 | enum <link linkend="v4l2-frmivaltypes">v4l2_frmivaltypes</link> { | ||
423 | V4L2_FRMIVAL_TYPE_DISCRETE = 1, | ||
424 | V4L2_FRMIVAL_TYPE_CONTINUOUS = 2, | ||
425 | V4L2_FRMIVAL_TYPE_STEPWISE = 3, | ||
426 | }; | ||
427 | |||
428 | struct <link linkend="v4l2-frmival-stepwise">v4l2_frmival_stepwise</link> { | ||
429 | struct <link linkend="v4l2-fract">v4l2_fract</link> min; /* Minimum frame interval [s] */ | ||
430 | struct <link linkend="v4l2-fract">v4l2_fract</link> max; /* Maximum frame interval [s] */ | ||
431 | struct <link linkend="v4l2-fract">v4l2_fract</link> step; /* Frame interval step size [s] */ | ||
432 | }; | ||
433 | |||
434 | struct <link linkend="v4l2-frmivalenum">v4l2_frmivalenum</link> { | ||
435 | __u32 index; /* Frame format index */ | ||
436 | __u32 pixel_format; /* Pixel format */ | ||
437 | __u32 width; /* Frame width */ | ||
438 | __u32 height; /* Frame height */ | ||
439 | __u32 type; /* Frame interval type the device supports. */ | ||
440 | |||
441 | union { /* Frame interval */ | ||
442 | struct <link linkend="v4l2-fract">v4l2_fract</link> discrete; | ||
443 | struct <link linkend="v4l2-frmival-stepwise">v4l2_frmival_stepwise</link> stepwise; | ||
444 | }; | ||
445 | |||
446 | __u32 reserved[2]; /* Reserved space for future use */ | ||
447 | }; | ||
448 | #endif | ||
449 | |||
450 | /* | ||
451 | * T I M E C O D E | ||
452 | */ | ||
453 | struct <link linkend="v4l2-timecode">v4l2_timecode</link> { | ||
454 | __u32 type; | ||
455 | __u32 flags; | ||
456 | __u8 frames; | ||
457 | __u8 seconds; | ||
458 | __u8 minutes; | ||
459 | __u8 hours; | ||
460 | __u8 userbits[4]; | ||
461 | }; | ||
462 | |||
463 | /* Type */ | ||
464 | #define V4L2_TC_TYPE_24FPS 1 | ||
465 | #define V4L2_TC_TYPE_25FPS 2 | ||
466 | #define V4L2_TC_TYPE_30FPS 3 | ||
467 | #define V4L2_TC_TYPE_50FPS 4 | ||
468 | #define V4L2_TC_TYPE_60FPS 5 | ||
469 | |||
470 | /* Flags */ | ||
471 | #define V4L2_TC_FLAG_DROPFRAME 0x0001 /* "drop-frame" mode */ | ||
472 | #define V4L2_TC_FLAG_COLORFRAME 0x0002 | ||
473 | #define V4L2_TC_USERBITS_field 0x000C | ||
474 | #define V4L2_TC_USERBITS_USERDEFINED 0x0000 | ||
475 | #define V4L2_TC_USERBITS_8BITCHARS 0x0008 | ||
476 | /* The above is based on SMPTE timecodes */ | ||
477 | |||
478 | struct <link linkend="v4l2-jpegcompression">v4l2_jpegcompression</link> { | ||
479 | int quality; | ||
480 | |||
481 | int APPn; /* Number of APP segment to be written, | ||
482 | * must be 0..15 */ | ||
483 | int APP_len; /* Length of data in JPEG APPn segment */ | ||
484 | char APP_data[60]; /* Data in the JPEG APPn segment. */ | ||
485 | |||
486 | int COM_len; /* Length of data in JPEG COM segment */ | ||
487 | char COM_data[60]; /* Data in JPEG COM segment */ | ||
488 | |||
489 | __u32 jpeg_markers; /* Which markers should go into the JPEG | ||
490 | * output. Unless you exactly know what | ||
491 | * you do, leave them untouched. | ||
492 | * Inluding less markers will make the | ||
493 | * resulting code smaller, but there will | ||
494 | * be fewer aplications which can read it. | ||
495 | * The presence of the APP and COM marker | ||
496 | * is influenced by APP_len and COM_len | ||
497 | * ONLY, not by this property! */ | ||
498 | |||
499 | #define V4L2_JPEG_MARKER_DHT (1<<3) /* Define Huffman Tables */ | ||
500 | #define V4L2_JPEG_MARKER_DQT (1<<4) /* Define Quantization Tables */ | ||
501 | #define V4L2_JPEG_MARKER_DRI (1<<5) /* Define Restart Interval */ | ||
502 | #define V4L2_JPEG_MARKER_COM (1<<6) /* Comment segment */ | ||
503 | #define V4L2_JPEG_MARKER_APP (1<<7) /* App segment, driver will | ||
504 | * allways use APP0 */ | ||
505 | }; | ||
506 | |||
507 | /* | ||
508 | * M E M O R Y - M A P P I N G B U F F E R S | ||
509 | */ | ||
510 | struct <link linkend="v4l2-requestbuffers">v4l2_requestbuffers</link> { | ||
511 | __u32 count; | ||
512 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> type; | ||
513 | enum <link linkend="v4l2-memory">v4l2_memory</link> memory; | ||
514 | __u32 reserved[2]; | ||
515 | }; | ||
516 | |||
517 | struct <link linkend="v4l2-buffer">v4l2_buffer</link> { | ||
518 | __u32 index; | ||
519 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> type; | ||
520 | __u32 bytesused; | ||
521 | __u32 flags; | ||
522 | enum <link linkend="v4l2-field">v4l2_field</link> field; | ||
523 | struct timeval timestamp; | ||
524 | struct <link linkend="v4l2-timecode">v4l2_timecode</link> timecode; | ||
525 | __u32 sequence; | ||
526 | |||
527 | /* memory location */ | ||
528 | enum <link linkend="v4l2-memory">v4l2_memory</link> memory; | ||
529 | union { | ||
530 | __u32 offset; | ||
531 | unsigned long userptr; | ||
532 | } m; | ||
533 | __u32 length; | ||
534 | __u32 input; | ||
535 | __u32 reserved; | ||
536 | }; | ||
537 | |||
538 | /* Flags for 'flags' field */ | ||
539 | #define V4L2_BUF_FLAG_MAPPED 0x0001 /* Buffer is mapped (flag) */ | ||
540 | #define V4L2_BUF_FLAG_QUEUED 0x0002 /* Buffer is queued for processing */ | ||
541 | #define V4L2_BUF_FLAG_DONE 0x0004 /* Buffer is ready */ | ||
542 | #define V4L2_BUF_FLAG_KEYFRAME 0x0008 /* Image is a keyframe (I-frame) */ | ||
543 | #define V4L2_BUF_FLAG_PFRAME 0x0010 /* Image is a P-frame */ | ||
544 | #define V4L2_BUF_FLAG_BFRAME 0x0020 /* Image is a B-frame */ | ||
545 | #define V4L2_BUF_FLAG_TIMECODE 0x0100 /* timecode field is valid */ | ||
546 | #define V4L2_BUF_FLAG_INPUT 0x0200 /* input field is valid */ | ||
547 | |||
548 | /* | ||
549 | * O V E R L A Y P R E V I E W | ||
550 | */ | ||
551 | struct <link linkend="v4l2-framebuffer">v4l2_framebuffer</link> { | ||
552 | __u32 capability; | ||
553 | __u32 flags; | ||
554 | /* FIXME: in theory we should pass something like PCI device + memory | ||
555 | * region + offset instead of some physical address */ | ||
556 | void *base; | ||
557 | struct <link linkend="v4l2-pix-format">v4l2_pix_format</link> fmt; | ||
558 | }; | ||
559 | /* Flags for the 'capability' field. Read only */ | ||
560 | #define V4L2_FBUF_CAP_EXTERNOVERLAY 0x0001 | ||
561 | #define V4L2_FBUF_CAP_CHROMAKEY 0x0002 | ||
562 | #define V4L2_FBUF_CAP_LIST_CLIPPING 0x0004 | ||
563 | #define V4L2_FBUF_CAP_BITMAP_CLIPPING 0x0008 | ||
564 | #define V4L2_FBUF_CAP_LOCAL_ALPHA 0x0010 | ||
565 | #define V4L2_FBUF_CAP_GLOBAL_ALPHA 0x0020 | ||
566 | #define V4L2_FBUF_CAP_LOCAL_INV_ALPHA 0x0040 | ||
567 | /* Flags for the 'flags' field. */ | ||
568 | #define V4L2_FBUF_FLAG_PRIMARY 0x0001 | ||
569 | #define V4L2_FBUF_FLAG_OVERLAY 0x0002 | ||
570 | #define V4L2_FBUF_FLAG_CHROMAKEY 0x0004 | ||
571 | #define V4L2_FBUF_FLAG_LOCAL_ALPHA 0x0008 | ||
572 | #define V4L2_FBUF_FLAG_GLOBAL_ALPHA 0x0010 | ||
573 | #define V4L2_FBUF_FLAG_LOCAL_INV_ALPHA 0x0020 | ||
574 | |||
575 | struct <link linkend="v4l2-clip">v4l2_clip</link> { | ||
576 | struct <link linkend="v4l2-rect">v4l2_rect</link> c; | ||
577 | struct <link linkend="v4l2-clip">v4l2_clip</link> __user *next; | ||
578 | }; | ||
579 | |||
580 | struct <link linkend="v4l2-window">v4l2_window</link> { | ||
581 | struct <link linkend="v4l2-rect">v4l2_rect</link> w; | ||
582 | enum <link linkend="v4l2-field">v4l2_field</link> field; | ||
583 | __u32 chromakey; | ||
584 | struct <link linkend="v4l2-clip">v4l2_clip</link> __user *clips; | ||
585 | __u32 clipcount; | ||
586 | void __user *bitmap; | ||
587 | __u8 global_alpha; | ||
588 | }; | ||
589 | |||
590 | /* | ||
591 | * C A P T U R E P A R A M E T E R S | ||
592 | */ | ||
593 | struct <link linkend="v4l2-captureparm">v4l2_captureparm</link> { | ||
594 | __u32 capability; /* Supported modes */ | ||
595 | __u32 capturemode; /* Current mode */ | ||
596 | struct <link linkend="v4l2-fract">v4l2_fract</link> timeperframe; /* Time per frame in .1us units */ | ||
597 | __u32 extendedmode; /* Driver-specific extensions */ | ||
598 | __u32 readbuffers; /* # of buffers for read */ | ||
599 | __u32 reserved[4]; | ||
600 | }; | ||
601 | |||
602 | /* Flags for 'capability' and 'capturemode' fields */ | ||
603 | #define V4L2_MODE_HIGHQUALITY 0x0001 /* High quality imaging mode */ | ||
604 | #define V4L2_CAP_TIMEPERFRAME 0x1000 /* timeperframe field is supported */ | ||
605 | |||
606 | struct <link linkend="v4l2-outputparm">v4l2_outputparm</link> { | ||
607 | __u32 capability; /* Supported modes */ | ||
608 | __u32 outputmode; /* Current mode */ | ||
609 | struct <link linkend="v4l2-fract">v4l2_fract</link> timeperframe; /* Time per frame in seconds */ | ||
610 | __u32 extendedmode; /* Driver-specific extensions */ | ||
611 | __u32 writebuffers; /* # of buffers for write */ | ||
612 | __u32 reserved[4]; | ||
613 | }; | ||
614 | |||
615 | /* | ||
616 | * I N P U T I M A G E C R O P P I N G | ||
617 | */ | ||
618 | struct <link linkend="v4l2-cropcap">v4l2_cropcap</link> { | ||
619 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> type; | ||
620 | struct <link linkend="v4l2-rect">v4l2_rect</link> bounds; | ||
621 | struct <link linkend="v4l2-rect">v4l2_rect</link> defrect; | ||
622 | struct <link linkend="v4l2-fract">v4l2_fract</link> pixelaspect; | ||
623 | }; | ||
624 | |||
625 | struct <link linkend="v4l2-crop">v4l2_crop</link> { | ||
626 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> type; | ||
627 | struct <link linkend="v4l2-rect">v4l2_rect</link> c; | ||
628 | }; | ||
629 | |||
630 | /* | ||
631 | * A N A L O G V I D E O S T A N D A R D | ||
632 | */ | ||
633 | |||
634 | typedef __u64 v4l2_std_id; | ||
635 | |||
636 | /* one bit for each */ | ||
637 | #define V4L2_STD_PAL_B ((v4l2_std_id)0x00000001) | ||
638 | #define V4L2_STD_PAL_B1 ((v4l2_std_id)0x00000002) | ||
639 | #define V4L2_STD_PAL_G ((v4l2_std_id)0x00000004) | ||
640 | #define V4L2_STD_PAL_H ((v4l2_std_id)0x00000008) | ||
641 | #define V4L2_STD_PAL_I ((v4l2_std_id)0x00000010) | ||
642 | #define V4L2_STD_PAL_D ((v4l2_std_id)0x00000020) | ||
643 | #define V4L2_STD_PAL_D1 ((v4l2_std_id)0x00000040) | ||
644 | #define V4L2_STD_PAL_K ((v4l2_std_id)0x00000080) | ||
645 | |||
646 | #define V4L2_STD_PAL_M ((v4l2_std_id)0x00000100) | ||
647 | #define V4L2_STD_PAL_N ((v4l2_std_id)0x00000200) | ||
648 | #define V4L2_STD_PAL_Nc ((v4l2_std_id)0x00000400) | ||
649 | #define V4L2_STD_PAL_60 ((v4l2_std_id)0x00000800) | ||
650 | |||
651 | #define V4L2_STD_NTSC_M ((v4l2_std_id)0x00001000) | ||
652 | #define V4L2_STD_NTSC_M_JP ((v4l2_std_id)0x00002000) | ||
653 | #define V4L2_STD_NTSC_443 ((v4l2_std_id)0x00004000) | ||
654 | #define V4L2_STD_NTSC_M_KR ((v4l2_std_id)0x00008000) | ||
655 | |||
656 | #define V4L2_STD_SECAM_B ((v4l2_std_id)0x00010000) | ||
657 | #define V4L2_STD_SECAM_D ((v4l2_std_id)0x00020000) | ||
658 | #define V4L2_STD_SECAM_G ((v4l2_std_id)0x00040000) | ||
659 | #define V4L2_STD_SECAM_H ((v4l2_std_id)0x00080000) | ||
660 | #define V4L2_STD_SECAM_K ((v4l2_std_id)0x00100000) | ||
661 | #define V4L2_STD_SECAM_K1 ((v4l2_std_id)0x00200000) | ||
662 | #define V4L2_STD_SECAM_L ((v4l2_std_id)0x00400000) | ||
663 | #define V4L2_STD_SECAM_LC ((v4l2_std_id)0x00800000) | ||
664 | |||
665 | /* ATSC/HDTV */ | ||
666 | #define V4L2_STD_ATSC_8_VSB ((v4l2_std_id)0x01000000) | ||
667 | #define V4L2_STD_ATSC_16_VSB ((v4l2_std_id)0x02000000) | ||
668 | |||
669 | /* FIXME: | ||
670 | Although std_id is 64 bits, there is an issue on PPC32 architecture that | ||
671 | makes switch(__u64) to break. So, there's a hack on v4l2-common.c rounding | ||
672 | this value to 32 bits. | ||
673 | As, currently, the max value is for V4L2_STD_ATSC_16_VSB (30 bits wide), | ||
674 | it should work fine. However, if needed to add more than two standards, | ||
675 | v4l2-common.c should be fixed. | ||
676 | */ | ||
677 | |||
678 | /* some merged standards */ | ||
679 | #define V4L2_STD_MN (V4L2_STD_PAL_M|V4L2_STD_PAL_N|V4L2_STD_PAL_Nc|V4L2_STD_NTSC) | ||
680 | #define V4L2_STD_B (V4L2_STD_PAL_B|V4L2_STD_PAL_B1|V4L2_STD_SECAM_B) | ||
681 | #define V4L2_STD_GH (V4L2_STD_PAL_G|V4L2_STD_PAL_H|V4L2_STD_SECAM_G|V4L2_STD_SECAM_H) | ||
682 | #define V4L2_STD_DK (V4L2_STD_PAL_DK|V4L2_STD_SECAM_DK) | ||
683 | |||
684 | /* some common needed stuff */ | ||
685 | #define V4L2_STD_PAL_BG (V4L2_STD_PAL_B |\ | ||
686 | V4L2_STD_PAL_B1 |\ | ||
687 | V4L2_STD_PAL_G) | ||
688 | #define V4L2_STD_PAL_DK (V4L2_STD_PAL_D |\ | ||
689 | V4L2_STD_PAL_D1 |\ | ||
690 | V4L2_STD_PAL_K) | ||
691 | #define V4L2_STD_PAL (V4L2_STD_PAL_BG |\ | ||
692 | V4L2_STD_PAL_DK |\ | ||
693 | V4L2_STD_PAL_H |\ | ||
694 | V4L2_STD_PAL_I) | ||
695 | #define V4L2_STD_NTSC (V4L2_STD_NTSC_M |\ | ||
696 | V4L2_STD_NTSC_M_JP |\ | ||
697 | V4L2_STD_NTSC_M_KR) | ||
698 | #define V4L2_STD_SECAM_DK (V4L2_STD_SECAM_D |\ | ||
699 | V4L2_STD_SECAM_K |\ | ||
700 | V4L2_STD_SECAM_K1) | ||
701 | #define V4L2_STD_SECAM (V4L2_STD_SECAM_B |\ | ||
702 | V4L2_STD_SECAM_G |\ | ||
703 | V4L2_STD_SECAM_H |\ | ||
704 | V4L2_STD_SECAM_DK |\ | ||
705 | V4L2_STD_SECAM_L |\ | ||
706 | V4L2_STD_SECAM_LC) | ||
707 | |||
708 | #define V4L2_STD_525_60 (V4L2_STD_PAL_M |\ | ||
709 | V4L2_STD_PAL_60 |\ | ||
710 | V4L2_STD_NTSC |\ | ||
711 | V4L2_STD_NTSC_443) | ||
712 | #define V4L2_STD_625_50 (V4L2_STD_PAL |\ | ||
713 | V4L2_STD_PAL_N |\ | ||
714 | V4L2_STD_PAL_Nc |\ | ||
715 | V4L2_STD_SECAM) | ||
716 | #define V4L2_STD_ATSC (V4L2_STD_ATSC_8_VSB |\ | ||
717 | V4L2_STD_ATSC_16_VSB) | ||
718 | |||
719 | #define V4L2_STD_UNKNOWN 0 | ||
720 | #define V4L2_STD_ALL (V4L2_STD_525_60 |\ | ||
721 | V4L2_STD_625_50) | ||
722 | |||
723 | struct <link linkend="v4l2-standard">v4l2_standard</link> { | ||
724 | __u32 index; | ||
725 | v4l2_std_id id; | ||
726 | __u8 name[24]; | ||
727 | struct <link linkend="v4l2-fract">v4l2_fract</link> frameperiod; /* Frames, not fields */ | ||
728 | __u32 framelines; | ||
729 | __u32 reserved[4]; | ||
730 | }; | ||
731 | |||
732 | /* | ||
733 | * V I D E O I N P U T S | ||
734 | */ | ||
735 | struct <link linkend="v4l2-input">v4l2_input</link> { | ||
736 | __u32 index; /* Which input */ | ||
737 | __u8 name[32]; /* Label */ | ||
738 | __u32 type; /* Type of input */ | ||
739 | __u32 audioset; /* Associated audios (bitfield) */ | ||
740 | __u32 tuner; /* Associated tuner */ | ||
741 | v4l2_std_id std; | ||
742 | __u32 status; | ||
743 | __u32 reserved[4]; | ||
744 | }; | ||
745 | |||
746 | /* Values for the 'type' field */ | ||
747 | #define V4L2_INPUT_TYPE_TUNER 1 | ||
748 | #define V4L2_INPUT_TYPE_CAMERA 2 | ||
749 | |||
750 | /* field 'status' - general */ | ||
751 | #define V4L2_IN_ST_NO_POWER 0x00000001 /* Attached device is off */ | ||
752 | #define V4L2_IN_ST_NO_SIGNAL 0x00000002 | ||
753 | #define V4L2_IN_ST_NO_COLOR 0x00000004 | ||
754 | |||
755 | /* field 'status' - sensor orientation */ | ||
756 | /* If sensor is mounted upside down set both bits */ | ||
757 | #define V4L2_IN_ST_HFLIP 0x00000010 /* Frames are flipped horizontally */ | ||
758 | #define V4L2_IN_ST_VFLIP 0x00000020 /* Frames are flipped vertically */ | ||
759 | |||
760 | /* field 'status' - analog */ | ||
761 | #define V4L2_IN_ST_NO_H_LOCK 0x00000100 /* No horizontal sync lock */ | ||
762 | #define V4L2_IN_ST_COLOR_KILL 0x00000200 /* Color killer is active */ | ||
763 | |||
764 | /* field 'status' - digital */ | ||
765 | #define V4L2_IN_ST_NO_SYNC 0x00010000 /* No synchronization lock */ | ||
766 | #define V4L2_IN_ST_NO_EQU 0x00020000 /* No equalizer lock */ | ||
767 | #define V4L2_IN_ST_NO_CARRIER 0x00040000 /* Carrier recovery failed */ | ||
768 | |||
769 | /* field 'status' - VCR and set-top box */ | ||
770 | #define V4L2_IN_ST_MACROVISION 0x01000000 /* Macrovision detected */ | ||
771 | #define V4L2_IN_ST_NO_ACCESS 0x02000000 /* Conditional access denied */ | ||
772 | #define V4L2_IN_ST_VTR 0x04000000 /* VTR time constant */ | ||
773 | |||
774 | /* | ||
775 | * V I D E O O U T P U T S | ||
776 | */ | ||
777 | struct <link linkend="v4l2-output">v4l2_output</link> { | ||
778 | __u32 index; /* Which output */ | ||
779 | __u8 name[32]; /* Label */ | ||
780 | __u32 type; /* Type of output */ | ||
781 | __u32 audioset; /* Associated audios (bitfield) */ | ||
782 | __u32 modulator; /* Associated modulator */ | ||
783 | v4l2_std_id std; | ||
784 | __u32 reserved[4]; | ||
785 | }; | ||
786 | /* Values for the 'type' field */ | ||
787 | #define V4L2_OUTPUT_TYPE_MODULATOR 1 | ||
788 | #define V4L2_OUTPUT_TYPE_ANALOG 2 | ||
789 | #define V4L2_OUTPUT_TYPE_ANALOGVGAOVERLAY 3 | ||
790 | |||
791 | /* | ||
792 | * C O N T R O L S | ||
793 | */ | ||
794 | struct <link linkend="v4l2-control">v4l2_control</link> { | ||
795 | __u32 id; | ||
796 | __s32 value; | ||
797 | }; | ||
798 | |||
799 | struct <link linkend="v4l2-ext-control">v4l2_ext_control</link> { | ||
800 | __u32 id; | ||
801 | __u32 size; | ||
802 | __u32 reserved2[1]; | ||
803 | union { | ||
804 | __s32 value; | ||
805 | __s64 value64; | ||
806 | char *string; | ||
807 | }; | ||
808 | } __attribute__ ((packed)); | ||
809 | |||
810 | struct <link linkend="v4l2-ext-controls">v4l2_ext_controls</link> { | ||
811 | __u32 ctrl_class; | ||
812 | __u32 count; | ||
813 | __u32 error_idx; | ||
814 | __u32 reserved[2]; | ||
815 | struct <link linkend="v4l2-ext-control">v4l2_ext_control</link> *controls; | ||
816 | }; | ||
817 | |||
818 | /* Values for ctrl_class field */ | ||
819 | #define V4L2_CTRL_CLASS_USER 0x00980000 /* Old-style 'user' controls */ | ||
820 | #define V4L2_CTRL_CLASS_MPEG 0x00990000 /* MPEG-compression controls */ | ||
821 | #define V4L2_CTRL_CLASS_CAMERA 0x009a0000 /* Camera class controls */ | ||
822 | #define V4L2_CTRL_CLASS_FM_TX 0x009b0000 /* FM Modulator control class */ | ||
823 | |||
824 | #define V4L2_CTRL_ID_MASK (0x0fffffff) | ||
825 | #define V4L2_CTRL_ID2CLASS(id) ((id) & 0x0fff0000UL) | ||
826 | #define V4L2_CTRL_DRIVER_PRIV(id) (((id) & 0xffff) >= 0x1000) | ||
827 | |||
828 | /* Used in the VIDIOC_QUERYCTRL ioctl for querying controls */ | ||
829 | struct <link linkend="v4l2-queryctrl">v4l2_queryctrl</link> { | ||
830 | __u32 id; | ||
831 | enum <link linkend="v4l2-ctrl-type">v4l2_ctrl_type</link> type; | ||
832 | __u8 name[32]; /* Whatever */ | ||
833 | __s32 minimum; /* Note signedness */ | ||
834 | __s32 maximum; | ||
835 | __s32 step; | ||
836 | __s32 default_value; | ||
837 | __u32 flags; | ||
838 | __u32 reserved[2]; | ||
839 | }; | ||
840 | |||
841 | /* Used in the VIDIOC_QUERYMENU ioctl for querying menu items */ | ||
842 | struct <link linkend="v4l2-querymenu">v4l2_querymenu</link> { | ||
843 | __u32 id; | ||
844 | __u32 index; | ||
845 | __u8 name[32]; /* Whatever */ | ||
846 | __u32 reserved; | ||
847 | }; | ||
848 | |||
849 | /* Control flags */ | ||
850 | #define V4L2_CTRL_FLAG_DISABLED 0x0001 | ||
851 | #define V4L2_CTRL_FLAG_GRABBED 0x0002 | ||
852 | #define V4L2_CTRL_FLAG_READ_ONLY 0x0004 | ||
853 | #define V4L2_CTRL_FLAG_UPDATE 0x0008 | ||
854 | #define V4L2_CTRL_FLAG_INACTIVE 0x0010 | ||
855 | #define V4L2_CTRL_FLAG_SLIDER 0x0020 | ||
856 | #define V4L2_CTRL_FLAG_WRITE_ONLY 0x0040 | ||
857 | |||
858 | /* Query flag, to be ORed with the control ID */ | ||
859 | #define V4L2_CTRL_FLAG_NEXT_CTRL 0x80000000 | ||
860 | |||
861 | /* User-class control IDs defined by V4L2 */ | ||
862 | #define V4L2_CID_BASE (V4L2_CTRL_CLASS_USER | 0x900) | ||
863 | #define V4L2_CID_USER_BASE V4L2_CID_BASE | ||
864 | /* IDs reserved for driver specific controls */ | ||
865 | #define V4L2_CID_PRIVATE_BASE 0x08000000 | ||
866 | |||
867 | #define V4L2_CID_USER_CLASS (V4L2_CTRL_CLASS_USER | 1) | ||
868 | #define V4L2_CID_BRIGHTNESS (V4L2_CID_BASE+0) | ||
869 | #define V4L2_CID_CONTRAST (V4L2_CID_BASE+1) | ||
870 | #define V4L2_CID_SATURATION (V4L2_CID_BASE+2) | ||
871 | #define V4L2_CID_HUE (V4L2_CID_BASE+3) | ||
872 | #define V4L2_CID_AUDIO_VOLUME (V4L2_CID_BASE+5) | ||
873 | #define V4L2_CID_AUDIO_BALANCE (V4L2_CID_BASE+6) | ||
874 | #define V4L2_CID_AUDIO_BASS (V4L2_CID_BASE+7) | ||
875 | #define V4L2_CID_AUDIO_TREBLE (V4L2_CID_BASE+8) | ||
876 | #define V4L2_CID_AUDIO_MUTE (V4L2_CID_BASE+9) | ||
877 | #define V4L2_CID_AUDIO_LOUDNESS (V4L2_CID_BASE+10) | ||
878 | #define V4L2_CID_BLACK_LEVEL (V4L2_CID_BASE+11) /* Deprecated */ | ||
879 | #define V4L2_CID_AUTO_WHITE_BALANCE (V4L2_CID_BASE+12) | ||
880 | #define V4L2_CID_DO_WHITE_BALANCE (V4L2_CID_BASE+13) | ||
881 | #define V4L2_CID_RED_BALANCE (V4L2_CID_BASE+14) | ||
882 | #define V4L2_CID_BLUE_BALANCE (V4L2_CID_BASE+15) | ||
883 | #define V4L2_CID_GAMMA (V4L2_CID_BASE+16) | ||
884 | #define V4L2_CID_WHITENESS (V4L2_CID_GAMMA) /* Deprecated */ | ||
885 | #define V4L2_CID_EXPOSURE (V4L2_CID_BASE+17) | ||
886 | #define V4L2_CID_AUTOGAIN (V4L2_CID_BASE+18) | ||
887 | #define V4L2_CID_GAIN (V4L2_CID_BASE+19) | ||
888 | #define V4L2_CID_HFLIP (V4L2_CID_BASE+20) | ||
889 | #define V4L2_CID_VFLIP (V4L2_CID_BASE+21) | ||
890 | |||
891 | /* Deprecated; use V4L2_CID_PAN_RESET and V4L2_CID_TILT_RESET */ | ||
892 | #define V4L2_CID_HCENTER (V4L2_CID_BASE+22) | ||
893 | #define V4L2_CID_VCENTER (V4L2_CID_BASE+23) | ||
894 | |||
895 | #define V4L2_CID_POWER_LINE_FREQUENCY (V4L2_CID_BASE+24) | ||
896 | enum <link linkend="v4l2-power-line-frequency">v4l2_power_line_frequency</link> { | ||
897 | V4L2_CID_POWER_LINE_FREQUENCY_DISABLED = 0, | ||
898 | V4L2_CID_POWER_LINE_FREQUENCY_50HZ = 1, | ||
899 | V4L2_CID_POWER_LINE_FREQUENCY_60HZ = 2, | ||
900 | }; | ||
901 | #define V4L2_CID_HUE_AUTO (V4L2_CID_BASE+25) | ||
902 | #define V4L2_CID_WHITE_BALANCE_TEMPERATURE (V4L2_CID_BASE+26) | ||
903 | #define V4L2_CID_SHARPNESS (V4L2_CID_BASE+27) | ||
904 | #define V4L2_CID_BACKLIGHT_COMPENSATION (V4L2_CID_BASE+28) | ||
905 | #define V4L2_CID_CHROMA_AGC (V4L2_CID_BASE+29) | ||
906 | #define V4L2_CID_COLOR_KILLER (V4L2_CID_BASE+30) | ||
907 | #define V4L2_CID_COLORFX (V4L2_CID_BASE+31) | ||
908 | enum <link linkend="v4l2-colorfx">v4l2_colorfx</link> { | ||
909 | V4L2_COLORFX_NONE = 0, | ||
910 | V4L2_COLORFX_BW = 1, | ||
911 | V4L2_COLORFX_SEPIA = 2, | ||
912 | }; | ||
913 | #define V4L2_CID_AUTOBRIGHTNESS (V4L2_CID_BASE+32) | ||
914 | #define V4L2_CID_BAND_STOP_FILTER (V4L2_CID_BASE+33) | ||
915 | |||
916 | /* last CID + 1 */ | ||
917 | #define V4L2_CID_LASTP1 (V4L2_CID_BASE+34) | ||
918 | |||
919 | /* MPEG-class control IDs defined by V4L2 */ | ||
920 | #define V4L2_CID_MPEG_BASE (V4L2_CTRL_CLASS_MPEG | 0x900) | ||
921 | #define V4L2_CID_MPEG_CLASS (V4L2_CTRL_CLASS_MPEG | 1) | ||
922 | |||
923 | /* MPEG streams */ | ||
924 | #define V4L2_CID_MPEG_STREAM_TYPE (V4L2_CID_MPEG_BASE+0) | ||
925 | enum <link linkend="v4l2-mpeg-stream-type">v4l2_mpeg_stream_type</link> { | ||
926 | V4L2_MPEG_STREAM_TYPE_MPEG2_PS = 0, /* MPEG-2 program stream */ | ||
927 | V4L2_MPEG_STREAM_TYPE_MPEG2_TS = 1, /* MPEG-2 transport stream */ | ||
928 | V4L2_MPEG_STREAM_TYPE_MPEG1_SS = 2, /* MPEG-1 system stream */ | ||
929 | V4L2_MPEG_STREAM_TYPE_MPEG2_DVD = 3, /* MPEG-2 DVD-compatible stream */ | ||
930 | V4L2_MPEG_STREAM_TYPE_MPEG1_VCD = 4, /* MPEG-1 VCD-compatible stream */ | ||
931 | V4L2_MPEG_STREAM_TYPE_MPEG2_SVCD = 5, /* MPEG-2 SVCD-compatible stream */ | ||
932 | }; | ||
933 | #define V4L2_CID_MPEG_STREAM_PID_PMT (V4L2_CID_MPEG_BASE+1) | ||
934 | #define V4L2_CID_MPEG_STREAM_PID_AUDIO (V4L2_CID_MPEG_BASE+2) | ||
935 | #define V4L2_CID_MPEG_STREAM_PID_VIDEO (V4L2_CID_MPEG_BASE+3) | ||
936 | #define V4L2_CID_MPEG_STREAM_PID_PCR (V4L2_CID_MPEG_BASE+4) | ||
937 | #define V4L2_CID_MPEG_STREAM_PES_ID_AUDIO (V4L2_CID_MPEG_BASE+5) | ||
938 | #define V4L2_CID_MPEG_STREAM_PES_ID_VIDEO (V4L2_CID_MPEG_BASE+6) | ||
939 | #define V4L2_CID_MPEG_STREAM_VBI_FMT (V4L2_CID_MPEG_BASE+7) | ||
940 | enum <link linkend="v4l2-mpeg-stream-vbi-fmt">v4l2_mpeg_stream_vbi_fmt</link> { | ||
941 | V4L2_MPEG_STREAM_VBI_FMT_NONE = 0, /* No VBI in the MPEG stream */ | ||
942 | V4L2_MPEG_STREAM_VBI_FMT_IVTV = 1, /* VBI in private packets, IVTV format */ | ||
943 | }; | ||
944 | |||
945 | /* MPEG audio */ | ||
946 | #define V4L2_CID_MPEG_AUDIO_SAMPLING_FREQ (V4L2_CID_MPEG_BASE+100) | ||
947 | enum <link linkend="v4l2-mpeg-audio-sampling-freq">v4l2_mpeg_audio_sampling_freq</link> { | ||
948 | V4L2_MPEG_AUDIO_SAMPLING_FREQ_44100 = 0, | ||
949 | V4L2_MPEG_AUDIO_SAMPLING_FREQ_48000 = 1, | ||
950 | V4L2_MPEG_AUDIO_SAMPLING_FREQ_32000 = 2, | ||
951 | }; | ||
952 | #define V4L2_CID_MPEG_AUDIO_ENCODING (V4L2_CID_MPEG_BASE+101) | ||
953 | enum <link linkend="v4l2-mpeg-audio-encoding">v4l2_mpeg_audio_encoding</link> { | ||
954 | V4L2_MPEG_AUDIO_ENCODING_LAYER_1 = 0, | ||
955 | V4L2_MPEG_AUDIO_ENCODING_LAYER_2 = 1, | ||
956 | V4L2_MPEG_AUDIO_ENCODING_LAYER_3 = 2, | ||
957 | V4L2_MPEG_AUDIO_ENCODING_AAC = 3, | ||
958 | V4L2_MPEG_AUDIO_ENCODING_AC3 = 4, | ||
959 | }; | ||
960 | #define V4L2_CID_MPEG_AUDIO_L1_BITRATE (V4L2_CID_MPEG_BASE+102) | ||
961 | enum <link linkend="v4l2-mpeg-audio-l1-bitrate">v4l2_mpeg_audio_l1_bitrate</link> { | ||
962 | V4L2_MPEG_AUDIO_L1_BITRATE_32K = 0, | ||
963 | V4L2_MPEG_AUDIO_L1_BITRATE_64K = 1, | ||
964 | V4L2_MPEG_AUDIO_L1_BITRATE_96K = 2, | ||
965 | V4L2_MPEG_AUDIO_L1_BITRATE_128K = 3, | ||
966 | V4L2_MPEG_AUDIO_L1_BITRATE_160K = 4, | ||
967 | V4L2_MPEG_AUDIO_L1_BITRATE_192K = 5, | ||
968 | V4L2_MPEG_AUDIO_L1_BITRATE_224K = 6, | ||
969 | V4L2_MPEG_AUDIO_L1_BITRATE_256K = 7, | ||
970 | V4L2_MPEG_AUDIO_L1_BITRATE_288K = 8, | ||
971 | V4L2_MPEG_AUDIO_L1_BITRATE_320K = 9, | ||
972 | V4L2_MPEG_AUDIO_L1_BITRATE_352K = 10, | ||
973 | V4L2_MPEG_AUDIO_L1_BITRATE_384K = 11, | ||
974 | V4L2_MPEG_AUDIO_L1_BITRATE_416K = 12, | ||
975 | V4L2_MPEG_AUDIO_L1_BITRATE_448K = 13, | ||
976 | }; | ||
977 | #define V4L2_CID_MPEG_AUDIO_L2_BITRATE (V4L2_CID_MPEG_BASE+103) | ||
978 | enum <link linkend="v4l2-mpeg-audio-l2-bitrate">v4l2_mpeg_audio_l2_bitrate</link> { | ||
979 | V4L2_MPEG_AUDIO_L2_BITRATE_32K = 0, | ||
980 | V4L2_MPEG_AUDIO_L2_BITRATE_48K = 1, | ||
981 | V4L2_MPEG_AUDIO_L2_BITRATE_56K = 2, | ||
982 | V4L2_MPEG_AUDIO_L2_BITRATE_64K = 3, | ||
983 | V4L2_MPEG_AUDIO_L2_BITRATE_80K = 4, | ||
984 | V4L2_MPEG_AUDIO_L2_BITRATE_96K = 5, | ||
985 | V4L2_MPEG_AUDIO_L2_BITRATE_112K = 6, | ||
986 | V4L2_MPEG_AUDIO_L2_BITRATE_128K = 7, | ||
987 | V4L2_MPEG_AUDIO_L2_BITRATE_160K = 8, | ||
988 | V4L2_MPEG_AUDIO_L2_BITRATE_192K = 9, | ||
989 | V4L2_MPEG_AUDIO_L2_BITRATE_224K = 10, | ||
990 | V4L2_MPEG_AUDIO_L2_BITRATE_256K = 11, | ||
991 | V4L2_MPEG_AUDIO_L2_BITRATE_320K = 12, | ||
992 | V4L2_MPEG_AUDIO_L2_BITRATE_384K = 13, | ||
993 | }; | ||
994 | #define V4L2_CID_MPEG_AUDIO_L3_BITRATE (V4L2_CID_MPEG_BASE+104) | ||
995 | enum <link linkend="v4l2-mpeg-audio-l3-bitrate">v4l2_mpeg_audio_l3_bitrate</link> { | ||
996 | V4L2_MPEG_AUDIO_L3_BITRATE_32K = 0, | ||
997 | V4L2_MPEG_AUDIO_L3_BITRATE_40K = 1, | ||
998 | V4L2_MPEG_AUDIO_L3_BITRATE_48K = 2, | ||
999 | V4L2_MPEG_AUDIO_L3_BITRATE_56K = 3, | ||
1000 | V4L2_MPEG_AUDIO_L3_BITRATE_64K = 4, | ||
1001 | V4L2_MPEG_AUDIO_L3_BITRATE_80K = 5, | ||
1002 | V4L2_MPEG_AUDIO_L3_BITRATE_96K = 6, | ||
1003 | V4L2_MPEG_AUDIO_L3_BITRATE_112K = 7, | ||
1004 | V4L2_MPEG_AUDIO_L3_BITRATE_128K = 8, | ||
1005 | V4L2_MPEG_AUDIO_L3_BITRATE_160K = 9, | ||
1006 | V4L2_MPEG_AUDIO_L3_BITRATE_192K = 10, | ||
1007 | V4L2_MPEG_AUDIO_L3_BITRATE_224K = 11, | ||
1008 | V4L2_MPEG_AUDIO_L3_BITRATE_256K = 12, | ||
1009 | V4L2_MPEG_AUDIO_L3_BITRATE_320K = 13, | ||
1010 | }; | ||
1011 | #define V4L2_CID_MPEG_AUDIO_MODE (V4L2_CID_MPEG_BASE+105) | ||
1012 | enum <link linkend="v4l2-mpeg-audio-mode">v4l2_mpeg_audio_mode</link> { | ||
1013 | V4L2_MPEG_AUDIO_MODE_STEREO = 0, | ||
1014 | V4L2_MPEG_AUDIO_MODE_JOINT_STEREO = 1, | ||
1015 | V4L2_MPEG_AUDIO_MODE_DUAL = 2, | ||
1016 | V4L2_MPEG_AUDIO_MODE_MONO = 3, | ||
1017 | }; | ||
1018 | #define V4L2_CID_MPEG_AUDIO_MODE_EXTENSION (V4L2_CID_MPEG_BASE+106) | ||
1019 | enum <link linkend="v4l2-mpeg-audio-mode-extension">v4l2_mpeg_audio_mode_extension</link> { | ||
1020 | V4L2_MPEG_AUDIO_MODE_EXTENSION_BOUND_4 = 0, | ||
1021 | V4L2_MPEG_AUDIO_MODE_EXTENSION_BOUND_8 = 1, | ||
1022 | V4L2_MPEG_AUDIO_MODE_EXTENSION_BOUND_12 = 2, | ||
1023 | V4L2_MPEG_AUDIO_MODE_EXTENSION_BOUND_16 = 3, | ||
1024 | }; | ||
1025 | #define V4L2_CID_MPEG_AUDIO_EMPHASIS (V4L2_CID_MPEG_BASE+107) | ||
1026 | enum <link linkend="v4l2-mpeg-audio-emphasis">v4l2_mpeg_audio_emphasis</link> { | ||
1027 | V4L2_MPEG_AUDIO_EMPHASIS_NONE = 0, | ||
1028 | V4L2_MPEG_AUDIO_EMPHASIS_50_DIV_15_uS = 1, | ||
1029 | V4L2_MPEG_AUDIO_EMPHASIS_CCITT_J17 = 2, | ||
1030 | }; | ||
1031 | #define V4L2_CID_MPEG_AUDIO_CRC (V4L2_CID_MPEG_BASE+108) | ||
1032 | enum <link linkend="v4l2-mpeg-audio-crc">v4l2_mpeg_audio_crc</link> { | ||
1033 | V4L2_MPEG_AUDIO_CRC_NONE = 0, | ||
1034 | V4L2_MPEG_AUDIO_CRC_CRC16 = 1, | ||
1035 | }; | ||
1036 | #define V4L2_CID_MPEG_AUDIO_MUTE (V4L2_CID_MPEG_BASE+109) | ||
1037 | #define V4L2_CID_MPEG_AUDIO_AAC_BITRATE (V4L2_CID_MPEG_BASE+110) | ||
1038 | #define V4L2_CID_MPEG_AUDIO_AC3_BITRATE (V4L2_CID_MPEG_BASE+111) | ||
1039 | enum <link linkend="v4l2-mpeg-audio-ac3-bitrate">v4l2_mpeg_audio_ac3_bitrate</link> { | ||
1040 | V4L2_MPEG_AUDIO_AC3_BITRATE_32K = 0, | ||
1041 | V4L2_MPEG_AUDIO_AC3_BITRATE_40K = 1, | ||
1042 | V4L2_MPEG_AUDIO_AC3_BITRATE_48K = 2, | ||
1043 | V4L2_MPEG_AUDIO_AC3_BITRATE_56K = 3, | ||
1044 | V4L2_MPEG_AUDIO_AC3_BITRATE_64K = 4, | ||
1045 | V4L2_MPEG_AUDIO_AC3_BITRATE_80K = 5, | ||
1046 | V4L2_MPEG_AUDIO_AC3_BITRATE_96K = 6, | ||
1047 | V4L2_MPEG_AUDIO_AC3_BITRATE_112K = 7, | ||
1048 | V4L2_MPEG_AUDIO_AC3_BITRATE_128K = 8, | ||
1049 | V4L2_MPEG_AUDIO_AC3_BITRATE_160K = 9, | ||
1050 | V4L2_MPEG_AUDIO_AC3_BITRATE_192K = 10, | ||
1051 | V4L2_MPEG_AUDIO_AC3_BITRATE_224K = 11, | ||
1052 | V4L2_MPEG_AUDIO_AC3_BITRATE_256K = 12, | ||
1053 | V4L2_MPEG_AUDIO_AC3_BITRATE_320K = 13, | ||
1054 | V4L2_MPEG_AUDIO_AC3_BITRATE_384K = 14, | ||
1055 | V4L2_MPEG_AUDIO_AC3_BITRATE_448K = 15, | ||
1056 | V4L2_MPEG_AUDIO_AC3_BITRATE_512K = 16, | ||
1057 | V4L2_MPEG_AUDIO_AC3_BITRATE_576K = 17, | ||
1058 | V4L2_MPEG_AUDIO_AC3_BITRATE_640K = 18, | ||
1059 | }; | ||
1060 | |||
1061 | /* MPEG video */ | ||
1062 | #define V4L2_CID_MPEG_VIDEO_ENCODING (V4L2_CID_MPEG_BASE+200) | ||
1063 | enum <link linkend="v4l2-mpeg-video-encoding">v4l2_mpeg_video_encoding</link> { | ||
1064 | V4L2_MPEG_VIDEO_ENCODING_MPEG_1 = 0, | ||
1065 | V4L2_MPEG_VIDEO_ENCODING_MPEG_2 = 1, | ||
1066 | V4L2_MPEG_VIDEO_ENCODING_MPEG_4_AVC = 2, | ||
1067 | }; | ||
1068 | #define V4L2_CID_MPEG_VIDEO_ASPECT (V4L2_CID_MPEG_BASE+201) | ||
1069 | enum <link linkend="v4l2-mpeg-video-aspect">v4l2_mpeg_video_aspect</link> { | ||
1070 | V4L2_MPEG_VIDEO_ASPECT_1x1 = 0, | ||
1071 | V4L2_MPEG_VIDEO_ASPECT_4x3 = 1, | ||
1072 | V4L2_MPEG_VIDEO_ASPECT_16x9 = 2, | ||
1073 | V4L2_MPEG_VIDEO_ASPECT_221x100 = 3, | ||
1074 | }; | ||
1075 | #define V4L2_CID_MPEG_VIDEO_B_FRAMES (V4L2_CID_MPEG_BASE+202) | ||
1076 | #define V4L2_CID_MPEG_VIDEO_GOP_SIZE (V4L2_CID_MPEG_BASE+203) | ||
1077 | #define V4L2_CID_MPEG_VIDEO_GOP_CLOSURE (V4L2_CID_MPEG_BASE+204) | ||
1078 | #define V4L2_CID_MPEG_VIDEO_PULLDOWN (V4L2_CID_MPEG_BASE+205) | ||
1079 | #define V4L2_CID_MPEG_VIDEO_BITRATE_MODE (V4L2_CID_MPEG_BASE+206) | ||
1080 | enum <link linkend="v4l2-mpeg-video-bitrate-mode">v4l2_mpeg_video_bitrate_mode</link> { | ||
1081 | V4L2_MPEG_VIDEO_BITRATE_MODE_VBR = 0, | ||
1082 | V4L2_MPEG_VIDEO_BITRATE_MODE_CBR = 1, | ||
1083 | }; | ||
1084 | #define V4L2_CID_MPEG_VIDEO_BITRATE (V4L2_CID_MPEG_BASE+207) | ||
1085 | #define V4L2_CID_MPEG_VIDEO_BITRATE_PEAK (V4L2_CID_MPEG_BASE+208) | ||
1086 | #define V4L2_CID_MPEG_VIDEO_TEMPORAL_DECIMATION (V4L2_CID_MPEG_BASE+209) | ||
1087 | #define V4L2_CID_MPEG_VIDEO_MUTE (V4L2_CID_MPEG_BASE+210) | ||
1088 | #define V4L2_CID_MPEG_VIDEO_MUTE_YUV (V4L2_CID_MPEG_BASE+211) | ||
1089 | |||
1090 | /* MPEG-class control IDs specific to the CX2341x driver as defined by V4L2 */ | ||
1091 | #define V4L2_CID_MPEG_CX2341X_BASE (V4L2_CTRL_CLASS_MPEG | 0x1000) | ||
1092 | #define V4L2_CID_MPEG_CX2341X_VIDEO_SPATIAL_FILTER_MODE (V4L2_CID_MPEG_CX2341X_BASE+0) | ||
1093 | enum <link linkend="v4l2-mpeg-cx2341x-video-spatial-filter-mode">v4l2_mpeg_cx2341x_video_spatial_filter_mode</link> { | ||
1094 | V4L2_MPEG_CX2341X_VIDEO_SPATIAL_FILTER_MODE_MANUAL = 0, | ||
1095 | V4L2_MPEG_CX2341X_VIDEO_SPATIAL_FILTER_MODE_AUTO = 1, | ||
1096 | }; | ||
1097 | #define V4L2_CID_MPEG_CX2341X_VIDEO_SPATIAL_FILTER (V4L2_CID_MPEG_CX2341X_BASE+1) | ||
1098 | #define V4L2_CID_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE (V4L2_CID_MPEG_CX2341X_BASE+2) | ||
1099 | enum <link linkend="luma-spatial-filter-type">v4l2_mpeg_cx2341x_video_luma_spatial_filter_type</link> { | ||
1100 | V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_OFF = 0, | ||
1101 | V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_1D_HOR = 1, | ||
1102 | V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_1D_VERT = 2, | ||
1103 | V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_2D_HV_SEPARABLE = 3, | ||
1104 | V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_2D_SYM_NON_SEPARABLE = 4, | ||
1105 | }; | ||
1106 | #define V4L2_CID_MPEG_CX2341X_VIDEO_CHROMA_SPATIAL_FILTER_TYPE (V4L2_CID_MPEG_CX2341X_BASE+3) | ||
1107 | enum <link linkend="chroma-spatial-filter-type">v4l2_mpeg_cx2341x_video_chroma_spatial_filter_type</link> { | ||
1108 | V4L2_MPEG_CX2341X_VIDEO_CHROMA_SPATIAL_FILTER_TYPE_OFF = 0, | ||
1109 | V4L2_MPEG_CX2341X_VIDEO_CHROMA_SPATIAL_FILTER_TYPE_1D_HOR = 1, | ||
1110 | }; | ||
1111 | #define V4L2_CID_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER_MODE (V4L2_CID_MPEG_CX2341X_BASE+4) | ||
1112 | enum <link linkend="v4l2-mpeg-cx2341x-video-temporal-filter-mode">v4l2_mpeg_cx2341x_video_temporal_filter_mode</link> { | ||
1113 | V4L2_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER_MODE_MANUAL = 0, | ||
1114 | V4L2_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER_MODE_AUTO = 1, | ||
1115 | }; | ||
1116 | #define V4L2_CID_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER (V4L2_CID_MPEG_CX2341X_BASE+5) | ||
1117 | #define V4L2_CID_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE (V4L2_CID_MPEG_CX2341X_BASE+6) | ||
1118 | enum <link linkend="v4l2-mpeg-cx2341x-video-median-filter-type">v4l2_mpeg_cx2341x_video_median_filter_type</link> { | ||
1119 | V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_OFF = 0, | ||
1120 | V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_HOR = 1, | ||
1121 | V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_VERT = 2, | ||
1122 | V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_HOR_VERT = 3, | ||
1123 | V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_DIAG = 4, | ||
1124 | }; | ||
1125 | #define V4L2_CID_MPEG_CX2341X_VIDEO_LUMA_MEDIAN_FILTER_BOTTOM (V4L2_CID_MPEG_CX2341X_BASE+7) | ||
1126 | #define V4L2_CID_MPEG_CX2341X_VIDEO_LUMA_MEDIAN_FILTER_TOP (V4L2_CID_MPEG_CX2341X_BASE+8) | ||
1127 | #define V4L2_CID_MPEG_CX2341X_VIDEO_CHROMA_MEDIAN_FILTER_BOTTOM (V4L2_CID_MPEG_CX2341X_BASE+9) | ||
1128 | #define V4L2_CID_MPEG_CX2341X_VIDEO_CHROMA_MEDIAN_FILTER_TOP (V4L2_CID_MPEG_CX2341X_BASE+10) | ||
1129 | #define V4L2_CID_MPEG_CX2341X_STREAM_INSERT_NAV_PACKETS (V4L2_CID_MPEG_CX2341X_BASE+11) | ||
1130 | |||
1131 | /* Camera class control IDs */ | ||
1132 | #define V4L2_CID_CAMERA_CLASS_BASE (V4L2_CTRL_CLASS_CAMERA | 0x900) | ||
1133 | #define V4L2_CID_CAMERA_CLASS (V4L2_CTRL_CLASS_CAMERA | 1) | ||
1134 | |||
1135 | #define V4L2_CID_EXPOSURE_AUTO (V4L2_CID_CAMERA_CLASS_BASE+1) | ||
1136 | enum <link linkend="v4l2-exposure-auto-type">v4l2_exposure_auto_type</link> { | ||
1137 | V4L2_EXPOSURE_AUTO = 0, | ||
1138 | V4L2_EXPOSURE_MANUAL = 1, | ||
1139 | V4L2_EXPOSURE_SHUTTER_PRIORITY = 2, | ||
1140 | V4L2_EXPOSURE_APERTURE_PRIORITY = 3 | ||
1141 | }; | ||
1142 | #define V4L2_CID_EXPOSURE_ABSOLUTE (V4L2_CID_CAMERA_CLASS_BASE+2) | ||
1143 | #define V4L2_CID_EXPOSURE_AUTO_PRIORITY (V4L2_CID_CAMERA_CLASS_BASE+3) | ||
1144 | |||
1145 | #define V4L2_CID_PAN_RELATIVE (V4L2_CID_CAMERA_CLASS_BASE+4) | ||
1146 | #define V4L2_CID_TILT_RELATIVE (V4L2_CID_CAMERA_CLASS_BASE+5) | ||
1147 | #define V4L2_CID_PAN_RESET (V4L2_CID_CAMERA_CLASS_BASE+6) | ||
1148 | #define V4L2_CID_TILT_RESET (V4L2_CID_CAMERA_CLASS_BASE+7) | ||
1149 | |||
1150 | #define V4L2_CID_PAN_ABSOLUTE (V4L2_CID_CAMERA_CLASS_BASE+8) | ||
1151 | #define V4L2_CID_TILT_ABSOLUTE (V4L2_CID_CAMERA_CLASS_BASE+9) | ||
1152 | |||
1153 | #define V4L2_CID_FOCUS_ABSOLUTE (V4L2_CID_CAMERA_CLASS_BASE+10) | ||
1154 | #define V4L2_CID_FOCUS_RELATIVE (V4L2_CID_CAMERA_CLASS_BASE+11) | ||
1155 | #define V4L2_CID_FOCUS_AUTO (V4L2_CID_CAMERA_CLASS_BASE+12) | ||
1156 | |||
1157 | #define V4L2_CID_ZOOM_ABSOLUTE (V4L2_CID_CAMERA_CLASS_BASE+13) | ||
1158 | #define V4L2_CID_ZOOM_RELATIVE (V4L2_CID_CAMERA_CLASS_BASE+14) | ||
1159 | #define V4L2_CID_ZOOM_CONTINUOUS (V4L2_CID_CAMERA_CLASS_BASE+15) | ||
1160 | |||
1161 | #define V4L2_CID_PRIVACY (V4L2_CID_CAMERA_CLASS_BASE+16) | ||
1162 | |||
1163 | /* FM Modulator class control IDs */ | ||
1164 | #define V4L2_CID_FM_TX_CLASS_BASE (V4L2_CTRL_CLASS_FM_TX | 0x900) | ||
1165 | #define V4L2_CID_FM_TX_CLASS (V4L2_CTRL_CLASS_FM_TX | 1) | ||
1166 | |||
1167 | #define V4L2_CID_RDS_TX_DEVIATION (V4L2_CID_FM_TX_CLASS_BASE + 1) | ||
1168 | #define V4L2_CID_RDS_TX_PI (V4L2_CID_FM_TX_CLASS_BASE + 2) | ||
1169 | #define V4L2_CID_RDS_TX_PTY (V4L2_CID_FM_TX_CLASS_BASE + 3) | ||
1170 | #define V4L2_CID_RDS_TX_PS_NAME (V4L2_CID_FM_TX_CLASS_BASE + 5) | ||
1171 | #define V4L2_CID_RDS_TX_RADIO_TEXT (V4L2_CID_FM_TX_CLASS_BASE + 6) | ||
1172 | |||
1173 | #define V4L2_CID_AUDIO_LIMITER_ENABLED (V4L2_CID_FM_TX_CLASS_BASE + 64) | ||
1174 | #define V4L2_CID_AUDIO_LIMITER_RELEASE_TIME (V4L2_CID_FM_TX_CLASS_BASE + 65) | ||
1175 | #define V4L2_CID_AUDIO_LIMITER_DEVIATION (V4L2_CID_FM_TX_CLASS_BASE + 66) | ||
1176 | |||
1177 | #define V4L2_CID_AUDIO_COMPRESSION_ENABLED (V4L2_CID_FM_TX_CLASS_BASE + 80) | ||
1178 | #define V4L2_CID_AUDIO_COMPRESSION_GAIN (V4L2_CID_FM_TX_CLASS_BASE + 81) | ||
1179 | #define V4L2_CID_AUDIO_COMPRESSION_THRESHOLD (V4L2_CID_FM_TX_CLASS_BASE + 82) | ||
1180 | #define V4L2_CID_AUDIO_COMPRESSION_ATTACK_TIME (V4L2_CID_FM_TX_CLASS_BASE + 83) | ||
1181 | #define V4L2_CID_AUDIO_COMPRESSION_RELEASE_TIME (V4L2_CID_FM_TX_CLASS_BASE + 84) | ||
1182 | |||
1183 | #define V4L2_CID_PILOT_TONE_ENABLED (V4L2_CID_FM_TX_CLASS_BASE + 96) | ||
1184 | #define V4L2_CID_PILOT_TONE_DEVIATION (V4L2_CID_FM_TX_CLASS_BASE + 97) | ||
1185 | #define V4L2_CID_PILOT_TONE_FREQUENCY (V4L2_CID_FM_TX_CLASS_BASE + 98) | ||
1186 | |||
1187 | #define V4L2_CID_TUNE_PREEMPHASIS (V4L2_CID_FM_TX_CLASS_BASE + 112) | ||
1188 | enum <link linkend="v4l2-preemphasis">v4l2_preemphasis</link> { | ||
1189 | V4L2_PREEMPHASIS_DISABLED = 0, | ||
1190 | V4L2_PREEMPHASIS_50_uS = 1, | ||
1191 | V4L2_PREEMPHASIS_75_uS = 2, | ||
1192 | }; | ||
1193 | #define V4L2_CID_TUNE_POWER_LEVEL (V4L2_CID_FM_TX_CLASS_BASE + 113) | ||
1194 | #define V4L2_CID_TUNE_ANTENNA_CAPACITOR (V4L2_CID_FM_TX_CLASS_BASE + 114) | ||
1195 | |||
1196 | /* | ||
1197 | * T U N I N G | ||
1198 | */ | ||
1199 | struct <link linkend="v4l2-tuner">v4l2_tuner</link> { | ||
1200 | __u32 index; | ||
1201 | __u8 name[32]; | ||
1202 | enum <link linkend="v4l2-tuner-type">v4l2_tuner_type</link> type; | ||
1203 | __u32 capability; | ||
1204 | __u32 rangelow; | ||
1205 | __u32 rangehigh; | ||
1206 | __u32 rxsubchans; | ||
1207 | __u32 audmode; | ||
1208 | __s32 signal; | ||
1209 | __s32 afc; | ||
1210 | __u32 reserved[4]; | ||
1211 | }; | ||
1212 | |||
1213 | struct <link linkend="v4l2-modulator">v4l2_modulator</link> { | ||
1214 | __u32 index; | ||
1215 | __u8 name[32]; | ||
1216 | __u32 capability; | ||
1217 | __u32 rangelow; | ||
1218 | __u32 rangehigh; | ||
1219 | __u32 txsubchans; | ||
1220 | __u32 reserved[4]; | ||
1221 | }; | ||
1222 | |||
1223 | /* Flags for the 'capability' field */ | ||
1224 | #define V4L2_TUNER_CAP_LOW 0x0001 | ||
1225 | #define V4L2_TUNER_CAP_NORM 0x0002 | ||
1226 | #define V4L2_TUNER_CAP_STEREO 0x0010 | ||
1227 | #define V4L2_TUNER_CAP_LANG2 0x0020 | ||
1228 | #define V4L2_TUNER_CAP_SAP 0x0020 | ||
1229 | #define V4L2_TUNER_CAP_LANG1 0x0040 | ||
1230 | #define V4L2_TUNER_CAP_RDS 0x0080 | ||
1231 | |||
1232 | /* Flags for the 'rxsubchans' field */ | ||
1233 | #define V4L2_TUNER_SUB_MONO 0x0001 | ||
1234 | #define V4L2_TUNER_SUB_STEREO 0x0002 | ||
1235 | #define V4L2_TUNER_SUB_LANG2 0x0004 | ||
1236 | #define V4L2_TUNER_SUB_SAP 0x0004 | ||
1237 | #define V4L2_TUNER_SUB_LANG1 0x0008 | ||
1238 | #define V4L2_TUNER_SUB_RDS 0x0010 | ||
1239 | |||
1240 | /* Values for the 'audmode' field */ | ||
1241 | #define V4L2_TUNER_MODE_MONO 0x0000 | ||
1242 | #define V4L2_TUNER_MODE_STEREO 0x0001 | ||
1243 | #define V4L2_TUNER_MODE_LANG2 0x0002 | ||
1244 | #define V4L2_TUNER_MODE_SAP 0x0002 | ||
1245 | #define V4L2_TUNER_MODE_LANG1 0x0003 | ||
1246 | #define V4L2_TUNER_MODE_LANG1_LANG2 0x0004 | ||
1247 | |||
1248 | struct <link linkend="v4l2-frequency">v4l2_frequency</link> { | ||
1249 | __u32 tuner; | ||
1250 | enum <link linkend="v4l2-tuner-type">v4l2_tuner_type</link> type; | ||
1251 | __u32 frequency; | ||
1252 | __u32 reserved[8]; | ||
1253 | }; | ||
1254 | |||
1255 | struct <link linkend="v4l2-hw-freq-seek">v4l2_hw_freq_seek</link> { | ||
1256 | __u32 tuner; | ||
1257 | enum <link linkend="v4l2-tuner-type">v4l2_tuner_type</link> type; | ||
1258 | __u32 seek_upward; | ||
1259 | __u32 wrap_around; | ||
1260 | __u32 reserved[8]; | ||
1261 | }; | ||
1262 | |||
1263 | /* | ||
1264 | * R D S | ||
1265 | */ | ||
1266 | |||
1267 | struct <link linkend="v4l2-rds-data">v4l2_rds_data</link> { | ||
1268 | __u8 lsb; | ||
1269 | __u8 msb; | ||
1270 | __u8 block; | ||
1271 | } __attribute__ ((packed)); | ||
1272 | |||
1273 | #define V4L2_RDS_BLOCK_MSK 0x7 | ||
1274 | #define V4L2_RDS_BLOCK_A 0 | ||
1275 | #define V4L2_RDS_BLOCK_B 1 | ||
1276 | #define V4L2_RDS_BLOCK_C 2 | ||
1277 | #define V4L2_RDS_BLOCK_D 3 | ||
1278 | #define V4L2_RDS_BLOCK_C_ALT 4 | ||
1279 | #define V4L2_RDS_BLOCK_INVALID 7 | ||
1280 | |||
1281 | #define V4L2_RDS_BLOCK_CORRECTED 0x40 | ||
1282 | #define V4L2_RDS_BLOCK_ERROR 0x80 | ||
1283 | |||
1284 | /* | ||
1285 | * A U D I O | ||
1286 | */ | ||
1287 | struct <link linkend="v4l2-audio">v4l2_audio</link> { | ||
1288 | __u32 index; | ||
1289 | __u8 name[32]; | ||
1290 | __u32 capability; | ||
1291 | __u32 mode; | ||
1292 | __u32 reserved[2]; | ||
1293 | }; | ||
1294 | |||
1295 | /* Flags for the 'capability' field */ | ||
1296 | #define V4L2_AUDCAP_STEREO 0x00001 | ||
1297 | #define V4L2_AUDCAP_AVL 0x00002 | ||
1298 | |||
1299 | /* Flags for the 'mode' field */ | ||
1300 | #define V4L2_AUDMODE_AVL 0x00001 | ||
1301 | |||
1302 | struct <link linkend="v4l2-audioout">v4l2_audioout</link> { | ||
1303 | __u32 index; | ||
1304 | __u8 name[32]; | ||
1305 | __u32 capability; | ||
1306 | __u32 mode; | ||
1307 | __u32 reserved[2]; | ||
1308 | }; | ||
1309 | |||
1310 | /* | ||
1311 | * M P E G S E R V I C E S | ||
1312 | * | ||
1313 | * NOTE: EXPERIMENTAL API | ||
1314 | */ | ||
1315 | #if 1 /*KEEP*/ | ||
1316 | #define V4L2_ENC_IDX_FRAME_I (0) | ||
1317 | #define V4L2_ENC_IDX_FRAME_P (1) | ||
1318 | #define V4L2_ENC_IDX_FRAME_B (2) | ||
1319 | #define V4L2_ENC_IDX_FRAME_MASK (0xf) | ||
1320 | |||
1321 | struct <link linkend="v4l2-enc-idx-entry">v4l2_enc_idx_entry</link> { | ||
1322 | __u64 offset; | ||
1323 | __u64 pts; | ||
1324 | __u32 length; | ||
1325 | __u32 flags; | ||
1326 | __u32 reserved[2]; | ||
1327 | }; | ||
1328 | |||
1329 | #define V4L2_ENC_IDX_ENTRIES (64) | ||
1330 | struct <link linkend="v4l2-enc-idx">v4l2_enc_idx</link> { | ||
1331 | __u32 entries; | ||
1332 | __u32 entries_cap; | ||
1333 | __u32 reserved[4]; | ||
1334 | struct <link linkend="v4l2-enc-idx-entry">v4l2_enc_idx_entry</link> entry[V4L2_ENC_IDX_ENTRIES]; | ||
1335 | }; | ||
1336 | |||
1337 | |||
1338 | #define V4L2_ENC_CMD_START (0) | ||
1339 | #define V4L2_ENC_CMD_STOP (1) | ||
1340 | #define V4L2_ENC_CMD_PAUSE (2) | ||
1341 | #define V4L2_ENC_CMD_RESUME (3) | ||
1342 | |||
1343 | /* Flags for V4L2_ENC_CMD_STOP */ | ||
1344 | #define V4L2_ENC_CMD_STOP_AT_GOP_END (1 << 0) | ||
1345 | |||
1346 | struct <link linkend="v4l2-encoder-cmd">v4l2_encoder_cmd</link> { | ||
1347 | __u32 cmd; | ||
1348 | __u32 flags; | ||
1349 | union { | ||
1350 | struct { | ||
1351 | __u32 data[8]; | ||
1352 | } raw; | ||
1353 | }; | ||
1354 | }; | ||
1355 | |||
1356 | #endif | ||
1357 | |||
1358 | |||
1359 | /* | ||
1360 | * D A T A S E R V I C E S ( V B I ) | ||
1361 | * | ||
1362 | * Data services API by Michael Schimek | ||
1363 | */ | ||
1364 | |||
1365 | /* Raw VBI */ | ||
1366 | struct <link linkend="v4l2-vbi-format">v4l2_vbi_format</link> { | ||
1367 | __u32 sampling_rate; /* in 1 Hz */ | ||
1368 | __u32 offset; | ||
1369 | __u32 samples_per_line; | ||
1370 | __u32 sample_format; /* V4L2_PIX_FMT_* */ | ||
1371 | __s32 start[2]; | ||
1372 | __u32 count[2]; | ||
1373 | __u32 flags; /* V4L2_VBI_* */ | ||
1374 | __u32 reserved[2]; /* must be zero */ | ||
1375 | }; | ||
1376 | |||
1377 | /* VBI flags */ | ||
1378 | #define V4L2_VBI_UNSYNC (1 << 0) | ||
1379 | #define V4L2_VBI_INTERLACED (1 << 1) | ||
1380 | |||
1381 | /* Sliced VBI | ||
1382 | * | ||
1383 | * This implements is a proposal V4L2 API to allow SLICED VBI | ||
1384 | * required for some hardware encoders. It should change without | ||
1385 | * notice in the definitive implementation. | ||
1386 | */ | ||
1387 | |||
1388 | struct <link linkend="v4l2-sliced-vbi-format">v4l2_sliced_vbi_format</link> { | ||
1389 | __u16 service_set; | ||
1390 | /* service_lines[0][...] specifies lines 0-23 (1-23 used) of the first field | ||
1391 | service_lines[1][...] specifies lines 0-23 (1-23 used) of the second field | ||
1392 | (equals frame lines 313-336 for 625 line video | ||
1393 | standards, 263-286 for 525 line standards) */ | ||
1394 | __u16 service_lines[2][24]; | ||
1395 | __u32 io_size; | ||
1396 | __u32 reserved[2]; /* must be zero */ | ||
1397 | }; | ||
1398 | |||
1399 | /* Teletext World System Teletext | ||
1400 | (WST), defined on ITU-R BT.653-2 */ | ||
1401 | #define V4L2_SLICED_TELETEXT_B (0x0001) | ||
1402 | /* Video Program System, defined on ETS 300 231*/ | ||
1403 | #define V4L2_SLICED_VPS (0x0400) | ||
1404 | /* Closed Caption, defined on EIA-608 */ | ||
1405 | #define V4L2_SLICED_CAPTION_525 (0x1000) | ||
1406 | /* Wide Screen System, defined on ITU-R BT1119.1 */ | ||
1407 | #define V4L2_SLICED_WSS_625 (0x4000) | ||
1408 | |||
1409 | #define V4L2_SLICED_VBI_525 (V4L2_SLICED_CAPTION_525) | ||
1410 | #define V4L2_SLICED_VBI_625 (V4L2_SLICED_TELETEXT_B | V4L2_SLICED_VPS | V4L2_SLICED_WSS_625) | ||
1411 | |||
1412 | struct <link linkend="v4l2-sliced-vbi-cap">v4l2_sliced_vbi_cap</link> { | ||
1413 | __u16 service_set; | ||
1414 | /* service_lines[0][...] specifies lines 0-23 (1-23 used) of the first field | ||
1415 | service_lines[1][...] specifies lines 0-23 (1-23 used) of the second field | ||
1416 | (equals frame lines 313-336 for 625 line video | ||
1417 | standards, 263-286 for 525 line standards) */ | ||
1418 | __u16 service_lines[2][24]; | ||
1419 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> type; | ||
1420 | __u32 reserved[3]; /* must be 0 */ | ||
1421 | }; | ||
1422 | |||
1423 | struct <link linkend="v4l2-sliced-vbi-data">v4l2_sliced_vbi_data</link> { | ||
1424 | __u32 id; | ||
1425 | __u32 field; /* 0: first field, 1: second field */ | ||
1426 | __u32 line; /* 1-23 */ | ||
1427 | __u32 reserved; /* must be 0 */ | ||
1428 | __u8 data[48]; | ||
1429 | }; | ||
1430 | |||
1431 | /* | ||
1432 | * Sliced VBI data inserted into MPEG Streams | ||
1433 | */ | ||
1434 | |||
1435 | /* | ||
1436 | * V4L2_MPEG_STREAM_VBI_FMT_IVTV: | ||
1437 | * | ||
1438 | * Structure of payload contained in an MPEG 2 Private Stream 1 PES Packet in an | ||
1439 | * MPEG-2 Program Pack that contains V4L2_MPEG_STREAM_VBI_FMT_IVTV Sliced VBI | ||
1440 | * data | ||
1441 | * | ||
1442 | * Note, the MPEG-2 Program Pack and Private Stream 1 PES packet header | ||
1443 | * definitions are not included here. See the MPEG-2 specifications for details | ||
1444 | * on these headers. | ||
1445 | */ | ||
1446 | |||
1447 | /* Line type IDs */ | ||
1448 | #define V4L2_MPEG_VBI_IVTV_TELETEXT_B (1) | ||
1449 | #define V4L2_MPEG_VBI_IVTV_CAPTION_525 (4) | ||
1450 | #define V4L2_MPEG_VBI_IVTV_WSS_625 (5) | ||
1451 | #define V4L2_MPEG_VBI_IVTV_VPS (7) | ||
1452 | |||
1453 | struct <link linkend="v4l2-mpeg-vbi-itv0-line">v4l2_mpeg_vbi_itv0_line</link> { | ||
1454 | __u8 id; /* One of V4L2_MPEG_VBI_IVTV_* above */ | ||
1455 | __u8 data[42]; /* Sliced VBI data for the line */ | ||
1456 | } __attribute__ ((packed)); | ||
1457 | |||
1458 | struct <link linkend="v4l2-mpeg-vbi-itv0">v4l2_mpeg_vbi_itv0</link> { | ||
1459 | __le32 linemask[2]; /* Bitmasks of VBI service lines present */ | ||
1460 | struct <link linkend="v4l2-mpeg-vbi-itv0-line">v4l2_mpeg_vbi_itv0_line</link> line[35]; | ||
1461 | } __attribute__ ((packed)); | ||
1462 | |||
1463 | struct <link linkend="v4l2-mpeg-vbi-itv0-1">v4l2_mpeg_vbi_ITV0</link> { | ||
1464 | struct <link linkend="v4l2-mpeg-vbi-itv0-line">v4l2_mpeg_vbi_itv0_line</link> line[36]; | ||
1465 | } __attribute__ ((packed)); | ||
1466 | |||
1467 | #define V4L2_MPEG_VBI_IVTV_MAGIC0 "itv0" | ||
1468 | #define V4L2_MPEG_VBI_IVTV_MAGIC1 "ITV0" | ||
1469 | |||
1470 | struct <link linkend="v4l2-mpeg-vbi-fmt-ivtv">v4l2_mpeg_vbi_fmt_ivtv</link> { | ||
1471 | __u8 magic[4]; | ||
1472 | union { | ||
1473 | struct <link linkend="v4l2-mpeg-vbi-itv0">v4l2_mpeg_vbi_itv0</link> itv0; | ||
1474 | struct <link linkend="v4l2-mpeg-vbi-itv0-1">v4l2_mpeg_vbi_ITV0</link> ITV0; | ||
1475 | }; | ||
1476 | } __attribute__ ((packed)); | ||
1477 | |||
1478 | /* | ||
1479 | * A G G R E G A T E S T R U C T U R E S | ||
1480 | */ | ||
1481 | |||
1482 | /* Stream data format | ||
1483 | */ | ||
1484 | struct <link linkend="v4l2-format">v4l2_format</link> { | ||
1485 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> type; | ||
1486 | union { | ||
1487 | struct <link linkend="v4l2-pix-format">v4l2_pix_format</link> pix; /* V4L2_BUF_TYPE_VIDEO_CAPTURE */ | ||
1488 | struct <link linkend="v4l2-window">v4l2_window</link> win; /* V4L2_BUF_TYPE_VIDEO_OVERLAY */ | ||
1489 | struct <link linkend="v4l2-vbi-format">v4l2_vbi_format</link> vbi; /* V4L2_BUF_TYPE_VBI_CAPTURE */ | ||
1490 | struct <link linkend="v4l2-sliced-vbi-format">v4l2_sliced_vbi_format</link> sliced; /* V4L2_BUF_TYPE_SLICED_VBI_CAPTURE */ | ||
1491 | __u8 raw_data[200]; /* user-defined */ | ||
1492 | } fmt; | ||
1493 | }; | ||
1494 | |||
1495 | |||
1496 | /* Stream type-dependent parameters | ||
1497 | */ | ||
1498 | struct <link linkend="v4l2-streamparm">v4l2_streamparm</link> { | ||
1499 | enum <link linkend="v4l2-buf-type">v4l2_buf_type</link> type; | ||
1500 | union { | ||
1501 | struct <link linkend="v4l2-captureparm">v4l2_captureparm</link> capture; | ||
1502 | struct <link linkend="v4l2-outputparm">v4l2_outputparm</link> output; | ||
1503 | __u8 raw_data[200]; /* user-defined */ | ||
1504 | } parm; | ||
1505 | }; | ||
1506 | |||
1507 | /* | ||
1508 | * A D V A N C E D D E B U G G I N G | ||
1509 | * | ||
1510 | * NOTE: EXPERIMENTAL API, NEVER RELY ON THIS IN APPLICATIONS! | ||
1511 | * FOR DEBUGGING, TESTING AND INTERNAL USE ONLY! | ||
1512 | */ | ||
1513 | |||
1514 | /* VIDIOC_DBG_G_REGISTER and VIDIOC_DBG_S_REGISTER */ | ||
1515 | |||
1516 | #define V4L2_CHIP_MATCH_HOST 0 /* Match against chip ID on host (0 for the host) */ | ||
1517 | #define V4L2_CHIP_MATCH_I2C_DRIVER 1 /* Match against I2C driver name */ | ||
1518 | #define V4L2_CHIP_MATCH_I2C_ADDR 2 /* Match against I2C 7-bit address */ | ||
1519 | #define V4L2_CHIP_MATCH_AC97 3 /* Match against anciliary AC97 chip */ | ||
1520 | |||
1521 | struct <link linkend="v4l2-dbg-match">v4l2_dbg_match</link> { | ||
1522 | __u32 type; /* Match type */ | ||
1523 | union { /* Match this chip, meaning determined by type */ | ||
1524 | __u32 addr; | ||
1525 | char name[32]; | ||
1526 | }; | ||
1527 | } __attribute__ ((packed)); | ||
1528 | |||
1529 | struct <link linkend="v4l2-dbg-register">v4l2_dbg_register</link> { | ||
1530 | struct <link linkend="v4l2-dbg-match">v4l2_dbg_match</link> match; | ||
1531 | __u32 size; /* register size in bytes */ | ||
1532 | __u64 reg; | ||
1533 | __u64 val; | ||
1534 | } __attribute__ ((packed)); | ||
1535 | |||
1536 | /* VIDIOC_DBG_G_CHIP_IDENT */ | ||
1537 | struct <link linkend="v4l2-dbg-chip-ident">v4l2_dbg_chip_ident</link> { | ||
1538 | struct <link linkend="v4l2-dbg-match">v4l2_dbg_match</link> match; | ||
1539 | __u32 ident; /* chip identifier as specified in <media/v4l2-chip-ident.h> */ | ||
1540 | __u32 revision; /* chip revision, chip specific */ | ||
1541 | } __attribute__ ((packed)); | ||
1542 | |||
1543 | /* | ||
1544 | * I O C T L C O D E S F O R V I D E O D E V I C E S | ||
1545 | * | ||
1546 | */ | ||
1547 | #define VIDIOC_QUERYCAP _IOR('V', 0, struct <link linkend="v4l2-capability">v4l2_capability</link>) | ||
1548 | #define VIDIOC_RESERVED _IO('V', 1) | ||
1549 | #define VIDIOC_ENUM_FMT _IOWR('V', 2, struct <link linkend="v4l2-fmtdesc">v4l2_fmtdesc</link>) | ||
1550 | #define VIDIOC_G_FMT _IOWR('V', 4, struct <link linkend="v4l2-format">v4l2_format</link>) | ||
1551 | #define VIDIOC_S_FMT _IOWR('V', 5, struct <link linkend="v4l2-format">v4l2_format</link>) | ||
1552 | #define VIDIOC_REQBUFS _IOWR('V', 8, struct <link linkend="v4l2-requestbuffers">v4l2_requestbuffers</link>) | ||
1553 | #define VIDIOC_QUERYBUF _IOWR('V', 9, struct <link linkend="v4l2-buffer">v4l2_buffer</link>) | ||
1554 | #define VIDIOC_G_FBUF _IOR('V', 10, struct <link linkend="v4l2-framebuffer">v4l2_framebuffer</link>) | ||
1555 | #define VIDIOC_S_FBUF _IOW('V', 11, struct <link linkend="v4l2-framebuffer">v4l2_framebuffer</link>) | ||
1556 | #define VIDIOC_OVERLAY _IOW('V', 14, int) | ||
1557 | #define VIDIOC_QBUF _IOWR('V', 15, struct <link linkend="v4l2-buffer">v4l2_buffer</link>) | ||
1558 | #define VIDIOC_DQBUF _IOWR('V', 17, struct <link linkend="v4l2-buffer">v4l2_buffer</link>) | ||
1559 | #define VIDIOC_STREAMON _IOW('V', 18, int) | ||
1560 | #define VIDIOC_STREAMOFF _IOW('V', 19, int) | ||
1561 | #define VIDIOC_G_PARM _IOWR('V', 21, struct <link linkend="v4l2-streamparm">v4l2_streamparm</link>) | ||
1562 | #define VIDIOC_S_PARM _IOWR('V', 22, struct <link linkend="v4l2-streamparm">v4l2_streamparm</link>) | ||
1563 | #define VIDIOC_G_STD _IOR('V', 23, v4l2_std_id) | ||
1564 | #define VIDIOC_S_STD _IOW('V', 24, v4l2_std_id) | ||
1565 | #define VIDIOC_ENUMSTD _IOWR('V', 25, struct <link linkend="v4l2-standard">v4l2_standard</link>) | ||
1566 | #define VIDIOC_ENUMINPUT _IOWR('V', 26, struct <link linkend="v4l2-input">v4l2_input</link>) | ||
1567 | #define VIDIOC_G_CTRL _IOWR('V', 27, struct <link linkend="v4l2-control">v4l2_control</link>) | ||
1568 | #define VIDIOC_S_CTRL _IOWR('V', 28, struct <link linkend="v4l2-control">v4l2_control</link>) | ||
1569 | #define VIDIOC_G_TUNER _IOWR('V', 29, struct <link linkend="v4l2-tuner">v4l2_tuner</link>) | ||
1570 | #define VIDIOC_S_TUNER _IOW('V', 30, struct <link linkend="v4l2-tuner">v4l2_tuner</link>) | ||
1571 | #define VIDIOC_G_AUDIO _IOR('V', 33, struct <link linkend="v4l2-audio">v4l2_audio</link>) | ||
1572 | #define VIDIOC_S_AUDIO _IOW('V', 34, struct <link linkend="v4l2-audio">v4l2_audio</link>) | ||
1573 | #define VIDIOC_QUERYCTRL _IOWR('V', 36, struct <link linkend="v4l2-queryctrl">v4l2_queryctrl</link>) | ||
1574 | #define VIDIOC_QUERYMENU _IOWR('V', 37, struct <link linkend="v4l2-querymenu">v4l2_querymenu</link>) | ||
1575 | #define VIDIOC_G_INPUT _IOR('V', 38, int) | ||
1576 | #define VIDIOC_S_INPUT _IOWR('V', 39, int) | ||
1577 | #define VIDIOC_G_OUTPUT _IOR('V', 46, int) | ||
1578 | #define VIDIOC_S_OUTPUT _IOWR('V', 47, int) | ||
1579 | #define VIDIOC_ENUMOUTPUT _IOWR('V', 48, struct <link linkend="v4l2-output">v4l2_output</link>) | ||
1580 | #define VIDIOC_G_AUDOUT _IOR('V', 49, struct <link linkend="v4l2-audioout">v4l2_audioout</link>) | ||
1581 | #define VIDIOC_S_AUDOUT _IOW('V', 50, struct <link linkend="v4l2-audioout">v4l2_audioout</link>) | ||
1582 | #define VIDIOC_G_MODULATOR _IOWR('V', 54, struct <link linkend="v4l2-modulator">v4l2_modulator</link>) | ||
1583 | #define VIDIOC_S_MODULATOR _IOW('V', 55, struct <link linkend="v4l2-modulator">v4l2_modulator</link>) | ||
1584 | #define VIDIOC_G_FREQUENCY _IOWR('V', 56, struct <link linkend="v4l2-frequency">v4l2_frequency</link>) | ||
1585 | #define VIDIOC_S_FREQUENCY _IOW('V', 57, struct <link linkend="v4l2-frequency">v4l2_frequency</link>) | ||
1586 | #define VIDIOC_CROPCAP _IOWR('V', 58, struct <link linkend="v4l2-cropcap">v4l2_cropcap</link>) | ||
1587 | #define VIDIOC_G_CROP _IOWR('V', 59, struct <link linkend="v4l2-crop">v4l2_crop</link>) | ||
1588 | #define VIDIOC_S_CROP _IOW('V', 60, struct <link linkend="v4l2-crop">v4l2_crop</link>) | ||
1589 | #define VIDIOC_G_JPEGCOMP _IOR('V', 61, struct <link linkend="v4l2-jpegcompression">v4l2_jpegcompression</link>) | ||
1590 | #define VIDIOC_S_JPEGCOMP _IOW('V', 62, struct <link linkend="v4l2-jpegcompression">v4l2_jpegcompression</link>) | ||
1591 | #define VIDIOC_QUERYSTD _IOR('V', 63, v4l2_std_id) | ||
1592 | #define VIDIOC_TRY_FMT _IOWR('V', 64, struct <link linkend="v4l2-format">v4l2_format</link>) | ||
1593 | #define VIDIOC_ENUMAUDIO _IOWR('V', 65, struct <link linkend="v4l2-audio">v4l2_audio</link>) | ||
1594 | #define VIDIOC_ENUMAUDOUT _IOWR('V', 66, struct <link linkend="v4l2-audioout">v4l2_audioout</link>) | ||
1595 | #define VIDIOC_G_PRIORITY _IOR('V', 67, enum <link linkend="v4l2-priority">v4l2_priority</link>) | ||
1596 | #define VIDIOC_S_PRIORITY _IOW('V', 68, enum <link linkend="v4l2-priority">v4l2_priority</link>) | ||
1597 | #define VIDIOC_G_SLICED_VBI_CAP _IOWR('V', 69, struct <link linkend="v4l2-sliced-vbi-cap">v4l2_sliced_vbi_cap</link>) | ||
1598 | #define VIDIOC_LOG_STATUS _IO('V', 70) | ||
1599 | #define VIDIOC_G_EXT_CTRLS _IOWR('V', 71, struct <link linkend="v4l2-ext-controls">v4l2_ext_controls</link>) | ||
1600 | #define VIDIOC_S_EXT_CTRLS _IOWR('V', 72, struct <link linkend="v4l2-ext-controls">v4l2_ext_controls</link>) | ||
1601 | #define VIDIOC_TRY_EXT_CTRLS _IOWR('V', 73, struct <link linkend="v4l2-ext-controls">v4l2_ext_controls</link>) | ||
1602 | #if 1 /*KEEP*/ | ||
1603 | #define VIDIOC_ENUM_FRAMESIZES _IOWR('V', 74, struct <link linkend="v4l2-frmsizeenum">v4l2_frmsizeenum</link>) | ||
1604 | #define VIDIOC_ENUM_FRAMEINTERVALS _IOWR('V', 75, struct <link linkend="v4l2-frmivalenum">v4l2_frmivalenum</link>) | ||
1605 | #define VIDIOC_G_ENC_INDEX _IOR('V', 76, struct <link linkend="v4l2-enc-idx">v4l2_enc_idx</link>) | ||
1606 | #define VIDIOC_ENCODER_CMD _IOWR('V', 77, struct <link linkend="v4l2-encoder-cmd">v4l2_encoder_cmd</link>) | ||
1607 | #define VIDIOC_TRY_ENCODER_CMD _IOWR('V', 78, struct <link linkend="v4l2-encoder-cmd">v4l2_encoder_cmd</link>) | ||
1608 | #endif | ||
1609 | |||
1610 | #if 1 /*KEEP*/ | ||
1611 | /* Experimental, meant for debugging, testing and internal use. | ||
1612 | Only implemented if CONFIG_VIDEO_ADV_DEBUG is defined. | ||
1613 | You must be root to use these ioctls. Never use these in applications! */ | ||
1614 | #define VIDIOC_DBG_S_REGISTER _IOW('V', 79, struct <link linkend="v4l2-dbg-register">v4l2_dbg_register</link>) | ||
1615 | #define VIDIOC_DBG_G_REGISTER _IOWR('V', 80, struct <link linkend="v4l2-dbg-register">v4l2_dbg_register</link>) | ||
1616 | |||
1617 | /* Experimental, meant for debugging, testing and internal use. | ||
1618 | Never use this ioctl in applications! */ | ||
1619 | #define VIDIOC_DBG_G_CHIP_IDENT _IOWR('V', 81, struct <link linkend="v4l2-dbg-chip-ident">v4l2_dbg_chip_ident</link>) | ||
1620 | #endif | ||
1621 | |||
1622 | #define VIDIOC_S_HW_FREQ_SEEK _IOW('V', 82, struct <link linkend="v4l2-hw-freq-seek">v4l2_hw_freq_seek</link>) | ||
1623 | /* Reminder: when adding new ioctls please add support for them to | ||
1624 | drivers/media/video/v4l2-compat-ioctl32.c as well! */ | ||
1625 | |||
1626 | #ifdef __OLD_VIDIOC_ | ||
1627 | /* for compatibility, will go away some day */ | ||
1628 | #define VIDIOC_OVERLAY_OLD _IOWR('V', 14, int) | ||
1629 | #define VIDIOC_S_PARM_OLD _IOW('V', 22, struct <link linkend="v4l2-streamparm">v4l2_streamparm</link>) | ||
1630 | #define VIDIOC_S_CTRL_OLD _IOW('V', 28, struct <link linkend="v4l2-control">v4l2_control</link>) | ||
1631 | #define VIDIOC_G_AUDIO_OLD _IOWR('V', 33, struct <link linkend="v4l2-audio">v4l2_audio</link>) | ||
1632 | #define VIDIOC_G_AUDOUT_OLD _IOWR('V', 49, struct <link linkend="v4l2-audioout">v4l2_audioout</link>) | ||
1633 | #define VIDIOC_CROPCAP_OLD _IOR('V', 58, struct <link linkend="v4l2-cropcap">v4l2_cropcap</link>) | ||
1634 | #endif | ||
1635 | |||
1636 | #define BASE_VIDIOC_PRIVATE 192 /* 192-255 are private */ | ||
1637 | |||
1638 | #endif /* __LINUX_VIDEODEV2_H */ | ||
1639 | </programlisting> | ||