v4l2-dev.h 3.3 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
#define OBSOLETE_DEVDATA 1 /* to be removed soon */
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36

#include <linux/poll.h>
#include <linux/fs.h>
#include <linux/device.h>
#include <linux/mutex.h>
#include <linux/compiler.h> /* need __user */
#include <linux/videodev2.h>

#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

37 38
struct v4l2_ioctl_callbacks;

39 40 41 42 43 44 45 46 47
/*
 * 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 */
48
	const struct file_operations *fops;
49

50
	/* sysfs */
51
	struct device dev;		/* v4l device */
52
	struct device *parent;		/* device parent */
53

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

62
	int debug;			/* Activates debug level*/
63 64

	/* Video standard vars */
65 66
	v4l2_std_id tvnorms;		/* Supported tv norms */
	v4l2_std_id current_norm;	/* Current tvnorm */
67 68 69 70 71

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

	/* ioctl callbacks */
72
	const struct v4l2_ioctl_ops *ioctl_ops;
73

74 75 76 77 78 79
#ifdef OBSOLETE_DEVDATA /* to be removed soon */
	/* 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;
80 81 82 83 84 85 86
#endif

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

87
/* Class-dev to video-device */
88
#define to_video_device(cd) container_of(cd, struct video_device, dev)
89

90 91
/* Version 2 functions */
extern int video_register_device(struct video_device *vfd, int type, int nr);
92 93
int video_register_device_index(struct video_device *vfd, int type, int nr,
					int index);
94 95 96 97 98 99 100
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);

101
#ifdef OBSOLETE_DEVDATA /* to be removed soon */
102 103 104 105 106 107 108 109 110 111
/* 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;
}
112 113 114

/* Obsolete stuff - Still needed for radio devices and obsolete drivers */
extern struct video_device* video_devdata(struct file*);
115 116
extern int video_exclusive_open(struct inode *inode, struct file *file);
extern int video_exclusive_release(struct inode *inode, struct file *file);
117
#endif
118 119

#endif /* _V4L2_DEV_H */