v4l2-dev.h 12.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11
/*
 *
 *	V 4 L 2   D R I V E R   H E L P E R   A P I
 *
 * Moved from videodev2.h
 *
 *	Some commonly needed functions for drivers (v4l2-common.o module)
 */
#ifndef _V4L2_DEV_H
#define _V4L2_DEV_H

12 13
#define OBSOLETE_OWNER   1 /* to be removed soon */
#define OBSOLETE_DEVDATA 1 /* to be removed soon */
14 15 16 17 18 19

#include <linux/poll.h>
#include <linux/fs.h>
#include <linux/device.h>
#include <linux/mutex.h>
#include <linux/compiler.h> /* need __user */
20
#ifdef CONFIG_VIDEO_V4L1_COMPAT
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
#include <linux/videodev.h>
#else
#include <linux/videodev2.h>
#endif

#define VIDEO_MAJOR	81
/* Minor device allocation */
#define MINOR_VFL_TYPE_GRABBER_MIN   0
#define MINOR_VFL_TYPE_GRABBER_MAX  63
#define MINOR_VFL_TYPE_RADIO_MIN    64
#define MINOR_VFL_TYPE_RADIO_MAX   127
#define MINOR_VFL_TYPE_VTX_MIN     192
#define MINOR_VFL_TYPE_VTX_MAX     223
#define MINOR_VFL_TYPE_VBI_MIN     224
#define MINOR_VFL_TYPE_VBI_MAX     255

#define VFL_TYPE_GRABBER	0
#define VFL_TYPE_VBI		1
#define VFL_TYPE_RADIO		2
#define VFL_TYPE_VTX		3

/*
 * Newer version of video_device, handled by videodev2.c
 * 	This version moves redundant code from video device code to
 *	the common handler
 */

struct video_device
{
	/* device ops */
51
	const struct file_operations *fops;
52

53
	/* sysfs */
54
	struct device dev;		/* v4l device */
55
	struct device *parent;		/* device parent */
56

57 58
	/* device info */
	char name[32];
59 60
	int type;       		/* v4l1 */
	int type2;      		/* v4l2 */
61
	int minor;
62 63
	/* attribute to diferentiate multiple indexs on one physical device */
	int index;
64

65
	int debug;			/* Activates debug level*/
66 67

	/* Video standard vars */
68 69
	v4l2_std_id tvnorms;		/* Supported tv norms */
	v4l2_std_id current_norm;	/* Current tvnorm */
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85

	/* callbacks */
	void (*release)(struct video_device *vfd);

	/* ioctl callbacks */

	/* VIDIOC_QUERYCAP handler */
	int (*vidioc_querycap)(struct file *file, void *fh, struct v4l2_capability *cap);

	/* Priority handling */
	int (*vidioc_g_priority)   (struct file *file, void *fh,
				    enum v4l2_priority *p);
	int (*vidioc_s_priority)   (struct file *file, void *fh,
				    enum v4l2_priority p);

	/* VIDIOC_ENUM_FMT handlers */
86
	int (*vidioc_enum_fmt_vid_cap)     (struct file *file, void *fh,
87
					    struct v4l2_fmtdesc *f);
88
	int (*vidioc_enum_fmt_vid_overlay) (struct file *file, void *fh,
89
					    struct v4l2_fmtdesc *f);
90
	int (*vidioc_enum_fmt_vid_out)     (struct file *file, void *fh,
91
					    struct v4l2_fmtdesc *f);
92 93 94
#if 1
	/* deprecated, will be removed in 2.6.28 */
	int (*vidioc_enum_fmt_vbi_cap)     (struct file *file, void *fh,
95
					    struct v4l2_fmtdesc *f);
96
#endif
97 98 99 100
	int (*vidioc_enum_fmt_type_private)(struct file *file, void *fh,
					    struct v4l2_fmtdesc *f);

	/* VIDIOC_G_FMT handlers */
101
	int (*vidioc_g_fmt_vid_cap)    (struct file *file, void *fh,
102
					struct v4l2_format *f);
103
	int (*vidioc_g_fmt_vid_overlay)(struct file *file, void *fh,
104
					struct v4l2_format *f);
105
	int (*vidioc_g_fmt_vid_out)    (struct file *file, void *fh,
106
					struct v4l2_format *f);
107
	int (*vidioc_g_fmt_vid_out_overlay)(struct file *file, void *fh,
108
					struct v4l2_format *f);
109
	int (*vidioc_g_fmt_vbi_cap)    (struct file *file, void *fh,
110
					struct v4l2_format *f);
111
	int (*vidioc_g_fmt_vbi_out)    (struct file *file, void *fh,
112
					struct v4l2_format *f);
113
	int (*vidioc_g_fmt_sliced_vbi_cap)(struct file *file, void *fh,
114
					struct v4l2_format *f);
115
	int (*vidioc_g_fmt_sliced_vbi_out)(struct file *file, void *fh,
116
					struct v4l2_format *f);
117 118 119 120
	int (*vidioc_g_fmt_type_private)(struct file *file, void *fh,
					struct v4l2_format *f);

	/* VIDIOC_S_FMT handlers */
121
	int (*vidioc_s_fmt_vid_cap)    (struct file *file, void *fh,
122
					struct v4l2_format *f);
123
	int (*vidioc_s_fmt_vid_overlay)(struct file *file, void *fh,
124
					struct v4l2_format *f);
125
	int (*vidioc_s_fmt_vid_out)    (struct file *file, void *fh,
126
					struct v4l2_format *f);
127
	int (*vidioc_s_fmt_vid_out_overlay)(struct file *file, void *fh,
128
					struct v4l2_format *f);
129
	int (*vidioc_s_fmt_vbi_cap)    (struct file *file, void *fh,
130
					struct v4l2_format *f);
131
	int (*vidioc_s_fmt_vbi_out)    (struct file *file, void *fh,
132
					struct v4l2_format *f);
133
	int (*vidioc_s_fmt_sliced_vbi_cap)(struct file *file, void *fh,
134
					struct v4l2_format *f);
135
	int (*vidioc_s_fmt_sliced_vbi_out)(struct file *file, void *fh,
136
					struct v4l2_format *f);
137 138 139 140
	int (*vidioc_s_fmt_type_private)(struct file *file, void *fh,
					struct v4l2_format *f);

	/* VIDIOC_TRY_FMT handlers */
141
	int (*vidioc_try_fmt_vid_cap)    (struct file *file, void *fh,
142
					  struct v4l2_format *f);
143
	int (*vidioc_try_fmt_vid_overlay)(struct file *file, void *fh,
144
					  struct v4l2_format *f);
145
	int (*vidioc_try_fmt_vid_out)    (struct file *file, void *fh,
146
					  struct v4l2_format *f);
147
	int (*vidioc_try_fmt_vid_out_overlay)(struct file *file, void *fh,
148
					  struct v4l2_format *f);
149
	int (*vidioc_try_fmt_vbi_cap)    (struct file *file, void *fh,
150
					  struct v4l2_format *f);
151
	int (*vidioc_try_fmt_vbi_out)    (struct file *file, void *fh,
152
					  struct v4l2_format *f);
153
	int (*vidioc_try_fmt_sliced_vbi_cap)(struct file *file, void *fh,
154
					  struct v4l2_format *f);
155
	int (*vidioc_try_fmt_sliced_vbi_out)(struct file *file, void *fh,
156
					  struct v4l2_format *f);
157 158 159 160 161 162 163 164 165 166 167
	int (*vidioc_try_fmt_type_private)(struct file *file, void *fh,
					  struct v4l2_format *f);

	/* Buffer handlers */
	int (*vidioc_reqbufs) (struct file *file, void *fh, struct v4l2_requestbuffers *b);
	int (*vidioc_querybuf)(struct file *file, void *fh, struct v4l2_buffer *b);
	int (*vidioc_qbuf)    (struct file *file, void *fh, struct v4l2_buffer *b);
	int (*vidioc_dqbuf)   (struct file *file, void *fh, struct v4l2_buffer *b);


	int (*vidioc_overlay) (struct file *file, void *fh, unsigned int i);
168
#ifdef CONFIG_VIDEO_V4L1_COMPAT
169 170 171 172 173 174 175 176 177 178 179 180 181
			/* buffer type is struct vidio_mbuf * */
	int (*vidiocgmbuf)  (struct file *file, void *fh, struct video_mbuf *p);
#endif
	int (*vidioc_g_fbuf)   (struct file *file, void *fh,
				struct v4l2_framebuffer *a);
	int (*vidioc_s_fbuf)   (struct file *file, void *fh,
				struct v4l2_framebuffer *a);

		/* Stream on/off */
	int (*vidioc_streamon) (struct file *file, void *fh, enum v4l2_buf_type i);
	int (*vidioc_streamoff)(struct file *file, void *fh, enum v4l2_buf_type i);

		/* Standard handling
182
			ENUMSTD is handled by videodev.c
183
		 */
184
	int (*vidioc_g_std) (struct file *file, void *fh, v4l2_std_id *norm);
185
	int (*vidioc_s_std) (struct file *file, void *fh, v4l2_std_id *norm);
186 187 188 189 190 191 192 193 194
	int (*vidioc_querystd) (struct file *file, void *fh, v4l2_std_id *a);

		/* Input handling */
	int (*vidioc_enum_input)(struct file *file, void *fh,
				 struct v4l2_input *inp);
	int (*vidioc_g_input)   (struct file *file, void *fh, unsigned int *i);
	int (*vidioc_s_input)   (struct file *file, void *fh, unsigned int i);

		/* Output handling */
195
	int (*vidioc_enum_output) (struct file *file, void *fh,
196 197 198 199 200 201 202 203 204 205 206
				  struct v4l2_output *a);
	int (*vidioc_g_output)   (struct file *file, void *fh, unsigned int *i);
	int (*vidioc_s_output)   (struct file *file, void *fh, unsigned int i);

		/* Control handling */
	int (*vidioc_queryctrl)        (struct file *file, void *fh,
					struct v4l2_queryctrl *a);
	int (*vidioc_g_ctrl)           (struct file *file, void *fh,
					struct v4l2_control *a);
	int (*vidioc_s_ctrl)           (struct file *file, void *fh,
					struct v4l2_control *a);
207 208 209 210 211 212
	int (*vidioc_g_ext_ctrls)      (struct file *file, void *fh,
					struct v4l2_ext_controls *a);
	int (*vidioc_s_ext_ctrls)      (struct file *file, void *fh,
					struct v4l2_ext_controls *a);
	int (*vidioc_try_ext_ctrls)    (struct file *file, void *fh,
					struct v4l2_ext_controls *a);
213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246
	int (*vidioc_querymenu)        (struct file *file, void *fh,
					struct v4l2_querymenu *a);

	/* Audio ioctls */
	int (*vidioc_enumaudio)        (struct file *file, void *fh,
					struct v4l2_audio *a);
	int (*vidioc_g_audio)          (struct file *file, void *fh,
					struct v4l2_audio *a);
	int (*vidioc_s_audio)          (struct file *file, void *fh,
					struct v4l2_audio *a);

	/* Audio out ioctls */
	int (*vidioc_enumaudout)       (struct file *file, void *fh,
					struct v4l2_audioout *a);
	int (*vidioc_g_audout)         (struct file *file, void *fh,
					struct v4l2_audioout *a);
	int (*vidioc_s_audout)         (struct file *file, void *fh,
					struct v4l2_audioout *a);
	int (*vidioc_g_modulator)      (struct file *file, void *fh,
					struct v4l2_modulator *a);
	int (*vidioc_s_modulator)      (struct file *file, void *fh,
					struct v4l2_modulator *a);
	/* Crop ioctls */
	int (*vidioc_cropcap)          (struct file *file, void *fh,
					struct v4l2_cropcap *a);
	int (*vidioc_g_crop)           (struct file *file, void *fh,
					struct v4l2_crop *a);
	int (*vidioc_s_crop)           (struct file *file, void *fh,
					struct v4l2_crop *a);
	/* Compression ioctls */
	int (*vidioc_g_jpegcomp)       (struct file *file, void *fh,
					struct v4l2_jpegcompression *a);
	int (*vidioc_s_jpegcomp)       (struct file *file, void *fh,
					struct v4l2_jpegcompression *a);
247 248
	int (*vidioc_g_enc_index)      (struct file *file, void *fh,
					struct v4l2_enc_idx *a);
249 250 251 252
	int (*vidioc_encoder_cmd)      (struct file *file, void *fh,
					struct v4l2_encoder_cmd *a);
	int (*vidioc_try_encoder_cmd)  (struct file *file, void *fh,
					struct v4l2_encoder_cmd *a);
253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276

	/* Stream type-dependent parameter ioctls */
	int (*vidioc_g_parm)           (struct file *file, void *fh,
					struct v4l2_streamparm *a);
	int (*vidioc_s_parm)           (struct file *file, void *fh,
					struct v4l2_streamparm *a);

	/* Tuner ioctls */
	int (*vidioc_g_tuner)          (struct file *file, void *fh,
					struct v4l2_tuner *a);
	int (*vidioc_s_tuner)          (struct file *file, void *fh,
					struct v4l2_tuner *a);
	int (*vidioc_g_frequency)      (struct file *file, void *fh,
					struct v4l2_frequency *a);
	int (*vidioc_s_frequency)      (struct file *file, void *fh,
					struct v4l2_frequency *a);

	/* Sliced VBI cap */
	int (*vidioc_g_sliced_vbi_cap) (struct file *file, void *fh,
					struct v4l2_sliced_vbi_cap *a);

	/* Log status ioctl */
	int (*vidioc_log_status)       (struct file *file, void *fh);

277 278
	int (*vidioc_s_hw_freq_seek)   (struct file *file, void *fh,
					struct v4l2_hw_freq_seek *a);
279

280 281 282 283 284 285 286
	/* Debugging ioctls */
#ifdef CONFIG_VIDEO_ADV_DEBUG
	int (*vidioc_g_register)       (struct file *file, void *fh,
					struct v4l2_register *reg);
	int (*vidioc_s_register)       (struct file *file, void *fh,
					struct v4l2_register *reg);
#endif
287 288
	int (*vidioc_g_chip_ident)     (struct file *file, void *fh,
					struct v4l2_chip_ident *chip);
289

290 291 292 293
	/* For other private ioctls */
	int (*vidioc_default)	       (struct file *file, void *fh,
					int cmd, void *arg);

294

295
#ifdef OBSOLETE_OWNER /* to be removed soon */
296 297 298 299 300 301 302 303 304 305 306 307 308 309
/* obsolete -- fops->owner is used instead */
struct module *owner;
/* dev->driver_data will be used instead some day.
	* Use the video_{get|set}_drvdata() helper functions,
	* so the switch over will be transparent for you.
	* Or use {pci|usb}_{get|set}_drvdata() directly. */
void *priv;
#endif

	/* for videodev.c intenal usage -- please don't touch */
	int users;                     /* video_exclusive_{open|close} ... */
	struct mutex lock;             /* ... helper function uses these   */
};

310
/* Class-dev to video-device */
311
#define to_video_device(cd) container_of(cd, struct video_device, dev)
312

313 314
/* Version 2 functions */
extern int video_register_device(struct video_device *vfd, int type, int nr);
315 316
int video_register_device_index(struct video_device *vfd, int type, int nr,
					int index);
317 318 319 320 321 322 323
void video_unregister_device(struct video_device *);

/* helper functions to alloc / release struct video_device, the
   later can be used for video_device->release() */
struct video_device *video_device_alloc(void);
void video_device_release(struct video_device *vfd);

324
#ifdef CONFIG_VIDEO_V4L1_COMPAT
325 326
#include <linux/mm.h>

A
Andrew Morton 已提交
327
static inline int __must_check
328
video_device_create_file(struct video_device *vfd,
329
			 struct device_attribute *attr)
330
{
331
	int ret = device_create_file(&vfd->dev, attr);
332
	if (ret < 0)
333
		printk(KERN_WARNING "%s error: %d\n", __func__, ret);
334
	return ret;
335 336 337
}
static inline void
video_device_remove_file(struct video_device *vfd,
338
			 struct device_attribute *attr)
339
{
340
	device_remove_file(&vfd->dev, attr);
341 342
}

343 344
#endif /* CONFIG_VIDEO_V4L1_COMPAT */

345
#ifdef OBSOLETE_OWNER /* to be removed soon */
346 347 348 349 350 351 352 353 354 355
/* helper functions to access driver private data. */
static inline void *video_get_drvdata(struct video_device *dev)
{
	return dev->priv;
}

static inline void video_set_drvdata(struct video_device *dev, void *data)
{
	dev->priv = data;
}
356

357 358
#endif

359 360 361
#ifdef OBSOLETE_DEVDATA /* to be removed soon */
/* Obsolete stuff - Still needed for radio devices and obsolete drivers */
extern struct video_device* video_devdata(struct file*);
362 363
extern int video_exclusive_open(struct inode *inode, struct file *file);
extern int video_exclusive_release(struct inode *inode, struct file *file);
364
#endif
365 366

#endif /* _V4L2_DEV_H */