This is an automatic generated email to let you know that the following patch 
were queued at the 
http://git.linuxtv.org/media_tree.git tree:

Subject: [media] usbvision: convert to unlocked_ioctl
Author:  Hans Verkuil <hverk...@xs4all.nl>
Date:    Sat Dec 18 11:06:09 2010 -0300

Convert driver to use core-assisted locking.

Signed-off-by: Hans Verkuil <hverk...@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mche...@redhat.com>

 drivers/media/video/usbvision/usbvision-core.c  |    6 +--
 drivers/media/video/usbvision/usbvision-video.c |   44 +++-------------------
 drivers/media/video/usbvision/usbvision.h       |    2 +-
 3 files changed, 9 insertions(+), 43 deletions(-)

---

http://git.linuxtv.org/media_tree.git?a=commitdiff;h=3091054ce9bb98777c401453d38b8decdd1057b0

diff --git a/drivers/media/video/usbvision/usbvision-core.c 
b/drivers/media/video/usbvision/usbvision-core.c
index b9dd74f..de58aa7 100644
--- a/drivers/media/video/usbvision/usbvision-core.c
+++ b/drivers/media/video/usbvision/usbvision-core.c
@@ -2291,10 +2291,8 @@ static void call_usbvision_power_off(struct work_struct 
*work)
        struct usb_usbvision *usbvision = container_of(work, struct 
usb_usbvision, powerOffWork);
 
        PDEBUG(DBG_FUNC, "");
-       if(mutex_lock_interruptible(&usbvision->lock)) {
+       if (mutex_lock_interruptible(&usbvision->v4l2_lock))
                return;
-       }
-
 
        if(usbvision->user == 0) {
                usbvision_i2c_unregister(usbvision);
@@ -2302,7 +2300,7 @@ static void call_usbvision_power_off(struct work_struct 
*work)
                usbvision_power_off(usbvision);
                usbvision->initialized = 0;
        }
-       mutex_unlock(&usbvision->lock);
+       mutex_unlock(&usbvision->v4l2_lock);
 }
 
 static void usbvision_powerOffTimer(unsigned long data)
diff --git a/drivers/media/video/usbvision/usbvision-video.c 
b/drivers/media/video/usbvision/usbvision-video.c
index 13018a9..f5a8769 100644
--- a/drivers/media/video/usbvision/usbvision-video.c
+++ b/drivers/media/video/usbvision/usbvision-video.c
@@ -357,7 +357,6 @@ static int usbvision_v4l2_open(struct file *file)
 
        PDEBUG(DBG_IO, "open");
 
-       mutex_lock(&usbvision->lock);
        usbvision_reset_powerOffTimer(usbvision);
 
        if (usbvision->user)
@@ -413,7 +412,6 @@ static int usbvision_v4l2_open(struct file *file)
        usbvision_empty_framequeues(usbvision);
 
        PDEBUG(DBG_IO, "success");
-       mutex_unlock(&usbvision->lock);
        return errCode;
 }
 
@@ -430,7 +428,6 @@ static int usbvision_v4l2_close(struct file *file)
        struct usb_usbvision *usbvision = video_drvdata(file);
 
        PDEBUG(DBG_IO, "close");
-       mutex_lock(&usbvision->lock);
 
        usbvision_audio_off(usbvision);
        usbvision_restart_isoc(usbvision);
@@ -450,8 +447,6 @@ static int usbvision_v4l2_close(struct file *file)
                usbvision->initialized = 0;
        }
 
-       mutex_unlock(&usbvision->lock);
-
        if (usbvision->remove_pending) {
                printk(KERN_INFO "%s: Final disconnect\n", __func__);
                usbvision_release(usbvision);
@@ -598,13 +593,11 @@ static int vidioc_s_input (struct file *file, void *priv, 
unsigned int input)
        if (input >= usbvision->video_inputs)
                return -EINVAL;
 
-       mutex_lock(&usbvision->lock);
        usbvision_muxsel(usbvision, input);
        usbvision_set_input(usbvision);
        usbvision_set_output(usbvision,
                             usbvision->curwidth,
                             usbvision->curheight);
-       mutex_unlock(&usbvision->lock);
        return 0;
 }
 
@@ -614,9 +607,7 @@ static int vidioc_s_std (struct file *file, void *priv, 
v4l2_std_id *id)
 
        usbvision->tvnormId=*id;
 
