Commit 69fd04d0 authored by Dafna Hirschfeld's avatar Dafna Hirschfeld Committed by Mauro Carvalho Chehab

media: stk1160: move transfer_buffer and urb to same struct 'stk1160_urb'

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: default avatarDafna Hirschfeld <dafna.hirschfeld@collabora.com>
Reviewed-by: default avatarEzequiel Garcia <ezequiel@vanguardiasur.com.ar>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent fbe04b49
...@@ -232,7 +232,7 @@ static int stk1160_start_streaming(struct stk1160 *dev) ...@@ -232,7 +232,7 @@ static int stk1160_start_streaming(struct stk1160 *dev)
/* submit urbs and enables IRQ */ /* submit urbs and enables IRQ */
for (i = 0; i < dev->isoc_ctl.num_bufs; i++) { 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) { if (rc) {
stk1160_err("cannot submit urb[%d] (%d)\n", i, rc); stk1160_err("cannot submit urb[%d] (%d)\n", i, rc);
goto out_uninit; goto out_uninit;
......
...@@ -347,7 +347,7 @@ void stk1160_cancel_isoc(struct stk1160 *dev) ...@@ -347,7 +347,7 @@ void stk1160_cancel_isoc(struct stk1160 *dev)
* We don't care for NULL pointer since * We don't care for NULL pointer since
* usb_kill_urb allows it. * 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"); stk1160_dbg("all urbs killed\n");
...@@ -366,30 +366,25 @@ void stk1160_free_isoc(struct stk1160 *dev) ...@@ -366,30 +366,25 @@ void stk1160_free_isoc(struct stk1160 *dev)
for (i = 0; i < num_bufs; i++) { for (i = 0; i < num_bufs; i++) {
urb = dev->isoc_ctl.urb[i]; urb = dev->isoc_ctl.urb_ctl[i].urb;
if (urb) { if (urb) {
if (dev->isoc_ctl.transfer_buffer[i]) { if (dev->isoc_ctl.urb_ctl[i].transfer_buffer) {
#ifndef CONFIG_DMA_NONCOHERENT #ifndef CONFIG_DMA_NONCOHERENT
usb_free_coherent(dev->udev, usb_free_coherent(dev->udev,
urb->transfer_buffer_length, urb->transfer_buffer_length,
dev->isoc_ctl.transfer_buffer[i], dev->isoc_ctl.urb_ctl[i].transfer_buffer,
urb->transfer_dma); urb->transfer_dma);
#else #else
kfree(dev->isoc_ctl.transfer_buffer[i]); kfree(dev->isoc_ctl.urb_ctl[i].transfer_buffer);
#endif #endif
} }
usb_free_urb(urb); 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; dev->isoc_ctl.num_bufs = 0;
stk1160_dbg("all urb buffers freed\n"); stk1160_dbg("all urb buffers freed\n");
...@@ -429,19 +424,6 @@ int stk1160_alloc_isoc(struct stk1160 *dev) ...@@ -429,19 +424,6 @@ int stk1160_alloc_isoc(struct stk1160 *dev)
dev->isoc_ctl.buf = NULL; dev->isoc_ctl.buf = NULL;
dev->isoc_ctl.max_pkt_size = dev->max_pkt_size; 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 */ /* allocate urbs and transfer buffers */
for (i = 0; i < num_bufs; i++) { for (i = 0; i < num_bufs; i++) {
...@@ -449,15 +431,17 @@ int stk1160_alloc_isoc(struct stk1160 *dev) ...@@ -449,15 +431,17 @@ int stk1160_alloc_isoc(struct stk1160 *dev)
urb = usb_alloc_urb(max_packets, GFP_KERNEL); urb = usb_alloc_urb(max_packets, GFP_KERNEL);
if (!urb) if (!urb)
goto free_i_bufs; goto free_i_bufs;
dev->isoc_ctl.urb[i] = urb; dev->isoc_ctl.urb_ctl[i].urb = urb;
#ifndef CONFIG_DMA_NONCOHERENT #ifndef CONFIG_DMA_NONCOHERENT
dev->isoc_ctl.transfer_buffer[i] = usb_alloc_coherent(dev->udev, dev->isoc_ctl.urb_ctl[i].transfer_buffer =
sb_size, GFP_KERNEL, &urb->transfer_dma); usb_alloc_coherent(dev->udev, sb_size, GFP_KERNEL,
&urb->transfer_dma);
#else #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 #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", stk1160_err("cannot alloc %d bytes for tx[%d] buffer\n",
sb_size, i); sb_size, i);
...@@ -466,14 +450,14 @@ int stk1160_alloc_isoc(struct stk1160 *dev) ...@@ -466,14 +450,14 @@ int stk1160_alloc_isoc(struct stk1160 *dev)
goto free_i_bufs; goto free_i_bufs;
goto nomore_tx_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? * FIXME: Where can I get the endpoint?
*/ */
urb->dev = dev->udev; urb->dev = dev->udev;
urb->pipe = usb_rcvisocpipe(dev->udev, STK1160_EP_VIDEO); 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->transfer_buffer_length = sb_size;
urb->complete = stk1160_isoc_irq; urb->complete = stk1160_isoc_irq;
urb->context = dev; urb->context = dev;
...@@ -508,8 +492,8 @@ int stk1160_alloc_isoc(struct stk1160 *dev) ...@@ -508,8 +492,8 @@ int stk1160_alloc_isoc(struct stk1160 *dev)
* enough to work fine, so we just free the extra urb, * enough to work fine, so we just free the extra urb,
* store the allocated count and keep going, fingers crossed! * store the allocated count and keep going, fingers crossed!
*/ */
usb_free_urb(dev->isoc_ctl.urb[i]); usb_free_urb(dev->isoc_ctl.urb_ctl[i].urb);
dev->isoc_ctl.urb[i] = NULL; dev->isoc_ctl.urb_ctl[i].urb = NULL;
stk1160_warn("%d urbs allocated. Trying to continue...\n", i); stk1160_warn("%d urbs allocated. Trying to continue...\n", i);
......
...@@ -84,6 +84,11 @@ struct stk1160_buffer { ...@@ -84,6 +84,11 @@ struct stk1160_buffer {
unsigned int pos; /* current pos inside buffer */ unsigned int pos; /* current pos inside buffer */
}; };
struct stk1160_urb {
struct urb *urb;
char *transfer_buffer;
};
struct stk1160_isoc_ctl { struct stk1160_isoc_ctl {
/* max packet size of isoc transaction */ /* max packet size of isoc transaction */
int max_pkt_size; int max_pkt_size;
...@@ -91,11 +96,7 @@ struct stk1160_isoc_ctl { ...@@ -91,11 +96,7 @@ struct stk1160_isoc_ctl {
/* number of allocated urbs */ /* number of allocated urbs */
int num_bufs; int num_bufs;
/* urb for isoc transfers */ struct stk1160_urb urb_ctl[STK1160_NUM_BUFS];
struct urb **urb;
/* transfer buffers for isoc transfer */
char **transfer_buffer;
/* current buffer */ /* current buffer */
struct stk1160_buffer *buf; struct stk1160_buffer *buf;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment