提交 4839c58f 编写于 作者: M Mauro Carvalho Chehab

media: v4l2-dev: convert VFL_TYPE_* into an enum

Using enums makes easier to document, as it can use kernel-doc
markups. It also allows cross-referencing, with increases the
kAPI readability.

Please notice that now cx88_querycap() has to have a default for
the VFL type, as there are more types than supported by the driver.
Acked-By: NMike Isely <isely@pobox.com>
Acked-by: NHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
上级 2120961f
...@@ -196,11 +196,18 @@ device. ...@@ -196,11 +196,18 @@ device.
Which device is registered depends on the type argument. The following Which device is registered depends on the type argument. The following
types exist: types exist:
- ``VFL_TYPE_GRABBER``: ``/dev/videoX`` for video input/output devices ========================== ==================== ==============================
- ``VFL_TYPE_VBI``: ``/dev/vbiX`` for vertical blank data (i.e. closed captions, teletext) :c:type:`vfl_devnode_type` Device name Usage
- ``VFL_TYPE_RADIO``: ``/dev/radioX`` for radio tuners ========================== ==================== ==============================
- ``VFL_TYPE_SDR``: ``/dev/swradioX`` for Software Defined Radio tuners ``VFL_TYPE_GRABBER`` ``/dev/videoX`` for video input/output devices
- ``VFL_TYPE_TOUCH``: ``/dev/v4l-touchX`` for touch sensors ``VFL_TYPE_VBI`` ``/dev/vbiX`` for vertical blank data (i.e.
closed captions, teletext)
``VFL_TYPE_RADIO`` ``/dev/radioX`` for radio tuners
``VFL_TYPE_SUBDEV`` ``/dev/v4l-subdevX`` for V4L2 subdevices
``VFL_TYPE_SDR`` ``/dev/swradioX`` for Software Defined Radio
(SDR) tuners
``VFL_TYPE_TOUCH`` ``/dev/v4l-touchX`` for touch sensors
========================== ==================== ==============================
The last argument gives you a certain amount of control over the device The last argument gives you a certain amount of control over the device
device node number used (i.e. the X in ``videoX``). Normally you will pass -1 device node number used (i.e. the X in ``videoX``). Normally you will pass -1
......
...@@ -805,8 +805,7 @@ static int vidioc_querycap(struct file *file, void *priv, ...@@ -805,8 +805,7 @@ static int vidioc_querycap(struct file *file, void *priv,
strcpy(cap->driver, "cx88_blackbird"); strcpy(cap->driver, "cx88_blackbird");
sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci)); sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci));
cx88_querycap(file, core, cap); return cx88_querycap(file, core, cap);
return 0;
} }
static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv, static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv,
......
...@@ -806,8 +806,8 @@ static int vidioc_s_fmt_vid_cap(struct file *file, void *priv, ...@@ -806,8 +806,8 @@ static int vidioc_s_fmt_vid_cap(struct file *file, void *priv,
return 0; return 0;
} }
void cx88_querycap(struct file *file, struct cx88_core *core, int cx88_querycap(struct file *file, struct cx88_core *core,
struct v4l2_capability *cap) struct v4l2_capability *cap)
{ {
struct video_device *vdev = video_devdata(file); struct video_device *vdev = video_devdata(file);
...@@ -825,11 +825,14 @@ void cx88_querycap(struct file *file, struct cx88_core *core, ...@@ -825,11 +825,14 @@ void cx88_querycap(struct file *file, struct cx88_core *core,
case VFL_TYPE_VBI: case VFL_TYPE_VBI:
cap->device_caps |= V4L2_CAP_VBI_CAPTURE; cap->device_caps |= V4L2_CAP_VBI_CAPTURE;
break; break;
default:
return -EINVAL;
} }
cap->capabilities = cap->device_caps | V4L2_CAP_VIDEO_CAPTURE | cap->capabilities = cap->device_caps | V4L2_CAP_VIDEO_CAPTURE |
V4L2_CAP_VBI_CAPTURE | V4L2_CAP_DEVICE_CAPS; V4L2_CAP_VBI_CAPTURE | V4L2_CAP_DEVICE_CAPS;
if (core->board.radio.type == CX88_RADIO) if (core->board.radio.type == CX88_RADIO)
cap->capabilities |= V4L2_CAP_RADIO; cap->capabilities |= V4L2_CAP_RADIO;
return 0;
} }
EXPORT_SYMBOL(cx88_querycap); EXPORT_SYMBOL(cx88_querycap);
...@@ -841,8 +844,7 @@ static int vidioc_querycap(struct file *file, void *priv, ...@@ -841,8 +844,7 @@ static int vidioc_querycap(struct file *file, void *priv,
strcpy(cap->driver, "cx8800"); strcpy(cap->driver, "cx8800");
sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci)); sprintf(cap->bus_info, "PCI:%s", pci_name(dev->pci));
cx88_querycap(file, core, cap); return cx88_querycap(file, core, cap);
return 0;
} }
static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv, static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv,
......
...@@ -734,7 +734,7 @@ int cx8802_start_dma(struct cx8802_dev *dev, ...@@ -734,7 +734,7 @@ int cx8802_start_dma(struct cx8802_dev *dev,
int cx88_enum_input(struct cx88_core *core, struct v4l2_input *i); int cx88_enum_input(struct cx88_core *core, struct v4l2_input *i);
int cx88_set_freq(struct cx88_core *core, const struct v4l2_frequency *f); int cx88_set_freq(struct cx88_core *core, const struct v4l2_frequency *f);
int cx88_video_mux(struct cx88_core *core, unsigned int input); int cx88_video_mux(struct cx88_core *core, unsigned int input);
void cx88_querycap(struct file *file, struct cx88_core *core, int cx88_querycap(struct file *file, struct cx88_core *core,
struct v4l2_capability *cap); struct v4l2_capability *cap);
#endif #endif
...@@ -1531,6 +1531,8 @@ int saa7134_querycap(struct file *file, void *priv, ...@@ -1531,6 +1531,8 @@ int saa7134_querycap(struct file *file, void *priv,
case VFL_TYPE_VBI: case VFL_TYPE_VBI:
cap->device_caps |= vbi_caps; cap->device_caps |= vbi_caps;
break; break;
default:
return -EINVAL;
} }
cap->capabilities = radio_caps | video_caps | vbi_caps | cap->capabilities = radio_caps | video_caps | vbi_caps |
cap->device_caps | V4L2_CAP_DEVICE_CAPS; cap->device_caps | V4L2_CAP_DEVICE_CAPS;
......
...@@ -1756,6 +1756,8 @@ static int cx231xx_v4l2_open(struct file *filp) ...@@ -1756,6 +1756,8 @@ static int cx231xx_v4l2_open(struct file *filp)
case VFL_TYPE_RADIO: case VFL_TYPE_RADIO:
radio = 1; radio = 1;
break; break;
default:
return -EINVAL;
} }
cx231xx_videodbg("open dev=%s type=%s users=%d\n", cx231xx_videodbg("open dev=%s type=%s users=%d\n",
......
...@@ -153,6 +153,8 @@ static int pvr2_querycap(struct file *file, void *priv, struct v4l2_capability * ...@@ -153,6 +153,8 @@ static int pvr2_querycap(struct file *file, void *priv, struct v4l2_capability *
case VFL_TYPE_RADIO: case VFL_TYPE_RADIO:
cap->device_caps = V4L2_CAP_RADIO; cap->device_caps = V4L2_CAP_RADIO;
break; break;
default:
return -EINVAL;
} }
cap->device_caps |= V4L2_CAP_TUNER | V4L2_CAP_READWRITE; cap->device_caps |= V4L2_CAP_TUNER | V4L2_CAP_READWRITE;
return 0; return 0;
......
...@@ -1313,6 +1313,8 @@ static int __tm6000_open(struct file *file) ...@@ -1313,6 +1313,8 @@ static int __tm6000_open(struct file *file)
case VFL_TYPE_RADIO: case VFL_TYPE_RADIO:
radio = 1; radio = 1;
break; break;
default:
return -EINVAL;
} }
/* If more than one user, mutex should be added */ /* If more than one user, mutex should be added */
......
...@@ -102,7 +102,7 @@ static DECLARE_BITMAP(devnode_nums[VFL_TYPE_MAX], VIDEO_NUM_DEVICES); ...@@ -102,7 +102,7 @@ static DECLARE_BITMAP(devnode_nums[VFL_TYPE_MAX], VIDEO_NUM_DEVICES);
#ifdef CONFIG_VIDEO_FIXED_MINOR_RANGES #ifdef CONFIG_VIDEO_FIXED_MINOR_RANGES
/* Return the bitmap corresponding to vfl_type. */ /* Return the bitmap corresponding to vfl_type. */
static inline unsigned long *devnode_bits(int vfl_type) static inline unsigned long *devnode_bits(enum vfl_devnode_type vfl_type)
{ {
/* Any types not assigned to fixed minor ranges must be mapped to /* Any types not assigned to fixed minor ranges must be mapped to
one single bitmap for the purposes of finding a free node number one single bitmap for the purposes of finding a free node number
...@@ -113,7 +113,7 @@ static inline unsigned long *devnode_bits(int vfl_type) ...@@ -113,7 +113,7 @@ static inline unsigned long *devnode_bits(int vfl_type)
} }
#else #else
/* Return the bitmap corresponding to vfl_type. */ /* Return the bitmap corresponding to vfl_type. */
static inline unsigned long *devnode_bits(int vfl_type) static inline unsigned long *devnode_bits(enum vfl_devnode_type vfl_type)
{ {
return devnode_nums[vfl_type]; return devnode_nums[vfl_type];
} }
...@@ -821,8 +821,10 @@ static int video_register_media_controller(struct video_device *vdev, int type) ...@@ -821,8 +821,10 @@ static int video_register_media_controller(struct video_device *vdev, int type)
return 0; return 0;
} }
int __video_register_device(struct video_device *vdev, int type, int nr, int __video_register_device(struct video_device *vdev,
int warn_if_nr_in_use, struct module *owner) enum vfl_devnode_type type,
int nr, int warn_if_nr_in_use,
struct module *owner)
{ {
int i = 0; int i = 0;
int ret; int ret;
......
...@@ -21,13 +21,25 @@ ...@@ -21,13 +21,25 @@
#define VIDEO_MAJOR 81 #define VIDEO_MAJOR 81
#define VFL_TYPE_GRABBER 0 /**
#define VFL_TYPE_VBI 1 * enum vfl_devnode_type - type of V4L2 device node
#define VFL_TYPE_RADIO 2 *
#define VFL_TYPE_SUBDEV 3 * @VFL_TYPE_GRABBER: for video input/output devices
#define VFL_TYPE_SDR 4 * @VFL_TYPE_VBI: for vertical blank data (i.e. closed captions, teletext)
#define VFL_TYPE_TOUCH 5 * @VFL_TYPE_RADIO: for radio tuners
#define VFL_TYPE_MAX 6 * @VFL_TYPE_SUBDEV: for V4L2 subdevices
* @VFL_TYPE_SDR: for Software Defined Radio tuners
* @VFL_TYPE_TOUCH: for touch sensors
*/
enum vfl_devnode_type {
VFL_TYPE_GRABBER = 0,
VFL_TYPE_VBI = 1,
VFL_TYPE_RADIO = 2,
VFL_TYPE_SUBDEV = 3,
VFL_TYPE_SDR = 4,
VFL_TYPE_TOUCH = 5,
};
#define VFL_TYPE_MAX VFL_TYPE_TOUCH
/* Is this a receiver, transmitter or mem-to-mem? */ /* Is this a receiver, transmitter or mem-to-mem? */
/* Ignored for VFL_TYPE_SUBDEV. */ /* Ignored for VFL_TYPE_SUBDEV. */
...@@ -189,7 +201,7 @@ struct v4l2_file_operations { ...@@ -189,7 +201,7 @@ struct v4l2_file_operations {
* @prio: pointer to &struct v4l2_prio_state with device's Priority state. * @prio: pointer to &struct v4l2_prio_state with device's Priority state.
* If NULL, then v4l2_dev->prio will be used. * If NULL, then v4l2_dev->prio will be used.
* @name: video device name * @name: video device name
* @vfl_type: V4L device type * @vfl_type: V4L device type, as defined by &enum vfl_devnode_type
* @vfl_dir: V4L receiver, transmitter or m2m * @vfl_dir: V4L receiver, transmitter or m2m
* @minor: device node 'minor'. It is set to -1 if the registration failed * @minor: device node 'minor'. It is set to -1 if the registration failed
* @num: number of the video device node * @num: number of the video device node
...@@ -237,7 +249,7 @@ struct video_device ...@@ -237,7 +249,7 @@ struct video_device
/* device info */ /* device info */
char name[32]; char name[32];
int vfl_type; enum vfl_devnode_type vfl_type;
int vfl_dir; int vfl_dir;
int minor; int minor;
u16 num; u16 num;
...@@ -282,7 +294,7 @@ struct video_device ...@@ -282,7 +294,7 @@ struct video_device
* __video_register_device - register video4linux devices * __video_register_device - register video4linux devices
* *
* @vdev: struct video_device to register * @vdev: struct video_device to register
* @type: type of device to register * @type: type of device to register, as defined by &enum vfl_devnode_type
* @nr: which device node number is desired: * @nr: which device node number is desired:
* (0 == /dev/video0, 1 == /dev/video1, ..., -1 == first free) * (0 == /dev/video0, 1 == /dev/video1, ..., -1 == first free)
* @warn_if_nr_in_use: warn if the desired device node number * @warn_if_nr_in_use: warn if the desired device node number
...@@ -301,29 +313,22 @@ struct video_device ...@@ -301,29 +313,22 @@ struct video_device
* *
* Returns 0 on success. * Returns 0 on success.
* *
* Valid values for @type are:
*
* - %VFL_TYPE_GRABBER - A frame grabber
* - %VFL_TYPE_VBI - Vertical blank data (undecoded)
* - %VFL_TYPE_RADIO - A radio card
* - %VFL_TYPE_SUBDEV - A subdevice
* - %VFL_TYPE_SDR - Software Defined Radio
* - %VFL_TYPE_TOUCH - A touch sensor
*
* .. note:: * .. note::
* *
* This function is meant to be used only inside the V4L2 core. * This function is meant to be used only inside the V4L2 core.
* Drivers should use video_register_device() or * Drivers should use video_register_device() or
* video_register_device_no_warn(). * video_register_device_no_warn().
*/ */
int __must_check __video_register_device(struct video_device *vdev, int type, int __must_check __video_register_device(struct video_device *vdev,
int nr, int warn_if_nr_in_use, struct module *owner); enum vfl_devnode_type type,
int nr, int warn_if_nr_in_use,
struct module *owner);
/** /**
* video_register_device - register video4linux devices * video_register_device - register video4linux devices
* *
* @vdev: struct video_device to register * @vdev: struct video_device to register
* @type: type of device to register * @type: type of device to register, as defined by &enum vfl_devnode_type
* @nr: which device node number is desired: * @nr: which device node number is desired:
* (0 == /dev/video0, 1 == /dev/video1, ..., -1 == first free) * (0 == /dev/video0, 1 == /dev/video1, ..., -1 == first free)
* *
...@@ -337,7 +342,8 @@ int __must_check __video_register_device(struct video_device *vdev, int type, ...@@ -337,7 +342,8 @@ int __must_check __video_register_device(struct video_device *vdev, int type,
* you video_device_release() should be called on failure. * you video_device_release() should be called on failure.
*/ */
static inline int __must_check video_register_device(struct video_device *vdev, static inline int __must_check video_register_device(struct video_device *vdev,
int type, int nr) enum vfl_devnode_type type,
int nr)
{ {
return __video_register_device(vdev, type, nr, 1, vdev->fops->owner); return __video_register_device(vdev, type, nr, 1, vdev->fops->owner);
} }
...@@ -346,7 +352,7 @@ static inline int __must_check video_register_device(struct video_device *vdev, ...@@ -346,7 +352,7 @@ static inline int __must_check video_register_device(struct video_device *vdev,
* video_register_device_no_warn - register video4linux devices * video_register_device_no_warn - register video4linux devices
* *
* @vdev: struct video_device to register * @vdev: struct video_device to register
* @type: type of device to register * @type: type of device to register, as defined by &enum vfl_devnode_type
* @nr: which device node number is desired: * @nr: which device node number is desired:
* (0 == /dev/video0, 1 == /dev/video1, ..., -1 == first free) * (0 == /dev/video0, 1 == /dev/video1, ..., -1 == first free)
* *
...@@ -362,8 +368,9 @@ static inline int __must_check video_register_device(struct video_device *vdev, ...@@ -362,8 +368,9 @@ static inline int __must_check video_register_device(struct video_device *vdev,
* is responsible for freeing any data. Usually that means that * is responsible for freeing any data. Usually that means that
* you video_device_release() should be called on failure. * you video_device_release() should be called on failure.
*/ */
static inline int __must_check video_register_device_no_warn( static inline int __must_check
struct video_device *vdev, int type, int nr) video_register_device_no_warn(struct video_device *vdev,
enum vfl_devnode_type type, int nr)
{ {
return __video_register_device(vdev, type, nr, 0, vdev->fops->owner); return __video_register_device(vdev, type, nr, 0, vdev->fops->owner);
} }
......
...@@ -93,6 +93,13 @@ struct v4l2_mbus_config { ...@@ -93,6 +93,13 @@ struct v4l2_mbus_config {
unsigned int flags; unsigned int flags;
}; };
/**
* v4l2_fill_pix_format - Ancillary routine that fills a &struct
* v4l2_pix_format fields from a &struct v4l2_mbus_framefmt.
*
* @pix_fmt: pointer to &struct v4l2_pix_format to be filled
* @mbus_fmt: pointer to &struct v4l2_mbus_framefmt to be used as model
*/
static inline void v4l2_fill_pix_format(struct v4l2_pix_format *pix_fmt, static inline void v4l2_fill_pix_format(struct v4l2_pix_format *pix_fmt,
const struct v4l2_mbus_framefmt *mbus_fmt) const struct v4l2_mbus_framefmt *mbus_fmt)
{ {
...@@ -105,6 +112,15 @@ static inline void v4l2_fill_pix_format(struct v4l2_pix_format *pix_fmt, ...@@ -105,6 +112,15 @@ static inline void v4l2_fill_pix_format(struct v4l2_pix_format *pix_fmt,
pix_fmt->xfer_func = mbus_fmt->xfer_func; pix_fmt->xfer_func = mbus_fmt->xfer_func;
} }
/**
* v4l2_fill_pix_format - Ancillary routine that fills a &struct
* v4l2_mbus_framefmt from a &struct v4l2_pix_format and a
* data format code.
*
* @mbus_fmt: pointer to &struct v4l2_mbus_framefmt to be filled
* @pix_fmt: pointer to &struct v4l2_pix_format to be used as model
* @code: data format code (from &enum v4l2_mbus_pixelcode)
*/
static inline void v4l2_fill_mbus_format(struct v4l2_mbus_framefmt *mbus_fmt, static inline void v4l2_fill_mbus_format(struct v4l2_mbus_framefmt *mbus_fmt,
const struct v4l2_pix_format *pix_fmt, const struct v4l2_pix_format *pix_fmt,
u32 code) u32 code)
...@@ -119,6 +135,13 @@ static inline void v4l2_fill_mbus_format(struct v4l2_mbus_framefmt *mbus_fmt, ...@@ -119,6 +135,13 @@ static inline void v4l2_fill_mbus_format(struct v4l2_mbus_framefmt *mbus_fmt,
mbus_fmt->code = code; mbus_fmt->code = code;
} }
/**
* v4l2_fill_pix_format - Ancillary routine that fills a &struct
* v4l2_pix_format_mplane fields from a media bus structure.
*
* @pix_mp_fmt: pointer to &struct v4l2_pix_format_mplane to be filled
* @mbus_fmt: pointer to &struct v4l2_mbus_framefmt to be used as model
*/
static inline void v4l2_fill_pix_format_mplane( static inline void v4l2_fill_pix_format_mplane(
struct v4l2_pix_format_mplane *pix_mp_fmt, struct v4l2_pix_format_mplane *pix_mp_fmt,
const struct v4l2_mbus_framefmt *mbus_fmt) const struct v4l2_mbus_framefmt *mbus_fmt)
...@@ -132,6 +155,13 @@ static inline void v4l2_fill_pix_format_mplane( ...@@ -132,6 +155,13 @@ static inline void v4l2_fill_pix_format_mplane(
pix_mp_fmt->xfer_func = mbus_fmt->xfer_func; pix_mp_fmt->xfer_func = mbus_fmt->xfer_func;
} }
/**
* v4l2_fill_pix_format - Ancillary routine that fills a &struct
* v4l2_mbus_framefmt from a &struct v4l2_pix_format_mplane.
*
* @mbus_fmt: pointer to &struct v4l2_mbus_framefmt to be filled
* @pix_mp_fmt: pointer to &struct v4l2_pix_format_mplane to be used as model
*/
static inline void v4l2_fill_mbus_format_mplane( static inline void v4l2_fill_mbus_format_mplane(
struct v4l2_mbus_framefmt *mbus_fmt, struct v4l2_mbus_framefmt *mbus_fmt,
const struct v4l2_pix_format_mplane *pix_mp_fmt) const struct v4l2_pix_format_mplane *pix_mp_fmt)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册