-       mutex_lock(&usbvision->lock);
        call_all(usbvision, core, s_std, usbvision->tvnormId);
-       mutex_unlock(&usbvision->lock);
        /* propagate the change to the decoder */
        usbvision_muxsel(usbvision, usbvision->ctl_input);
 
@@ -978,9 +969,7 @@ static int vidioc_s_fmt_vid_cap(struct file *file, void 
*priv,
        usbvision->curFrame = NULL;
 
        /* by now we are committed to the new data... */
-       mutex_lock(&usbvision->lock);
        usbvision_set_output(usbvision, vf->fmt.pix.width, vf->fmt.pix.height);
-       mutex_unlock(&usbvision->lock);
 
        return 0;
 }
@@ -1101,16 +1090,12 @@ static int usbvision_v4l2_mmap(struct file *file, 
struct vm_area_struct *vma)
 
        PDEBUG(DBG_MMAP, "mmap");
 
-       mutex_lock(&usbvision->lock);
-
        if (!USBVISION_IS_OPERATIONAL(usbvision)) {
-               mutex_unlock(&usbvision->lock);
                return -EFAULT;
        }
 
        if (!(vma->vm_flags & VM_WRITE) ||
            size != PAGE_ALIGN(usbvision->max_frame_size)) {
-               mutex_unlock(&usbvision->lock);
                return -EINVAL;
        }
 
@@ -1122,7 +1107,6 @@ static int usbvision_v4l2_mmap(struct file *file, struct 
vm_area_struct *vma)
        if (i == usbvision->num_frames) {
                PDEBUG(DBG_MMAP,
                       "mmap: user supplied mapping address is out of range");
-               mutex_unlock(&usbvision->lock);
                return -EINVAL;
        }
 
@@ -1135,7 +1119,6 @@ static int usbvision_v4l2_mmap(struct file *file, struct 
vm_area_struct *vma)
 
                if (vm_insert_page(vma, start, vmalloc_to_page(pos))) {
                        PDEBUG(DBG_MMAP, "mmap: vm_insert_page failed");
-                       mutex_unlock(&usbvision->lock);
                        return -EAGAIN;
                }
                start += PAGE_SIZE;
@@ -1143,7 +1126,6 @@ static int usbvision_v4l2_mmap(struct file *file, struct 
vm_area_struct *vma)
                size -= PAGE_SIZE;
        }
 
-       mutex_unlock(&usbvision->lock);
        return 0;
 }
 
@@ -1159,8 +1141,6 @@ static int usbvision_radio_open(struct file *file)
 
        PDEBUG(DBG_IO, "%s:", __func__);
 
-       mutex_lock(&usbvision->lock);
-
        if (usbvision->user) {
                dev_err(&usbvision->rdev->dev,
                        "%s: Someone tried to open an already opened USBVision 
Radio!\n",
@@ -1199,7 +1179,6 @@ static int usbvision_radio_open(struct file *file)
                }
        }
 out:
-       mutex_unlock(&usbvision->lock);
        return errCode;
 }
 
@@ -1211,8 +1190,6 @@ static int usbvision_radio_close(struct file *file)
 
        PDEBUG(DBG_IO, "");
 
-       mutex_lock(&usbvision->lock);
-
        /* Set packet size to 0 */
        usbvision->ifaceAlt=0;
        errCode = usb_set_interface(usbvision->dev, usbvision->iface,
@@ -1227,8 +1204,6 @@ static int usbvision_radio_close(struct file *file)
                usbvision->initialized = 0;
        }
 
-       mutex_unlock(&usbvision->lock);
-
        if (usbvision->remove_pending) {
                printk(KERN_INFO "%s: Final disconnect\n", __func__);
                usbvision_release(usbvision);
@@ -1249,7 +1224,7 @@ static const struct v4l2_file_operations usbvision_fops = 
{
        .release        = usbvision_v4l2_close,
        .read           = usbvision_v4l2_read,
        .mmap           = usbvision_v4l2_mmap,
-       .ioctl          = video_ioctl2,
+       .unlocked_ioctl = video_ioctl2,
 /*     .poll          = video_poll, */
 };
 
@@ -1299,7 +1274,7 @@ static const struct v4l2_file_operations 
usbvision_radio_fops = {
        .owner             = THIS_MODULE,
        .open           = usbvision_radio_open,
        .release        = usbvision_radio_close,
-       .ioctl          = video_ioctl2,
+       .unlocked_ioctl = video_ioctl2,
 };
 
 static const struct v4l2_ioctl_ops usbvision_radio_ioctl_ops = {
@@ -1347,6 +1322,7 @@ static struct video_device *usbvision_vdev_init(struct 
usb_usbvision *usbvision,
                return NULL;
        }
        *vdev = *vdev_template;
+       vdev->lock = &usbvision->v4l2_lock;
        vdev->v4l2_dev = &usbvision->v4l2_dev;
        snprintf(vdev->name, sizeof(vdev->name), "%s", name);
        video_set_drvdata(vdev, usbvision);
@@ -1449,7 +1425,7 @@ static struct usb_usbvision *usbvision_alloc(struct 
usb_device *dev,
        if (v4l2_device_register(&intf->dev, &usbvision->v4l2_dev))
                goto err_free;
 
-       mutex_init(&usbvision->lock);   /* available */
+       mutex_init(&usbvision->v4l2_lock);
 
        // prepare control urb for control messages during interrupts
        usbvision->ctrlUrb = usb_alloc_urb(USBVISION_URB_FRAMES, GFP_KERNEL);
@@ -1479,14 +1455,10 @@ static void usbvision_release(struct usb_usbvision 
*usbvision)
 {
        PDEBUG(DBG_PROBE, "");
 
-       mutex_lock(&usbvision->lock);
-
        usbvision_reset_powerOffTimer(usbvision);
 
        usbvision->initialized = 0;
 
-       mutex_unlock(&usbvision->lock);
-
        usbvision_remove_sysfs(usbvision->vdev);
        usbvision_unregister_video(usbvision);
 
@@ -1599,8 +1571,6 @@ static int __devinit usbvision_probe(struct usb_interface 
*intf,
        }
        PDEBUG(DBG_PROBE, "bridgeType %d", usbvision->bridgeType);
 
-       mutex_lock(&usbvision->lock);
-
        /* compute alternate max packet sizes */
        uif = dev->actconfig->interface[0];
 
@@ -1610,7 +1580,6 @@ static int __devinit usbvision_probe(struct usb_interface 
*intf,
                                              usbvision->num_alt,GFP_KERNEL);
        if (usbvision->alt_max_pkt_size == NULL) {
                dev_err(&intf->dev, "usbvision: out of memory!\n");
-               mutex_unlock(&usbvision->lock);
                return -ENOMEM;
        }
 
@@ -1642,7 +1611,6 @@ static int __devinit usbvision_probe(struct usb_interface 
*intf,
        usbvision->streaming = Stream_Off;
        usbvision_configure_video(usbvision);
        usbvision_register_video(usbvision);
-       mutex_unlock(&usbvision->lock);
 
        usbvision_create_sysfs(usbvision->vdev);
 
@@ -1670,7 +1638,7 @@ static void __devexit usbvision_disconnect(struct 
usb_interface *intf)
                return;
        }
 
-       mutex_lock(&usbvision->lock);
+       mutex_lock(&usbvision->v4l2_lock);
 
        // At this time we ask to cancel outstanding URBs
        usbvision_stop_isoc(usbvision);
@@ -1686,7 +1654,7 @@ static void __devexit usbvision_disconnect(struct 
usb_interface *intf)
        usb_put_dev(usbvision->dev);
        usbvision->dev = NULL;  // USB device is no more
 
-       mutex_unlock(&usbvision->lock);
+       mutex_unlock(&usbvision->v4l2_lock);
 
        if (usbvision->user) {
                printk(KERN_INFO "%s: In use, disconnect pending\n",
diff --git a/drivers/media/video/usbvision/usbvision.h 
b/drivers/media/video/usbvision/usbvision.h
index cc4e96c..2271ede 100644
--- a/drivers/media/video/usbvision/usbvision.h
+++ b/drivers/media/video/usbvision/usbvision.h
@@ -391,7 +391,7 @@ struct usb_usbvision {
        unsigned char iface;                                            /* 
Video interface number */
        unsigned char ifaceAlt;                 /* Alt settings */
        unsigned char Vin_Reg2_Preset;
-       struct mutex               lock;
+       struct mutex v4l2_lock;
        struct timer_list powerOffTimer;
        struct work_struct powerOffWork;
        int power;                                                      /* is 
the device powered on? */

_______________________________________________
linuxtv-commits mailing list
linuxtv-commits@linuxtv.org
http://www.linuxtv.org/cgi-bin/mailman/listinfo/linuxtv-commits

Reply via email to