提交 ceb99e1b 编写于 作者: D David Ellingsworth 提交者: Mauro Carvalho Chehab

V4L/DVB (13064): radio-mr800: simplify access to amradio_device

Simplify access to amradio_device.
Signed-off-by: NDavid Ellingsworth <david@identd.dyndns.org>
Acked-by: NAlexey Klimov <klimov.linux@gmail.com>
Signed-off-by: NDouglas Schilling Landgraf <dougsland@redhat.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 d1939e4c
...@@ -141,6 +141,8 @@ struct amradio_device { ...@@ -141,6 +141,8 @@ struct amradio_device {
int muted; int muted;
}; };
#define vdev_to_amradio(r) container_of(r, struct amradio_device, videodev)
/* USB Device ID List */ /* USB Device ID List */
static struct usb_device_id usb_amradio_device_table[] = { static struct usb_device_id usb_amradio_device_table[] = {
{USB_DEVICE_AND_INTERFACE_INFO(USB_AMRADIO_VENDOR, USB_AMRADIO_PRODUCT, {USB_DEVICE_AND_INTERFACE_INFO(USB_AMRADIO_VENDOR, USB_AMRADIO_PRODUCT,
...@@ -280,7 +282,7 @@ static void usb_amradio_disconnect(struct usb_interface *intf) ...@@ -280,7 +282,7 @@ static void usb_amradio_disconnect(struct usb_interface *intf)
static int vidioc_querycap(struct file *file, void *priv, static int vidioc_querycap(struct file *file, void *priv,
struct v4l2_capability *v) struct v4l2_capability *v)
{ {
struct amradio_device *radio = video_drvdata(file); struct amradio_device *radio = file->private_data;
strlcpy(v->driver, "radio-mr800", sizeof(v->driver)); strlcpy(v->driver, "radio-mr800", sizeof(v->driver));
strlcpy(v->card, "AverMedia MR 800 USB FM Radio", sizeof(v->card)); strlcpy(v->card, "AverMedia MR 800 USB FM Radio", sizeof(v->card));
...@@ -294,7 +296,7 @@ static int vidioc_querycap(struct file *file, void *priv, ...@@ -294,7 +296,7 @@ static int vidioc_querycap(struct file *file, void *priv,
static int vidioc_g_tuner(struct file *file, void *priv, static int vidioc_g_tuner(struct file *file, void *priv,
struct v4l2_tuner *v) struct v4l2_tuner *v)
{ {
struct amradio_device *radio = video_get_drvdata(video_devdata(file)); struct amradio_device *radio = file->private_data;
int retval; int retval;
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
...@@ -345,7 +347,7 @@ static int vidioc_g_tuner(struct file *file, void *priv, ...@@ -345,7 +347,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
static int vidioc_s_tuner(struct file *file, void *priv, static int vidioc_s_tuner(struct file *file, void *priv,
struct v4l2_tuner *v) struct v4l2_tuner *v)
{ {
struct amradio_device *radio = video_get_drvdata(video_devdata(file)); struct amradio_device *radio = file->private_data;
int retval; int retval;
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
...@@ -388,7 +390,7 @@ static int vidioc_s_tuner(struct file *file, void *priv, ...@@ -388,7 +390,7 @@ static int vidioc_s_tuner(struct file *file, void *priv,
static int vidioc_s_frequency(struct file *file, void *priv, static int vidioc_s_frequency(struct file *file, void *priv,
struct v4l2_frequency *f) struct v4l2_frequency *f)
{ {
struct amradio_device *radio = video_get_drvdata(video_devdata(file)); struct amradio_device *radio = file->private_data;
int retval; int retval;
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
...@@ -415,7 +417,7 @@ static int vidioc_s_frequency(struct file *file, void *priv, ...@@ -415,7 +417,7 @@ static int vidioc_s_frequency(struct file *file, void *priv,
static int vidioc_g_frequency(struct file *file, void *priv, static int vidioc_g_frequency(struct file *file, void *priv,
struct v4l2_frequency *f) struct v4l2_frequency *f)
{ {
struct amradio_device *radio = video_get_drvdata(video_devdata(file)); struct amradio_device *radio = file->private_data;
int retval = 0; int retval = 0;
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
...@@ -450,7 +452,7 @@ static int vidioc_queryctrl(struct file *file, void *priv, ...@@ -450,7 +452,7 @@ static int vidioc_queryctrl(struct file *file, void *priv,
static int vidioc_g_ctrl(struct file *file, void *priv, static int vidioc_g_ctrl(struct file *file, void *priv,
struct v4l2_control *ctrl) struct v4l2_control *ctrl)
{ {
struct amradio_device *radio = video_get_drvdata(video_devdata(file)); struct amradio_device *radio = file->private_data;
int retval = -EINVAL; int retval = -EINVAL;
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
...@@ -477,7 +479,7 @@ static int vidioc_g_ctrl(struct file *file, void *priv, ...@@ -477,7 +479,7 @@ static int vidioc_g_ctrl(struct file *file, void *priv,
static int vidioc_s_ctrl(struct file *file, void *priv, static int vidioc_s_ctrl(struct file *file, void *priv,
struct v4l2_control *ctrl) struct v4l2_control *ctrl)
{ {
struct amradio_device *radio = video_get_drvdata(video_devdata(file)); struct amradio_device *radio = file->private_data;
int retval = -EINVAL; int retval = -EINVAL;
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
...@@ -550,7 +552,7 @@ static int vidioc_s_input(struct file *filp, void *priv, unsigned int i) ...@@ -550,7 +552,7 @@ static int vidioc_s_input(struct file *filp, void *priv, unsigned int i)
/* open device - amradio_start() and amradio_setfreq() */ /* open device - amradio_start() and amradio_setfreq() */
static int usb_amradio_open(struct file *file) static int usb_amradio_open(struct file *file)
{ {
struct amradio_device *radio = video_get_drvdata(video_devdata(file)); struct amradio_device *radio = vdev_to_amradio(video_devdata(file));
int retval = 0; int retval = 0;
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
...@@ -560,6 +562,7 @@ static int usb_amradio_open(struct file *file) ...@@ -560,6 +562,7 @@ static int usb_amradio_open(struct file *file)
goto unlock; goto unlock;
} }
file->private_data = radio;
radio->users = 1; radio->users = 1;
radio->muted = 1; radio->muted = 1;
...@@ -589,7 +592,7 @@ static int usb_amradio_open(struct file *file) ...@@ -589,7 +592,7 @@ static int usb_amradio_open(struct file *file)
/*close device */ /*close device */
static int usb_amradio_close(struct file *file) static int usb_amradio_close(struct file *file)
{ {
struct amradio_device *radio = video_get_drvdata(video_devdata(file)); struct amradio_device *radio = file->private_data;
int retval = 0; int retval = 0;
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
...@@ -674,7 +677,7 @@ static const struct v4l2_ioctl_ops usb_amradio_ioctl_ops = { ...@@ -674,7 +677,7 @@ static const struct v4l2_ioctl_ops usb_amradio_ioctl_ops = {
static void usb_amradio_video_device_release(struct video_device *videodev) static void usb_amradio_video_device_release(struct video_device *videodev)
{ {
struct amradio_device *radio = video_get_drvdata(videodev); struct amradio_device *radio = vdev_to_amradio(videodev);
v4l2_device_unregister(&radio->v4l2_dev); v4l2_device_unregister(&radio->v4l2_dev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册