提交 51977a8d 编写于 作者: J Jean-Francois Moine 提交者: Mauro Carvalho Chehab

V4L/DVB (8930): gspca: The image transfer by bulk is started by the subdrivers.

Signed-off-by: NJean-Francois Moine <moinejf@free.fr>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 7b537391
...@@ -185,7 +185,7 @@ static void bulk_irq(struct urb *urb ...@@ -185,7 +185,7 @@ static void bulk_irq(struct urb *urb
{ {
struct gspca_dev *gspca_dev = (struct gspca_dev *) urb->context; struct gspca_dev *gspca_dev = (struct gspca_dev *) urb->context;
struct gspca_frame *frame; struct gspca_frame *frame;
int j, ret; int j;
PDEBUG(D_PACK, "bulk irq"); PDEBUG(D_PACK, "bulk irq");
if (!gspca_dev->streaming) if (!gspca_dev->streaming)
...@@ -212,11 +212,6 @@ static void bulk_irq(struct urb *urb ...@@ -212,11 +212,6 @@ static void bulk_irq(struct urb *urb
urb->transfer_buffer, urb->transfer_buffer,
urb->actual_length); urb->actual_length);
} }
/* resubmit the URB */
urb->status = 0;
ret = usb_submit_urb(urb, GFP_ATOMIC);
if (ret < 0)
PDEBUG(D_ERR|D_PACK, "usb_submit_urb() ret %d", ret);
} }
/* /*
...@@ -502,13 +497,14 @@ static int create_urbs(struct gspca_dev *gspca_dev, ...@@ -502,13 +497,14 @@ static int create_urbs(struct gspca_dev *gspca_dev,
PDEBUG(D_STREAM, PDEBUG(D_STREAM,
"isoc %d pkts size %d = bsize:%d", "isoc %d pkts size %d = bsize:%d",
npkt, psize, bsize); npkt, psize, bsize);
nurbs = DEF_NURBS;
} else { } else {
npkt = 0; npkt = 0;
bsize = psize; bsize = psize;
PDEBUG(D_STREAM, "bulk bsize:%d", bsize); PDEBUG(D_STREAM, "bulk bsize:%d", bsize);
nurbs = 1;
} }
nurbs = DEF_NURBS;
gspca_dev->nurbs = nurbs; gspca_dev->nurbs = nurbs;
for (n = 0; n < nurbs; n++) { for (n = 0; n < nurbs; n++) {
urb = usb_alloc_urb(npkt, GFP_KERNEL); urb = usb_alloc_urb(npkt, GFP_KERNEL);
...@@ -583,6 +579,10 @@ static int gspca_init_transfer(struct gspca_dev *gspca_dev) ...@@ -583,6 +579,10 @@ static int gspca_init_transfer(struct gspca_dev *gspca_dev)
gspca_dev->streaming = 1; gspca_dev->streaming = 1;
atomic_set(&gspca_dev->nevent, 0); atomic_set(&gspca_dev->nevent, 0);
/* start the bulk transfer is done by the subdriver */
if (gspca_dev->bulk)
break;
/* submit the URBs */ /* submit the URBs */
for (n = 0; n < gspca_dev->nurbs; n++) { for (n = 0; n < gspca_dev->nurbs; n++) {
ret = usb_submit_urb(gspca_dev->urb[n], GFP_KERNEL); ret = usb_submit_urb(gspca_dev->urb[n], GFP_KERNEL);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册