From: Martin Kelly Date: Tue, 5 Dec 2017 19:15:49 +0000 (-0800) Subject: can: kvaser_usb: cancel urb on -EPIPE and -EPROTO X-Git-Tag: v4.4.106~101 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=bd424bd1757291ba95c4c47f35ea5c955a4b3e42;p=thirdparty%2Fkernel%2Fstable.git can: kvaser_usb: cancel urb on -EPIPE and -EPROTO commit 6aa8d5945502baf4687d80de59b7ac865e9e666b upstream. In mcba_usb, we have observed that when you unplug the device, the driver will endlessly resubmit failing URBs, which can cause CPU stalls. This issue is fixed in mcba_usb by catching the codes seen on device disconnect (-EPIPE and -EPROTO). This driver also resubmits in the case of -EPIPE and -EPROTO, so fix it in the same way. Signed-off-by: Martin Kelly Signed-off-by: Marc Kleine-Budde Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/net/can/usb/kvaser_usb.c b/drivers/net/can/usb/kvaser_usb.c index 79422879f7541..db1855b0e08f2 100644 --- a/drivers/net/can/usb/kvaser_usb.c +++ b/drivers/net/can/usb/kvaser_usb.c @@ -1322,6 +1322,8 @@ static void kvaser_usb_read_bulk_callback(struct urb *urb) case 0: break; case -ENOENT: + case -EPIPE: + case -EPROTO: case -ESHUTDOWN: return; default: