upstream: [media] em28xx: move v4l2 user counting fields from struct em28xx to struct...
authorFrank Schaefer <fschaefer.oss@googlemail.com>
Sun, 11 May 2014 20:59:04 +0000 (17:59 -0300)
committerChanho Park <chanho61.park@samsung.com>
Tue, 18 Nov 2014 02:59:20 +0000 (11:59 +0900)
Despite being at the common em28xx struct, those two fields are
actually taking into account only the usage inside em28xx v4l2
submodule. So, move them out of the common struct.

Signed-off-by: Frank Schäfer <fschaefer.oss@googlemail.com>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
drivers/media/usb/em28xx/em28xx-video.c
drivers/media/usb/em28xx/em28xx.h

index 05de9a7..2a8fe30 100644 (file)
@@ -934,7 +934,7 @@ int em28xx_start_analog_streaming(struct vb2_queue *vq, unsigned int count)
        if (rc)
                return rc;
 
-       if (dev->streaming_users == 0) {
+       if (v4l2->streaming_users == 0) {
                /* First active streaming user, so allocate all the URBs */
 
                /* Allocate the USB bandwidth */
@@ -972,7 +972,7 @@ int em28xx_start_analog_streaming(struct vb2_queue *vq, unsigned int count)
                                     0, tuner, s_frequency, &f);
        }
 
-       dev->streaming_users++;
+       v4l2->streaming_users++;
 
        return rc;
 }
@@ -980,6 +980,7 @@ int em28xx_start_analog_streaming(struct vb2_queue *vq, unsigned int count)
 static void em28xx_stop_streaming(struct vb2_queue *vq)
 {
        struct em28xx *dev = vb2_get_drv_priv(vq);
+       struct em28xx_v4l2 *v4l2 = dev->v4l2;
        struct em28xx_dmaqueue *vidq = &dev->vidq;
        unsigned long flags = 0;
 
@@ -987,7 +988,7 @@ static void em28xx_stop_streaming(struct vb2_queue *vq)
 
        res_free(dev, vq->type);
 
-       if (dev->streaming_users-- == 1) {
+       if (v4l2->streaming_users-- == 1) {
                /* Last active user, so shutdown all the URBS */
                em28xx_uninit_usb_xfer(dev, EM28XX_ANALOG_MODE);
        }
@@ -1009,6 +1010,7 @@ static void em28xx_stop_streaming(struct vb2_queue *vq)
 void em28xx_stop_vbi_streaming(struct vb2_queue *vq)
 {
        struct em28xx *dev = vb2_get_drv_priv(vq);
+       struct em28xx_v4l2 *v4l2 = dev->v4l2;
        struct em28xx_dmaqueue *vbiq = &dev->vbiq;
        unsigned long flags = 0;
 
@@ -1016,7 +1018,7 @@ void em28xx_stop_vbi_streaming(struct vb2_queue *vq)
 
        res_free(dev, vq->type);
 
-       if (dev->streaming_users-- == 1) {
+       if (v4l2->streaming_users-- == 1) {
                /* Last active user, so shutdown all the URBS */
                em28xx_uninit_usb_xfer(dev, EM28XX_ANALOG_MODE);
        }
@@ -1346,8 +1348,9 @@ static int vidioc_s_fmt_vid_cap(struct file *file, void *priv,
                        struct v4l2_format *f)
 {
        struct em28xx *dev = video_drvdata(file);
+       struct em28xx_v4l2 *v4l2 = dev->v4l2;
 
-       if (dev->streaming_users > 0)
+       if (v4l2->streaming_users > 0)
                return -EBUSY;
 
        vidioc_try_fmt_vid_cap(file, priv, f);
@@ -1386,7 +1389,7 @@ static int vidioc_s_std(struct file *file, void *priv, v4l2_std_id norm)
        if (norm == v4l2->norm)
                return 0;
 
-       if (dev->streaming_users > 0)
+       if (v4l2->streaming_users > 0)
                return -EBUSY;
 
        v4l2->norm = norm;
@@ -1909,7 +1912,7 @@ static int em28xx_v4l2_open(struct file *filp)
 
        em28xx_videodbg("open dev=%s type=%s users=%d\n",
                        video_device_node_name(vdev), v4l2_type_names[fh_type],
-                       dev->users);
+                       v4l2->users);
 
        if (mutex_lock_interruptible(&dev->lock))
                return -ERESTARTSYS;
@@ -1924,7 +1927,7 @@ static int em28xx_v4l2_open(struct file *filp)
        fh->type = fh_type;
        filp->private_data = fh;
 
-       if (dev->users == 0) {
+       if (v4l2->users == 0) {
                em28xx_set_mode(dev, EM28XX_ANALOG_MODE);
 
                if (vdev->vfl_type != VFL_TYPE_RADIO)
@@ -1944,7 +1947,7 @@ static int em28xx_v4l2_open(struct file *filp)
 
        kref_get(&dev->ref);
        kref_get(&v4l2->ref);
-       dev->users++;
+       v4l2->users++;
 
        mutex_unlock(&dev->lock);
        v4l2_fh_add(&fh->fh);
@@ -2053,12 +2056,12 @@ static int em28xx_v4l2_close(struct file *filp)
        struct em28xx_v4l2    *v4l2 = dev->v4l2;
        int              errCode;
 
-       em28xx_videodbg("users=%d\n", dev->users);
+       em28xx_videodbg("users=%d\n", v4l2->users);
 
        vb2_fop_release(filp);
        mutex_lock(&dev->lock);
 
-       if (dev->users == 1) {
+       if (v4l2->users == 1) {
                /* No sense to try to write to the device */
                if (dev->disconnected)
                        goto exit;
@@ -2080,8 +2083,8 @@ static int em28xx_v4l2_close(struct file *filp)
        }
 
 exit:
+       v4l2->users--;
        kref_put(&v4l2->ref, em28xx_free_v4l2);
-       dev->users--;
        mutex_unlock(&dev->lock);
        kref_put(&dev->ref, em28xx_free_device);
 
index 7edba65..998be42 100644 (file)
@@ -524,6 +524,9 @@ struct em28xx_v4l2 {
        int sensor_yres;
        int sensor_xtal;
 
+       int users;              /* user count for exclusive use */
+       int streaming_users;    /* number of actively streaming users */
+
        struct em28xx_fmt *format;
        v4l2_std_id norm;       /* selected tv norm */
 
@@ -642,8 +645,6 @@ struct em28xx {
        struct rt_mutex i2c_bus_lock;
 
        /* video for linux */
-       int users;              /* user count for exclusive use */
-       int streaming_users;    /* Number of actively streaming users */
        int ctl_freq;           /* selected frequency */
        unsigned int ctl_input; /* selected input */
        unsigned int ctl_ainput;/* selected audio input */