提交 361ae54f 编写于 作者: H Hans Verkuil 提交者: Mauro Carvalho Chehab

V4L/DVB: radio-mr800: remove BKL

Signed-off-by: NHans Verkuil <hverkuil@xs4all.nl>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 d5906dd6
...@@ -176,8 +176,6 @@ static int amradio_set_mute(struct amradio_device *radio, char argument) ...@@ -176,8 +176,6 @@ static int amradio_set_mute(struct amradio_device *radio, char argument)
int retval; int retval;
int size; int size;
BUG_ON(!mutex_is_locked(&radio->lock));
radio->buffer[0] = 0x00; radio->buffer[0] = 0x00;
radio->buffer[1] = 0x55; radio->buffer[1] = 0x55;
radio->buffer[2] = 0xaa; radio->buffer[2] = 0xaa;
...@@ -207,8 +205,6 @@ static int amradio_setfreq(struct amradio_device *radio, int freq) ...@@ -207,8 +205,6 @@ static int amradio_setfreq(struct amradio_device *radio, int freq)
int size; int size;
unsigned short freq_send = 0x10 + (freq >> 3) / 25; unsigned short freq_send = 0x10 + (freq >> 3) / 25;
BUG_ON(!mutex_is_locked(&radio->lock));
radio->buffer[0] = 0x00; radio->buffer[0] = 0x00;
radio->buffer[1] = 0x55; radio->buffer[1] = 0x55;
radio->buffer[2] = 0xaa; radio->buffer[2] = 0xaa;
...@@ -253,8 +249,6 @@ static int amradio_set_stereo(struct amradio_device *radio, char argument) ...@@ -253,8 +249,6 @@ static int amradio_set_stereo(struct amradio_device *radio, char argument)
int retval; int retval;
int size; int size;
BUG_ON(!mutex_is_locked(&radio->lock));
radio->buffer[0] = 0x00; radio->buffer[0] = 0x00;
radio->buffer[1] = 0x55; radio->buffer[1] = 0x55;
radio->buffer[2] = 0xaa; radio->buffer[2] = 0xaa;
...@@ -290,11 +284,9 @@ static void usb_amradio_disconnect(struct usb_interface *intf) ...@@ -290,11 +284,9 @@ static void usb_amradio_disconnect(struct usb_interface *intf)
struct amradio_device *radio = to_amradio_dev(usb_get_intfdata(intf)); struct amradio_device *radio = to_amradio_dev(usb_get_intfdata(intf));
mutex_lock(&radio->lock); mutex_lock(&radio->lock);
radio->usbdev = NULL;
mutex_unlock(&radio->lock);
v4l2_device_disconnect(&radio->v4l2_dev); v4l2_device_disconnect(&radio->v4l2_dev);
video_unregister_device(&radio->videodev); video_unregister_device(&radio->videodev);
mutex_unlock(&radio->lock);
} }
/* vidioc_querycap - query device capabilities */ /* vidioc_querycap - query device capabilities */
...@@ -503,28 +495,18 @@ static int usb_amradio_init(struct amradio_device *radio) ...@@ -503,28 +495,18 @@ static int usb_amradio_init(struct amradio_device *radio)
static int usb_amradio_open(struct file *file) static int usb_amradio_open(struct file *file)
{ {
struct amradio_device *radio = video_drvdata(file); struct amradio_device *radio = video_drvdata(file);
int retval = 0; int retval;
mutex_lock(&radio->lock);
if (!radio->usbdev) {
retval = -EIO;
goto unlock;
}
file->private_data = radio; file->private_data = radio;
retval = usb_autopm_get_interface(radio->intf); retval = usb_autopm_get_interface(radio->intf);
if (retval) if (retval)
goto unlock; return retval;
if (unlikely(!radio->initialized)) { if (unlikely(!radio->initialized)) {
retval = usb_amradio_init(radio); retval = usb_amradio_init(radio);
if (retval) if (retval)
usb_autopm_put_interface(radio->intf); usb_autopm_put_interface(radio->intf);
} }
unlock:
mutex_unlock(&radio->lock);
return retval; return retval;
} }
...@@ -532,37 +514,9 @@ static int usb_amradio_open(struct file *file) ...@@ -532,37 +514,9 @@ static int usb_amradio_open(struct file *file)
static int usb_amradio_close(struct file *file) static int usb_amradio_close(struct file *file)
{ {
struct amradio_device *radio = file->private_data; struct amradio_device *radio = file->private_data;
int retval = 0;
mutex_lock(&radio->lock);
if (!radio->usbdev)
retval = -EIO;
else
usb_autopm_put_interface(radio->intf);
mutex_unlock(&radio->lock);
return retval;
}
static long usb_amradio_ioctl(struct file *file, unsigned int cmd,
unsigned long arg)
{
struct amradio_device *radio = file->private_data;
long retval = 0;
mutex_lock(&radio->lock);
if (!radio->usbdev) {
retval = -EIO;
goto unlock;
}
retval = video_ioctl2(file, cmd, arg);
unlock: usb_autopm_put_interface(radio->intf);
mutex_unlock(&radio->lock); return 0;
return retval;
} }
/* Suspend device - stop device. Need to be checked and fixed */ /* Suspend device - stop device. Need to be checked and fixed */
...@@ -570,16 +524,12 @@ static int usb_amradio_suspend(struct usb_interface *intf, pm_message_t message) ...@@ -570,16 +524,12 @@ static int usb_amradio_suspend(struct usb_interface *intf, pm_message_t message)
{ {
struct amradio_device *radio = to_amradio_dev(usb_get_intfdata(intf)); struct amradio_device *radio = to_amradio_dev(usb_get_intfdata(intf));
mutex_lock(&radio->lock);
if (!radio->muted && radio->initialized) { if (!radio->muted && radio->initialized) {
amradio_set_mute(radio, AMRADIO_STOP); amradio_set_mute(radio, AMRADIO_STOP);
radio->muted = 0; radio->muted = 0;
} }
dev_info(&intf->dev, "going into suspend..\n"); dev_info(&intf->dev, "going into suspend..\n");
mutex_unlock(&radio->lock);
return 0; return 0;
} }
...@@ -588,10 +538,8 @@ static int usb_amradio_resume(struct usb_interface *intf) ...@@ -588,10 +538,8 @@ static int usb_amradio_resume(struct usb_interface *intf)
{ {
struct amradio_device *radio = to_amradio_dev(usb_get_intfdata(intf)); struct amradio_device *radio = to_amradio_dev(usb_get_intfdata(intf));
mutex_lock(&radio->lock);
if (unlikely(!radio->initialized)) if (unlikely(!radio->initialized))
goto unlock; return 0;
if (radio->stereo) if (radio->stereo)
amradio_set_stereo(radio, WANT_STEREO); amradio_set_stereo(radio, WANT_STEREO);
...@@ -603,10 +551,7 @@ static int usb_amradio_resume(struct usb_interface *intf) ...@@ -603,10 +551,7 @@ static int usb_amradio_resume(struct usb_interface *intf)
if (!radio->muted) if (!radio->muted)
amradio_set_mute(radio, AMRADIO_START); amradio_set_mute(radio, AMRADIO_START);
unlock:
dev_info(&intf->dev, "coming out of suspend..\n"); dev_info(&intf->dev, "coming out of suspend..\n");
mutex_unlock(&radio->lock);
return 0; return 0;
} }
...@@ -615,7 +560,7 @@ static const struct v4l2_file_operations usb_amradio_fops = { ...@@ -615,7 +560,7 @@ static const struct v4l2_file_operations usb_amradio_fops = {
.owner = THIS_MODULE, .owner = THIS_MODULE,
.open = usb_amradio_open, .open = usb_amradio_open,
.release = usb_amradio_close, .release = usb_amradio_close,
.ioctl = usb_amradio_ioctl, .unlocked_ioctl = video_ioctl2,
}; };
static const struct v4l2_ioctl_ops usb_amradio_ioctl_ops = { static const struct v4l2_ioctl_ops usb_amradio_ioctl_ops = {
...@@ -671,19 +616,20 @@ static int usb_amradio_probe(struct usb_interface *intf, ...@@ -671,19 +616,20 @@ static int usb_amradio_probe(struct usb_interface *intf,
goto err_v4l2; goto err_v4l2;
} }
mutex_init(&radio->lock);
strlcpy(radio->videodev.name, radio->v4l2_dev.name, strlcpy(radio->videodev.name, radio->v4l2_dev.name,
sizeof(radio->videodev.name)); sizeof(radio->videodev.name));
radio->videodev.v4l2_dev = &radio->v4l2_dev; radio->videodev.v4l2_dev = &radio->v4l2_dev;
radio->videodev.fops = &usb_amradio_fops; radio->videodev.fops = &usb_amradio_fops;
radio->videodev.ioctl_ops = &usb_amradio_ioctl_ops; radio->videodev.ioctl_ops = &usb_amradio_ioctl_ops;
radio->videodev.release = usb_amradio_video_device_release; radio->videodev.release = usb_amradio_video_device_release;
radio->videodev.lock = &radio->lock;
radio->usbdev = interface_to_usbdev(intf); radio->usbdev = interface_to_usbdev(intf);
radio->intf = intf; radio->intf = intf;
radio->curfreq = 95.16 * FREQ_MUL; radio->curfreq = 95.16 * FREQ_MUL;
mutex_init(&radio->lock);
video_set_drvdata(&radio->videodev, radio); video_set_drvdata(&radio->videodev, radio);
retval = video_register_device(&radio->videodev, VFL_TYPE_RADIO, retval = video_register_device(&radio->videodev, VFL_TYPE_RADIO,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册