blob: 017ffb2220c7c66a808b5d7231350f1fa40a276c [file] [log] [blame]
Hans Verkuil35ea11f2008-07-20 08:12:02 -03001/*
2 *
3 * V 4 L 2 D R I V E R H E L P E R A P I
4 *
5 * Moved from videodev2.h
6 *
7 * Some commonly needed functions for drivers (v4l2-common.o module)
8 */
9#ifndef _V4L2_IOCTL_H
10#define _V4L2_IOCTL_H
11
12#include <linux/poll.h>
13#include <linux/fs.h>
Hans Verkuil35ea11f2008-07-20 08:12:02 -030014#include <linux/mutex.h>
15#include <linux/compiler.h> /* need __user */
Hans Verkuil35ea11f2008-07-20 08:12:02 -030016#include <linux/videodev2.h>
Hans Verkuil35ea11f2008-07-20 08:12:02 -030017
Sakari Ailusd3d7c962010-03-27 11:02:10 -030018struct v4l2_fh;
19
Hans Verkuila3998102008-07-21 02:57:38 -030020struct v4l2_ioctl_ops {
21 /* ioctl callbacks */
22
23 /* VIDIOC_QUERYCAP handler */
24 int (*vidioc_querycap)(struct file *file, void *fh, struct v4l2_capability *cap);
25
Hans Verkuila3998102008-07-21 02:57:38 -030026 /* VIDIOC_ENUM_FMT handlers */
27 int (*vidioc_enum_fmt_vid_cap) (struct file *file, void *fh,
28 struct v4l2_fmtdesc *f);
29 int (*vidioc_enum_fmt_vid_overlay) (struct file *file, void *fh,
30 struct v4l2_fmtdesc *f);
31 int (*vidioc_enum_fmt_vid_out) (struct file *file, void *fh,
32 struct v4l2_fmtdesc *f);
Pawel Osciakd14e6d72010-12-23 04:15:27 -030033 int (*vidioc_enum_fmt_vid_cap_mplane)(struct file *file, void *fh,
34 struct v4l2_fmtdesc *f);
35 int (*vidioc_enum_fmt_vid_out_mplane)(struct file *file, void *fh,
36 struct v4l2_fmtdesc *f);
Antti Palosaari855df1d2013-12-14 13:10:20 -030037 int (*vidioc_enum_fmt_sdr_cap) (struct file *file, void *fh,
38 struct v4l2_fmtdesc *f);
Antti Palosaari9effc722015-10-10 13:51:00 -030039 int (*vidioc_enum_fmt_sdr_out) (struct file *file, void *fh,
40 struct v4l2_fmtdesc *f);
Hans Verkuila3998102008-07-21 02:57:38 -030041
42 /* VIDIOC_G_FMT handlers */
43 int (*vidioc_g_fmt_vid_cap) (struct file *file, void *fh,
44 struct v4l2_format *f);
45 int (*vidioc_g_fmt_vid_overlay)(struct file *file, void *fh,
46 struct v4l2_format *f);
47 int (*vidioc_g_fmt_vid_out) (struct file *file, void *fh,
48 struct v4l2_format *f);
49 int (*vidioc_g_fmt_vid_out_overlay)(struct file *file, void *fh,
50 struct v4l2_format *f);
51 int (*vidioc_g_fmt_vbi_cap) (struct file *file, void *fh,
52 struct v4l2_format *f);
53 int (*vidioc_g_fmt_vbi_out) (struct file *file, void *fh,
54 struct v4l2_format *f);
55 int (*vidioc_g_fmt_sliced_vbi_cap)(struct file *file, void *fh,
56 struct v4l2_format *f);
57 int (*vidioc_g_fmt_sliced_vbi_out)(struct file *file, void *fh,
58 struct v4l2_format *f);
Pawel Osciakd14e6d72010-12-23 04:15:27 -030059 int (*vidioc_g_fmt_vid_cap_mplane)(struct file *file, void *fh,
60 struct v4l2_format *f);
61 int (*vidioc_g_fmt_vid_out_mplane)(struct file *file, void *fh,
62 struct v4l2_format *f);
Antti Palosaari855df1d2013-12-14 13:10:20 -030063 int (*vidioc_g_fmt_sdr_cap) (struct file *file, void *fh,
64 struct v4l2_format *f);
Antti Palosaari9effc722015-10-10 13:51:00 -030065 int (*vidioc_g_fmt_sdr_out) (struct file *file, void *fh,
66 struct v4l2_format *f);
Hans Verkuila3998102008-07-21 02:57:38 -030067
68 /* VIDIOC_S_FMT handlers */
69 int (*vidioc_s_fmt_vid_cap) (struct file *file, void *fh,
70 struct v4l2_format *f);
71 int (*vidioc_s_fmt_vid_overlay)(struct file *file, void *fh,
72 struct v4l2_format *f);
73 int (*vidioc_s_fmt_vid_out) (struct file *file, void *fh,
74 struct v4l2_format *f);
75 int (*vidioc_s_fmt_vid_out_overlay)(struct file *file, void *fh,
76 struct v4l2_format *f);
77 int (*vidioc_s_fmt_vbi_cap) (struct file *file, void *fh,
78 struct v4l2_format *f);
79 int (*vidioc_s_fmt_vbi_out) (struct file *file, void *fh,
80 struct v4l2_format *f);
81 int (*vidioc_s_fmt_sliced_vbi_cap)(struct file *file, void *fh,
82 struct v4l2_format *f);
83 int (*vidioc_s_fmt_sliced_vbi_out)(struct file *file, void *fh,
84 struct v4l2_format *f);
Pawel Osciakd14e6d72010-12-23 04:15:27 -030085 int (*vidioc_s_fmt_vid_cap_mplane)(struct file *file, void *fh,
86 struct v4l2_format *f);
87 int (*vidioc_s_fmt_vid_out_mplane)(struct file *file, void *fh,
88 struct v4l2_format *f);
Antti Palosaari855df1d2013-12-14 13:10:20 -030089 int (*vidioc_s_fmt_sdr_cap) (struct file *file, void *fh,
90 struct v4l2_format *f);
Antti Palosaari9effc722015-10-10 13:51:00 -030091 int (*vidioc_s_fmt_sdr_out) (struct file *file, void *fh,
92 struct v4l2_format *f);
Hans Verkuila3998102008-07-21 02:57:38 -030093
94 /* VIDIOC_TRY_FMT handlers */
95 int (*vidioc_try_fmt_vid_cap) (struct file *file, void *fh,
96 struct v4l2_format *f);
97 int (*vidioc_try_fmt_vid_overlay)(struct file *file, void *fh,
98 struct v4l2_format *f);
99 int (*vidioc_try_fmt_vid_out) (struct file *file, void *fh,
100 struct v4l2_format *f);
101 int (*vidioc_try_fmt_vid_out_overlay)(struct file *file, void *fh,
102 struct v4l2_format *f);
103 int (*vidioc_try_fmt_vbi_cap) (struct file *file, void *fh,
104 struct v4l2_format *f);
105 int (*vidioc_try_fmt_vbi_out) (struct file *file, void *fh,
106 struct v4l2_format *f);
107 int (*vidioc_try_fmt_sliced_vbi_cap)(struct file *file, void *fh,
108 struct v4l2_format *f);
109 int (*vidioc_try_fmt_sliced_vbi_out)(struct file *file, void *fh,
110 struct v4l2_format *f);
Pawel Osciakd14e6d72010-12-23 04:15:27 -0300111 int (*vidioc_try_fmt_vid_cap_mplane)(struct file *file, void *fh,
112 struct v4l2_format *f);
113 int (*vidioc_try_fmt_vid_out_mplane)(struct file *file, void *fh,
114 struct v4l2_format *f);
Antti Palosaari855df1d2013-12-14 13:10:20 -0300115 int (*vidioc_try_fmt_sdr_cap) (struct file *file, void *fh,
116 struct v4l2_format *f);
Antti Palosaari9effc722015-10-10 13:51:00 -0300117 int (*vidioc_try_fmt_sdr_out) (struct file *file, void *fh,
118 struct v4l2_format *f);
Hans Verkuila3998102008-07-21 02:57:38 -0300119
120 /* Buffer handlers */
121 int (*vidioc_reqbufs) (struct file *file, void *fh, struct v4l2_requestbuffers *b);
122 int (*vidioc_querybuf)(struct file *file, void *fh, struct v4l2_buffer *b);
123 int (*vidioc_qbuf) (struct file *file, void *fh, struct v4l2_buffer *b);
Tomasz Stanislawskib799d092012-06-14 11:32:23 -0300124 int (*vidioc_expbuf) (struct file *file, void *fh,
125 struct v4l2_exportbuffer *e);
Hans Verkuila3998102008-07-21 02:57:38 -0300126 int (*vidioc_dqbuf) (struct file *file, void *fh, struct v4l2_buffer *b);
127
Guennadi Liakhovetski21501582011-09-28 11:34:06 -0300128 int (*vidioc_create_bufs)(struct file *file, void *fh, struct v4l2_create_buffers *b);
129 int (*vidioc_prepare_buf)(struct file *file, void *fh, struct v4l2_buffer *b);
Hans Verkuila3998102008-07-21 02:57:38 -0300130
131 int (*vidioc_overlay) (struct file *file, void *fh, unsigned int i);
Hans Verkuila3998102008-07-21 02:57:38 -0300132 int (*vidioc_g_fbuf) (struct file *file, void *fh,
133 struct v4l2_framebuffer *a);
134 int (*vidioc_s_fbuf) (struct file *file, void *fh,
Hans Verkuile6eb28c2012-09-04 10:26:45 -0300135 const struct v4l2_framebuffer *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300136
137 /* Stream on/off */
138 int (*vidioc_streamon) (struct file *file, void *fh, enum v4l2_buf_type i);
139 int (*vidioc_streamoff)(struct file *file, void *fh, enum v4l2_buf_type i);
140
141 /* Standard handling
142 ENUMSTD is handled by videodev.c
143 */
144 int (*vidioc_g_std) (struct file *file, void *fh, v4l2_std_id *norm);
Hans Verkuil314527a2013-03-15 06:10:40 -0300145 int (*vidioc_s_std) (struct file *file, void *fh, v4l2_std_id norm);
Hans Verkuila3998102008-07-21 02:57:38 -0300146 int (*vidioc_querystd) (struct file *file, void *fh, v4l2_std_id *a);
147
148 /* Input handling */
149 int (*vidioc_enum_input)(struct file *file, void *fh,
150 struct v4l2_input *inp);
151 int (*vidioc_g_input) (struct file *file, void *fh, unsigned int *i);
152 int (*vidioc_s_input) (struct file *file, void *fh, unsigned int i);
153
154 /* Output handling */
155 int (*vidioc_enum_output) (struct file *file, void *fh,
156 struct v4l2_output *a);
157 int (*vidioc_g_output) (struct file *file, void *fh, unsigned int *i);
158 int (*vidioc_s_output) (struct file *file, void *fh, unsigned int i);
159
160 /* Control handling */
161 int (*vidioc_queryctrl) (struct file *file, void *fh,
162 struct v4l2_queryctrl *a);
Hans Verkuile6bee362014-06-10 04:22:06 -0300163 int (*vidioc_query_ext_ctrl) (struct file *file, void *fh,
164 struct v4l2_query_ext_ctrl *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300165 int (*vidioc_g_ctrl) (struct file *file, void *fh,
166 struct v4l2_control *a);
167 int (*vidioc_s_ctrl) (struct file *file, void *fh,
168 struct v4l2_control *a);
169 int (*vidioc_g_ext_ctrls) (struct file *file, void *fh,
170 struct v4l2_ext_controls *a);
171 int (*vidioc_s_ext_ctrls) (struct file *file, void *fh,
172 struct v4l2_ext_controls *a);
173 int (*vidioc_try_ext_ctrls) (struct file *file, void *fh,
174 struct v4l2_ext_controls *a);
175 int (*vidioc_querymenu) (struct file *file, void *fh,
176 struct v4l2_querymenu *a);
177
178 /* Audio ioctls */
179 int (*vidioc_enumaudio) (struct file *file, void *fh,
180 struct v4l2_audio *a);
181 int (*vidioc_g_audio) (struct file *file, void *fh,
182 struct v4l2_audio *a);
183 int (*vidioc_s_audio) (struct file *file, void *fh,
Hans Verkuil0e8025b92012-09-04 11:59:31 -0300184 const struct v4l2_audio *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300185
186 /* Audio out ioctls */
187 int (*vidioc_enumaudout) (struct file *file, void *fh,
188 struct v4l2_audioout *a);
189 int (*vidioc_g_audout) (struct file *file, void *fh,
190 struct v4l2_audioout *a);
191 int (*vidioc_s_audout) (struct file *file, void *fh,
Hans Verkuilba9425b2012-09-04 12:03:49 -0300192 const struct v4l2_audioout *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300193 int (*vidioc_g_modulator) (struct file *file, void *fh,
194 struct v4l2_modulator *a);
195 int (*vidioc_s_modulator) (struct file *file, void *fh,
Hans Verkuil3f70e1f2012-09-04 12:08:47 -0300196 const struct v4l2_modulator *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300197 /* Crop ioctls */
198 int (*vidioc_cropcap) (struct file *file, void *fh,
199 struct v4l2_cropcap *a);
200 int (*vidioc_g_crop) (struct file *file, void *fh,
201 struct v4l2_crop *a);
202 int (*vidioc_s_crop) (struct file *file, void *fh,
Hans Verkuil4f996592012-09-05 05:10:48 -0300203 const struct v4l2_crop *a);
Tomasz Stanislawski0e8caac2011-08-10 10:37:47 -0300204 int (*vidioc_g_selection) (struct file *file, void *fh,
205 struct v4l2_selection *s);
206 int (*vidioc_s_selection) (struct file *file, void *fh,
207 struct v4l2_selection *s);
Hans Verkuila3998102008-07-21 02:57:38 -0300208 /* Compression ioctls */
209 int (*vidioc_g_jpegcomp) (struct file *file, void *fh,
210 struct v4l2_jpegcompression *a);
211 int (*vidioc_s_jpegcomp) (struct file *file, void *fh,
Hans Verkuild88aab52012-09-17 05:05:25 -0300212 const struct v4l2_jpegcompression *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300213 int (*vidioc_g_enc_index) (struct file *file, void *fh,
214 struct v4l2_enc_idx *a);
215 int (*vidioc_encoder_cmd) (struct file *file, void *fh,
216 struct v4l2_encoder_cmd *a);
217 int (*vidioc_try_encoder_cmd) (struct file *file, void *fh,
218 struct v4l2_encoder_cmd *a);
Hans Verkuila45c0ad2011-11-24 09:53:43 -0300219 int (*vidioc_decoder_cmd) (struct file *file, void *fh,
220 struct v4l2_decoder_cmd *a);
221 int (*vidioc_try_decoder_cmd) (struct file *file, void *fh,
222 struct v4l2_decoder_cmd *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300223
224 /* Stream type-dependent parameter ioctls */
225 int (*vidioc_g_parm) (struct file *file, void *fh,
226 struct v4l2_streamparm *a);
227 int (*vidioc_s_parm) (struct file *file, void *fh,
228 struct v4l2_streamparm *a);
229
230 /* Tuner ioctls */
231 int (*vidioc_g_tuner) (struct file *file, void *fh,
232 struct v4l2_tuner *a);
233 int (*vidioc_s_tuner) (struct file *file, void *fh,
Hans Verkuil2f73c7c2013-03-15 06:10:06 -0300234 const struct v4l2_tuner *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300235 int (*vidioc_g_frequency) (struct file *file, void *fh,
236 struct v4l2_frequency *a);
237 int (*vidioc_s_frequency) (struct file *file, void *fh,
Hans Verkuilb530a442013-03-19 04:09:26 -0300238 const struct v4l2_frequency *a);
Hans Verkuil82b655b2012-07-05 06:37:08 -0300239 int (*vidioc_enum_freq_bands) (struct file *file, void *fh,
240 struct v4l2_frequency_band *band);
Hans Verkuila3998102008-07-21 02:57:38 -0300241
242 /* Sliced VBI cap */
243 int (*vidioc_g_sliced_vbi_cap) (struct file *file, void *fh,
244 struct v4l2_sliced_vbi_cap *a);
245
246 /* Log status ioctl */
247 int (*vidioc_log_status) (struct file *file, void *fh);
248
249 int (*vidioc_s_hw_freq_seek) (struct file *file, void *fh,
Hans Verkuilec6f4322012-09-14 07:41:18 -0300250 const struct v4l2_hw_freq_seek *a);
Hans Verkuila3998102008-07-21 02:57:38 -0300251
252 /* Debugging ioctls */
253#ifdef CONFIG_VIDEO_ADV_DEBUG
254 int (*vidioc_g_register) (struct file *file, void *fh,
Hans Verkuilaecde8b52008-12-30 07:14:19 -0300255 struct v4l2_dbg_register *reg);
Hans Verkuila3998102008-07-21 02:57:38 -0300256 int (*vidioc_s_register) (struct file *file, void *fh,
Hans Verkuil977ba3b2013-03-24 08:28:46 -0300257 const struct v4l2_dbg_register *reg);
Hans Verkuila3998102008-07-21 02:57:38 -0300258
Hans Verkuil96b03d22013-04-06 06:16:58 -0300259 int (*vidioc_g_chip_info) (struct file *file, void *fh,
260 struct v4l2_dbg_chip_info *chip);
Hans Verkuilcd634f12013-03-27 08:04:23 -0300261#endif
Hans Verkuil79b0c642013-03-18 12:16:34 -0300262
Mauro Carvalho Chehab74d83fa2008-11-11 21:13:47 -0300263 int (*vidioc_enum_framesizes) (struct file *file, void *fh,
264 struct v4l2_frmsizeenum *fsize);
265
266 int (*vidioc_enum_frameintervals) (struct file *file, void *fh,
267 struct v4l2_frmivalenum *fival);
268
Muralidharan Karicherib6456c02009-11-19 12:00:31 -0300269 /* DV Timings IOCTLs */
Muralidharan Karicherib6456c02009-11-19 12:00:31 -0300270 int (*vidioc_s_dv_timings) (struct file *file, void *fh,
271 struct v4l2_dv_timings *timings);
272 int (*vidioc_g_dv_timings) (struct file *file, void *fh,
273 struct v4l2_dv_timings *timings);
Hans Verkuil5d7758e2012-05-15 08:06:44 -0300274 int (*vidioc_query_dv_timings) (struct file *file, void *fh,
275 struct v4l2_dv_timings *timings);
276 int (*vidioc_enum_dv_timings) (struct file *file, void *fh,
277 struct v4l2_enum_dv_timings *timings);
278 int (*vidioc_dv_timings_cap) (struct file *file, void *fh,
279 struct v4l2_dv_timings_cap *cap);
Hans Verkuildd519bb2014-03-07 07:18:37 -0300280 int (*vidioc_g_edid) (struct file *file, void *fh, struct v4l2_edid *edid);
281 int (*vidioc_s_edid) (struct file *file, void *fh, struct v4l2_edid *edid);
Muralidharan Karicherib6456c02009-11-19 12:00:31 -0300282
Sakari Ailusd3d7c962010-03-27 11:02:10 -0300283 int (*vidioc_subscribe_event) (struct v4l2_fh *fh,
Hans Verkuil85f5fe32012-09-04 11:46:09 -0300284 const struct v4l2_event_subscription *sub);
Sakari Ailusd3d7c962010-03-27 11:02:10 -0300285 int (*vidioc_unsubscribe_event)(struct v4l2_fh *fh,
Hans Verkuil85f5fe32012-09-04 11:46:09 -0300286 const struct v4l2_event_subscription *sub);
Sakari Ailusd3d7c962010-03-27 11:02:10 -0300287
Hans Verkuila3998102008-07-21 02:57:38 -0300288 /* For other private ioctls */
Hans Verkuil069b7472008-12-30 07:04:34 -0300289 long (*vidioc_default) (struct file *file, void *fh,
Mauro Carvalho Chehab6d43be72013-03-26 08:04:52 -0300290 bool valid_prio, unsigned int cmd, void *arg);
Hans Verkuila3998102008-07-21 02:57:38 -0300291};
292
293
Mauro Carvalho Chehab28644622008-07-20 20:26:54 -0300294/* v4l debugging and diagnostics */
295
Hans Verkuil17028cd2014-12-01 10:10:44 -0300296/* Device debug flags to be used with the video device debug attribute */
297
298/* Just log the ioctl name + error code */
299#define V4L2_DEV_DEBUG_IOCTL 0x01
300/* Log the ioctl name arguments + error code */
301#define V4L2_DEV_DEBUG_IOCTL_ARG 0x02
302/* Log the file operations open, release, mmap and get_unmapped_area */
303#define V4L2_DEV_DEBUG_FOP 0x04
304/* Log the read and write file operations and the VIDIOC_(D)QBUF ioctls */
305#define V4L2_DEV_DEBUG_STREAMING 0x08
306/* Log poll() */
307#define V4L2_DEV_DEBUG_POLL 0x10
Mauro Carvalho Chehab28644622008-07-20 20:26:54 -0300308
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300309/* Video standard functions */
310extern const char *v4l2_norm_to_name(v4l2_std_id id);
Trent Piepho51f0b8d52009-03-04 01:21:02 -0300311extern void v4l2_video_std_frame_period(int id, struct v4l2_fract *frameperiod);
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300312extern int v4l2_video_std_construct(struct v4l2_standard *vs,
313 int id, const char *name);
Hans Verkuil4a085162012-06-22 06:38:06 -0300314/* Prints the ioctl in a human-readable format. If prefix != NULL,
315 then do printk(KERN_DEBUG "%s: ", prefix) first. */
316extern void v4l_printk_ioctl(const char *prefix, unsigned int cmd);
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300317
Hans Verkuil5a5adf62012-06-22 07:29:35 -0300318/* Internal use only: get the mutex (if any) that we need to lock for the
319 given command. */
320struct video_device;
321extern struct mutex *v4l2_ioctl_get_lock(struct video_device *vdev, unsigned cmd);
322
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300323/* names for fancy debug output */
324extern const char *v4l2_field_names[];
325extern const char *v4l2_type_names[];
326
Hans Verkuilbec43662008-12-30 06:58:20 -0300327#ifdef CONFIG_COMPAT
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300328/* 32 Bits compatibility layer for 64 bits processors */
Hans Verkuil9bb7cde2008-12-30 06:42:40 -0300329extern long v4l2_compat_ioctl32(struct file *file, unsigned int cmd,
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300330 unsigned long arg);
Hans Verkuilbec43662008-12-30 06:58:20 -0300331#endif
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300332
Hans Verkuil08af2452010-12-24 10:33:19 -0300333typedef long (*v4l2_kioctl)(struct file *file,
334 unsigned int cmd, void *arg);
335
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300336/* Include support for obsoleted stuff */
Hans Verkuil069b7472008-12-30 07:04:34 -0300337extern long video_usercopy(struct file *file, unsigned int cmd,
Hans Verkuilf473bf72008-11-01 08:25:11 -0300338 unsigned long arg, v4l2_kioctl func);
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300339
Mauro Carvalho Chehab8a522c92008-10-21 11:58:39 -0300340/* Standard handlers for V4L ioctl's */
Hans Verkuil069b7472008-12-30 07:04:34 -0300341extern long video_ioctl2(struct file *file,
Mauro Carvalho Chehab8a522c92008-10-21 11:58:39 -0300342 unsigned int cmd, unsigned long arg);
343
Hans Verkuil35ea11f2008-07-20 08:12:02 -0300344#endif /* _V4L2_IOCTL_H */