提交 6d16d2e1 编写于 作者: H Hans Verkuil 提交者: Greg Kroah-Hartman

media: gspca: do not resubmit URBs when streaming has stopped

[ Upstream commit e6f8bd59c28f758feea403a70d6c3ef28c50959f ]

When streaming is stopped all URBs are killed, but in fill_frame and in
bulk_irq this results in an attempt to resubmit the killed URB. That is
not what you want and causes spurious kernel messages.

So check if streaming has stopped before resubmitting.

Also check against gspca_dev->streaming rather than vb2_start_streaming_called()
since vb2_start_streaming_called() will return true when in stop_streaming,
but gspca_dev->streaming is set to false when stop_streaming is called.

Fixes: 6992effe ("gspca: Kill all URBs before releasing any of them")
Signed-off-by: NHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: NMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Signed-off-by: NSasha Levin <sashal@kernel.org>
上级 acf41fb8
...@@ -314,6 +314,8 @@ static void fill_frame(struct gspca_dev *gspca_dev, ...@@ -314,6 +314,8 @@ static void fill_frame(struct gspca_dev *gspca_dev,
} }
resubmit: resubmit:
if (!gspca_dev->streaming)
return;
/* resubmit the URB */ /* resubmit the URB */
st = usb_submit_urb(urb, GFP_ATOMIC); st = usb_submit_urb(urb, GFP_ATOMIC);
if (st < 0) if (st < 0)
...@@ -330,7 +332,7 @@ static void isoc_irq(struct urb *urb) ...@@ -330,7 +332,7 @@ static void isoc_irq(struct urb *urb)
struct gspca_dev *gspca_dev = (struct gspca_dev *) urb->context; struct gspca_dev *gspca_dev = (struct gspca_dev *) urb->context;
gspca_dbg(gspca_dev, D_PACK, "isoc irq\n"); gspca_dbg(gspca_dev, D_PACK, "isoc irq\n");
if (!vb2_start_streaming_called(&gspca_dev->queue)) if (!gspca_dev->streaming)
return; return;
fill_frame(gspca_dev, urb); fill_frame(gspca_dev, urb);
} }
...@@ -344,7 +346,7 @@ static void bulk_irq(struct urb *urb) ...@@ -344,7 +346,7 @@ static void bulk_irq(struct urb *urb)
int st; int st;
gspca_dbg(gspca_dev, D_PACK, "bulk irq\n"); gspca_dbg(gspca_dev, D_PACK, "bulk irq\n");
if (!vb2_start_streaming_called(&gspca_dev->queue)) if (!gspca_dev->streaming)
return; return;
switch (urb->status) { switch (urb->status) {
case 0: case 0:
...@@ -367,6 +369,8 @@ static void bulk_irq(struct urb *urb) ...@@ -367,6 +369,8 @@ static void bulk_irq(struct urb *urb)
urb->actual_length); urb->actual_length);
resubmit: resubmit:
if (!gspca_dev->streaming)
return;
/* resubmit the URB */ /* resubmit the URB */
if (gspca_dev->cam.bulk_nurbs != 0) { if (gspca_dev->cam.bulk_nurbs != 0) {
st = usb_submit_urb(urb, GFP_ATOMIC); st = usb_submit_urb(urb, GFP_ATOMIC);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册