Commit 3d98867e authored by Greg Kroah-Hartman's avatar Greg Kroah-Hartman

USB: fix the usb media drivers due to interrupt urb no automatic resubmission...

USB: fix the usb media drivers due to interrupt urb no automatic resubmission change to the usb core.
parent a99fcb8a
...@@ -428,16 +428,37 @@ static void se401_auto_resetlevel(struct usb_se401 *se401) ...@@ -428,16 +428,37 @@ static void se401_auto_resetlevel(struct usb_se401 *se401)
static void se401_button_irq(struct urb *urb) static void se401_button_irq(struct urb *urb)
{ {
struct usb_se401 *se401 = urb->context; struct usb_se401 *se401 = urb->context;
int status;
if (!se401->dev) { if (!se401->dev) {
info("ohoh: device vapourished"); info("ohoh: device vapourished");
return; return;
} }
if (urb->actual_length >=2 && !urb->status) { switch (urb->status) {
case 0:
/* success */
break;
case -ECONNRESET:
case -ENOENT:
case -ESHUTDOWN:
/* this urb is terminated, clean up */
dbg("%s - urb shutting down with status: %d", __FUNCTION__, urb->status);
return;
default:
dbg("%s - nonzero urb status received: %d", __FUNCTION__, urb->status);
goto exit;
}
if (urb->actual_length >=2) {
if (se401->button) if (se401->button)
se401->buttonpressed=1; se401->buttonpressed=1;
} }
exit:
status = usb_submit_urb (urb, GFP_ATOMIC);
if (status)
err ("%s - usb_submit_urb failed with result %d",
__FUNCTION__, status);
} }
static void se401_video_irq(struct urb *urb) static void se401_video_irq(struct urb *urb)
......
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