aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDean Anderson <dean@sensoray.com>2009-04-30 11:29:38 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2009-06-16 18:14:12 -0400
commitb02064caebd9b1d73dd29ebb6e75f487c5f0dbc5 (patch)
tree9bd96032a98801f2f29159c18da1996d0aa3bdf8
parent1fcbcc47d3ebd962f5486697cb85fd216e01cf89 (diff)
V4L/DVB (11738): patch: s2255drv: urb completion routine fixes
Error count in read pipe completion corrected. URB not resubmitted if shutting down. URB not freed in completion routine if new urb_submit_fails. (URB is freed on shutdown). Signed-off-by: Dean Anderson <dean@sensoray.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r--drivers/media/video/s2255drv.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/drivers/media/video/s2255drv.c b/drivers/media/video/s2255drv.c
index f08939c1f164..6be845ccc7d7 100644
--- a/drivers/media/video/s2255drv.c
+++ b/drivers/media/video/s2255drv.c
@@ -2281,8 +2281,10 @@ static void read_pipe_completion(struct urb *purb)
2281 return; 2281 return;
2282 } 2282 }
2283 status = purb->status; 2283 status = purb->status;
2284 if (status != 0) { 2284 /* if shutting down, do not resubmit, exit immediately */
2285 dprintk(2, "read_pipe_completion: err\n"); 2285 if (status == -ESHUTDOWN) {
2286 dprintk(2, "read_pipe_completion: err shutdown\n");
2287 pipe_info->err_count++;
2286 return; 2288 return;
2287 } 2289 }
2288 2290
@@ -2291,9 +2293,13 @@ static void read_pipe_completion(struct urb *purb)
2291 return; 2293 return;
2292 } 2294 }
2293 2295
2294 s2255_read_video_callback(dev, pipe_info); 2296 if (status == 0)
2297 s2255_read_video_callback(dev, pipe_info);
2298 else {
2299 pipe_info->err_count++;
2300 dprintk(1, "s2255drv: failed URB %d\n", status);
2301 }
2295 2302
2296 pipe_info->err_count = 0;
2297 pipe = usb_rcvbulkpipe(dev->udev, dev->read_endpoint); 2303 pipe = usb_rcvbulkpipe(dev->udev, dev->read_endpoint);
2298 /* reuse urb */ 2304 /* reuse urb */
2299 usb_fill_bulk_urb(pipe_info->stream_urb, dev->udev, 2305 usb_fill_bulk_urb(pipe_info->stream_urb, dev->udev,
@@ -2305,7 +2311,6 @@ static void read_pipe_completion(struct urb *purb)
2305 if (pipe_info->state != 0) { 2311 if (pipe_info->state != 0) {
2306 if (usb_submit_urb(pipe_info->stream_urb, GFP_KERNEL)) { 2312 if (usb_submit_urb(pipe_info->stream_urb, GFP_KERNEL)) {
2307 dev_err(&dev->udev->dev, "error submitting urb\n"); 2313 dev_err(&dev->udev->dev, "error submitting urb\n");
2308 usb_free_urb(pipe_info->stream_urb);
2309 } 2314 }
2310 } else { 2315 } else {
2311 dprintk(2, "read pipe complete state 0\n"); 2316 dprintk(2, "read pipe complete state 0\n");