These changes are the raw update to linux-4.4.6-rt14. Kernel sources
[kvmfornfv.git] / kernel / drivers / media / usb / usbvision / usbvision-core.c
index 44b0c28..dc3b4d5 100644 (file)
@@ -1367,7 +1367,7 @@ static void usbvision_isoc_irq(struct urb *urb)
 int usbvision_read_reg(struct usb_usbvision *usbvision, unsigned char reg)
 {
        int err_code = 0;
-       unsigned char buffer[1];
+       unsigned char *buffer = usbvision->ctrl_urb_buffer;
 
        if (!USBVISION_IS_OPERATIONAL(usbvision))
                return -1;
@@ -1401,10 +1401,12 @@ int usbvision_write_reg(struct usb_usbvision *usbvision, unsigned char reg,
        if (!USBVISION_IS_OPERATIONAL(usbvision))
                return 0;
 
+       usbvision->ctrl_urb_buffer[0] = value;
        err_code = usb_control_msg(usbvision->dev, usb_sndctrlpipe(usbvision->dev, 1),
                                USBVISION_OP_CODE,
                                USB_DIR_OUT | USB_TYPE_VENDOR |
-                               USB_RECIP_ENDPOINT, 0, (__u16) reg, &value, 1, HZ);
+                               USB_RECIP_ENDPOINT, 0, (__u16) reg,
+                               usbvision->ctrl_urb_buffer, 1, HZ);
 
        if (err_code < 0) {
                dev_err(&usbvision->dev->dev,
@@ -1596,7 +1598,7 @@ static int usbvision_init_webcam(struct usb_usbvision *usbvision)
                { 0x27, 0x00, 0x00 }, { 0x28, 0x00, 0x00 }, { 0x29, 0x00, 0x00 }, { 0x08, 0x80, 0x60 },
                { 0x0f, 0x2d, 0x24 }, { 0x0c, 0x80, 0x80 }
        };
-       char value[3];
+       unsigned char *value = usbvision->ctrl_urb_buffer;
 
        /* the only difference between PAL and NTSC init_values */
        if (usbvision_device_data[usbvision->dev_model].video_norm == V4L2_STD_NTSC)
@@ -1635,8 +1637,8 @@ static int usbvision_init_webcam(struct usb_usbvision *usbvision)
 static int usbvision_set_video_format(struct usb_usbvision *usbvision, int format)
 {
        static const char proc[] = "usbvision_set_video_format";
+       unsigned char *value = usbvision->ctrl_urb_buffer;
        int rc;
-       unsigned char value[2];
 
        if (!USBVISION_IS_OPERATIONAL(usbvision))
                return 0;
@@ -1677,7 +1679,7 @@ int usbvision_set_output(struct usb_usbvision *usbvision, int width,
        int err_code = 0;
        int usb_width, usb_height;
        unsigned int frame_rate = 0, frame_drop = 0;
-       unsigned char value[4];
+       unsigned char *value = usbvision->ctrl_urb_buffer;
 
        if (!USBVISION_IS_OPERATIONAL(usbvision))
                return 0;
@@ -1789,10 +1791,6 @@ int usbvision_frames_alloc(struct usb_usbvision *usbvision, int number_of_frames
                usbvision->num_frames--;
        }
 
-       spin_lock_init(&usbvision->queue_lock);
-       init_waitqueue_head(&usbvision->wait_frame);
-       init_waitqueue_head(&usbvision->wait_stream);
-
        /* Allocate all buffers */
        for (i = 0; i < usbvision->num_frames; i++) {
                usbvision->frame[i].index = i;
@@ -1872,7 +1870,7 @@ static int usbvision_set_compress_params(struct usb_usbvision *usbvision)
 {
        static const char proc[] = "usbvision_set_compresion_params: ";
        int rc;
-       unsigned char value[6];
+       unsigned char *value = usbvision->ctrl_urb_buffer;
 
        value[0] = 0x0F;    /* Intra-Compression cycle */
        value[1] = 0x01;    /* Reg.45 one line per strip */
@@ -1946,7 +1944,7 @@ int usbvision_set_input(struct usb_usbvision *usbvision)
 {
        static const char proc[] = "usbvision_set_input: ";
        int rc;
-       unsigned char value[8];
+       unsigned char *value = usbvision->ctrl_urb_buffer;
        unsigned char dvi_yuv_value;
 
        if (!USBVISION_IS_OPERATIONAL(usbvision))
@@ -2062,8 +2060,8 @@ int usbvision_set_input(struct usb_usbvision *usbvision)
 
 static int usbvision_set_dram_settings(struct usb_usbvision *usbvision)
 {
+       unsigned char *value = usbvision->ctrl_urb_buffer;
        int rc;
-       unsigned char value[8];
 
        if (usbvision->isoc_mode == ISOC_MODE_COMPRESS) {
                value[0] = 0x42;
@@ -2160,55 +2158,6 @@ int usbvision_power_on(struct usb_usbvision *usbvision)
 }
 
 
-/*
- * usbvision timer stuff
- */
-
-/* to call usbvision_power_off from task queue */
-static void call_usbvision_power_off(struct work_struct *work)
-{
-       struct usb_usbvision *usbvision = container_of(work, struct usb_usbvision, power_off_work);
-
-       PDEBUG(DBG_FUNC, "");
-       if (mutex_lock_interruptible(&usbvision->v4l2_lock))
-               return;
-
-       if (usbvision->user == 0) {
-               usbvision_i2c_unregister(usbvision);
-
-               usbvision_power_off(usbvision);
-               usbvision->initialized = 0;
-       }
-       mutex_unlock(&usbvision->v4l2_lock);
-}
-
-static void usbvision_power_off_timer(unsigned long data)
-{
-       struct usb_usbvision *usbvision = (void *)data;
-
-       PDEBUG(DBG_FUNC, "");
-       del_timer(&usbvision->power_off_timer);
-       INIT_WORK(&usbvision->power_off_work, call_usbvision_power_off);
-       (void) schedule_work(&usbvision->power_off_work);
-}
-
-void usbvision_init_power_off_timer(struct usb_usbvision *usbvision)
-{
-       setup_timer(&usbvision->power_off_timer, usbvision_power_off_timer,
-                   (unsigned long)usbvision);
-}
-
-void usbvision_set_power_off_timer(struct usb_usbvision *usbvision)
-{
-       mod_timer(&usbvision->power_off_timer, jiffies + USBVISION_POWEROFF_TIME);
-}
-
-void usbvision_reset_power_off_timer(struct usb_usbvision *usbvision)
-{
-       if (timer_pending(&usbvision->power_off_timer))
-               del_timer(&usbvision->power_off_timer);
-}
-
 /*
  * usbvision_begin_streaming()
  * Sure you have to put bit 7 to 0, if not incoming frames are droped, but no
@@ -2390,8 +2339,8 @@ int usbvision_init_isoc(struct usb_usbvision *usbvision)
 
        /* Submit all URBs */
        for (buf_idx = 0; buf_idx < USBVISION_NUMSBUF; buf_idx++) {
-                       err_code = usb_submit_urb(usbvision->sbuf[buf_idx].urb,
-                                                GFP_KERNEL);
+               err_code = usb_submit_urb(usbvision->sbuf[buf_idx].urb,
+                                        GFP_KERNEL);
                if (err_code) {
                        dev_err(&usbvision->dev->dev,
                                "%s: usb_submit_urb(%d) failed: error %d\n",