|
@@ -106,6 +106,7 @@ static struct usb_device_id blacklist_table[] = {
|
|
/* Atheros 3011 with sflash firmware */
|
|
/* Atheros 3011 with sflash firmware */
|
|
{ USB_DEVICE(0x0cf3, 0x3002), .driver_info = BTUSB_IGNORE },
|
|
{ USB_DEVICE(0x0cf3, 0x3002), .driver_info = BTUSB_IGNORE },
|
|
{ USB_DEVICE(0x13d3, 0x3304), .driver_info = BTUSB_IGNORE },
|
|
{ USB_DEVICE(0x13d3, 0x3304), .driver_info = BTUSB_IGNORE },
|
|
|
|
+ { USB_DEVICE(0x0930, 0x0215), .driver_info = BTUSB_IGNORE },
|
|
|
|
|
|
/* Atheros AR9285 Malbec with sflash firmware */
|
|
/* Atheros AR9285 Malbec with sflash firmware */
|
|
{ USB_DEVICE(0x03f0, 0x311d), .driver_info = BTUSB_IGNORE },
|
|
{ USB_DEVICE(0x03f0, 0x311d), .driver_info = BTUSB_IGNORE },
|
|
@@ -256,7 +257,9 @@ static void btusb_intr_complete(struct urb *urb)
|
|
|
|
|
|
err = usb_submit_urb(urb, GFP_ATOMIC);
|
|
err = usb_submit_urb(urb, GFP_ATOMIC);
|
|
if (err < 0) {
|
|
if (err < 0) {
|
|
- if (err != -EPERM)
|
|
|
|
|
|
+ /* -EPERM: urb is being killed;
|
|
|
|
+ * -ENODEV: device got disconnected */
|
|
|
|
+ if (err != -EPERM && err != -ENODEV)
|
|
BT_ERR("%s urb %p failed to resubmit (%d)",
|
|
BT_ERR("%s urb %p failed to resubmit (%d)",
|
|
hdev->name, urb, -err);
|
|
hdev->name, urb, -err);
|
|
usb_unanchor_urb(urb);
|
|
usb_unanchor_urb(urb);
|
|
@@ -341,7 +344,9 @@ static void btusb_bulk_complete(struct urb *urb)
|
|
|
|
|
|
err = usb_submit_urb(urb, GFP_ATOMIC);
|
|
err = usb_submit_urb(urb, GFP_ATOMIC);
|
|
if (err < 0) {
|
|
if (err < 0) {
|
|
- if (err != -EPERM)
|
|
|
|
|
|
+ /* -EPERM: urb is being killed;
|
|
|
|
+ * -ENODEV: device got disconnected */
|
|
|
|
+ if (err != -EPERM && err != -ENODEV)
|
|
BT_ERR("%s urb %p failed to resubmit (%d)",
|
|
BT_ERR("%s urb %p failed to resubmit (%d)",
|
|
hdev->name, urb, -err);
|
|
hdev->name, urb, -err);
|
|
usb_unanchor_urb(urb);
|
|
usb_unanchor_urb(urb);
|
|
@@ -431,7 +436,9 @@ static void btusb_isoc_complete(struct urb *urb)
|
|
|
|
|
|
err = usb_submit_urb(urb, GFP_ATOMIC);
|
|
err = usb_submit_urb(urb, GFP_ATOMIC);
|
|
if (err < 0) {
|
|
if (err < 0) {
|
|
- if (err != -EPERM)
|
|
|
|
|
|
+ /* -EPERM: urb is being killed;
|
|
|
|
+ * -ENODEV: device got disconnected */
|
|
|
|
+ if (err != -EPERM && err != -ENODEV)
|
|
BT_ERR("%s urb %p failed to resubmit (%d)",
|
|
BT_ERR("%s urb %p failed to resubmit (%d)",
|
|
hdev->name, urb, -err);
|
|
hdev->name, urb, -err);
|
|
usb_unanchor_urb(urb);
|
|
usb_unanchor_urb(urb);
|