media: stk1160: move transfer_buffer and urb to same struct 'stk1160_urb'
authorDafna Hirschfeld <dafna.hirschfeld@collabora.com>
Tue, 25 Jan 2022 08:02:12 +0000 (09:02 +0100)
committerMauro Carvalho Chehab <mchehab@kernel.org>
Mon, 7 Mar 2022 09:59:51 +0000 (10:59 +0100)
Instead of having two separated arrays, one for the urbs and
one for their buffers, have one array of a struct containing both.
In addition, the array is just 16 pointers, no need to dynamically
allocate it.

Signed-off-by: Dafna Hirschfeld <dafna.hirschfeld@collabora.com>
Reviewed-by: Ezequiel Garcia <ezequiel@vanguardiasur.com.ar>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
drivers/media/usb/stk1160/stk1160-v4l.c
drivers/media/usb/stk1160/stk1160-video.c
drivers/media/usb/stk1160/stk1160.h

index 1aa9534..ebf245d 100644 (file)
@@ -232,7 +232,7 @@ static int stk1160_start_streaming(struct stk1160 *dev)
 
        /* submit urbs and enables IRQ */
        for (i = 0; i < dev->isoc_ctl.num_bufs; i++) {
-               rc = usb_submit_urb(dev->isoc_ctl.urb[i], GFP_KERNEL);
+               rc = usb_submit_urb(dev->isoc_ctl.urb_ctl[i].urb, GFP_KERNEL);
                if (rc) {
                        stk1160_err("cannot submit urb[%d] (%d)\n", i, rc);
                        goto out_uninit;
index 92c8b1f..f3c0497 100644 (file)
@@ -347,7 +347,7 @@ void stk1160_cancel_isoc(struct stk1160 *dev)
                 * We don't care for NULL pointer since
                 * usb_kill_urb allows it.
                 */
-               usb_kill_urb(dev->isoc_ctl.urb[i]);
+               usb_kill_urb(dev->isoc_ctl.urb_ctl[i].urb);
        }
 
        stk1160_dbg("all urbs killed\n");
@@ -366,30 +366,25 @@ void stk1160_free_isoc(struct stk1160 *dev)
 
        for (i = 0; i < num_bufs; i++) {
 
-               urb = dev->isoc_ctl.urb[i];
+               urb = dev->isoc_ctl.urb_ctl[i].urb;
                if (urb) {
 
-                       if (dev->isoc_ctl.transfer_buffer[i]) {
+                       if (dev->isoc_ctl.urb_ctl[i].transfer_buffer) {
 #ifndef CONFIG_DMA_NONCOHERENT
                                usb_free_coherent(dev->udev,
                                        urb->transfer_buffer_length,
-                                       dev->isoc_ctl.transfer_buffer[i],
+                                       dev->isoc_ctl.urb_ctl[i].transfer_buffer,
                                        urb->transfer_dma);
 #else
-                               kfree(dev->isoc_ctl.transfer_buffer[i]);
+                               kfree(dev->isoc_ctl.urb_ctl[i].transfer_buffer);
 #endif
                        }
                        usb_free_urb(urb);
-                       dev->isoc_ctl.urb[i] = NULL;
+                       dev->isoc_ctl.urb_ctl[i].urb = NULL;
                }
-               dev->isoc_ctl.transfer_buffer[i] = NULL;
+               dev->isoc_ctl.urb_ctl[i].transfer_buffer = NULL;
        }
 
-       kfree(dev->isoc_ctl.urb);
-       kfree(dev->isoc_ctl.transfer_buffer);
-
-       dev->isoc_ctl.urb = NULL;
-       dev->isoc_ctl.transfer_buffer = NULL;
        dev->isoc_ctl.num_bufs = 0;
 
        stk1160_dbg("all urb buffers freed\n");
@@ -429,19 +424,6 @@ int stk1160_alloc_isoc(struct stk1160 *dev)
 
        dev->isoc_ctl.buf = NULL;
        dev->isoc_ctl.max_pkt_size = dev->max_pkt_size;
-       dev->isoc_ctl.urb = kcalloc(num_bufs, sizeof(void *), GFP_KERNEL);
-       if (!dev->isoc_ctl.urb) {
-               stk1160_err("out of memory for urb array\n");
-               return -ENOMEM;
-       }
-
-       dev->isoc_ctl.transfer_buffer = kcalloc(num_bufs, sizeof(void *),
-                                               GFP_KERNEL);
-       if (!dev->isoc_ctl.transfer_buffer) {
-               stk1160_err("out of memory for usb transfers\n");
-               kfree(dev->isoc_ctl.urb);
-               return -ENOMEM;
-       }
 
        /* allocate urbs and transfer buffers */
        for (i = 0; i < num_bufs; i++) {
@@ -449,15 +431,17 @@ int stk1160_alloc_isoc(struct stk1160 *dev)
                urb = usb_alloc_urb(max_packets, GFP_KERNEL);
                if (!urb)
                        goto free_i_bufs;
-               dev->isoc_ctl.urb[i] = urb;
+               dev->isoc_ctl.urb_ctl[i].urb = urb;
 
 #ifndef CONFIG_DMA_NONCOHERENT
-               dev->isoc_ctl.transfer_buffer[i] = usb_alloc_coherent(dev->udev,
-                       sb_size, GFP_KERNEL, &urb->transfer_dma);
+               dev->isoc_ctl.urb_ctl[i].transfer_buffer =
+                       usb_alloc_coherent(dev->udev, sb_size, GFP_KERNEL,
+                                          &urb->transfer_dma);
 #else
-               dev->isoc_ctl.transfer_buffer[i] = kmalloc(sb_size, GFP_KERNEL);
+               dev->isoc_ctl.urb_ctl[i].transfer_buffer =
+                       kmalloc(sb_size, GFP_KERNEL);
 #endif
-               if (!dev->isoc_ctl.transfer_buffer[i]) {
+               if (!dev->isoc_ctl.urb_ctl[i].transfer_buffer) {
                        stk1160_err("cannot alloc %d bytes for tx[%d] buffer\n",
                                sb_size, i);
 
@@ -466,14 +450,14 @@ int stk1160_alloc_isoc(struct stk1160 *dev)
                                goto free_i_bufs;
                        goto nomore_tx_bufs;
                }
-               memset(dev->isoc_ctl.transfer_buffer[i], 0, sb_size);
+               memset(dev->isoc_ctl.urb_ctl[i].transfer_buffer, 0, sb_size);
 
                /*
                 * FIXME: Where can I get the endpoint?
                 */
                urb->dev = dev->udev;
                urb->pipe = usb_rcvisocpipe(dev->udev, STK1160_EP_VIDEO);
-               urb->transfer_buffer = dev->isoc_ctl.transfer_buffer[i];
+               urb->transfer_buffer = dev->isoc_ctl.urb_ctl[i].transfer_buffer;
                urb->transfer_buffer_length = sb_size;
                urb->complete = stk1160_isoc_irq;
                urb->context = dev;
@@ -508,8 +492,8 @@ nomore_tx_bufs:
         * enough to work fine, so we just free the extra urb,
         * store the allocated count and keep going, fingers crossed!
         */
-       usb_free_urb(dev->isoc_ctl.urb[i]);
-       dev->isoc_ctl.urb[i] = NULL;
+       usb_free_urb(dev->isoc_ctl.urb_ctl[i].urb);
+       dev->isoc_ctl.urb_ctl[i].urb = NULL;
 
        stk1160_warn("%d urbs allocated. Trying to continue...\n", i);
 
index a70963c..0c355bb 100644 (file)
@@ -84,6 +84,11 @@ struct stk1160_buffer {
        unsigned int pos;               /* current pos inside buffer */
 };
 
+struct stk1160_urb {
+       struct urb *urb;
+       char *transfer_buffer;
+};
+
 struct stk1160_isoc_ctl {
        /* max packet size of isoc transaction */
        int max_pkt_size;
@@ -91,11 +96,7 @@ struct stk1160_isoc_ctl {
        /* number of allocated urbs */
        int num_bufs;
 
-       /* urb for isoc transfers */
-       struct urb **urb;
-
-       /* transfer buffers for isoc transfer */
-       char **transfer_buffer;
+       struct stk1160_urb urb_ctl[STK1160_NUM_BUFS];
 
        /* current buffer */
        struct stk1160_buffer *buf;