|
@@ -736,6 +736,7 @@ int usbnet_open (struct net_device *net)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ set_bit(EVENT_DEV_OPEN, &dev->flags);
|
|
|
netif_start_queue (net);
|
|
|
netif_info(dev, ifup, dev->net,
|
|
|
"open: enable queueing (rx %d, tx %d) mtu %d %s framing\n",
|
|
@@ -1259,6 +1260,9 @@ void usbnet_disconnect (struct usb_interface *intf)
|
|
|
if (dev->driver_info->unbind)
|
|
|
dev->driver_info->unbind (dev, intf);
|
|
|
|
|
|
+ usb_kill_urb(dev->interrupt);
|
|
|
+ usb_free_urb(dev->interrupt);
|
|
|
+
|
|
|
free_netdev(net);
|
|
|
usb_put_dev (xdev);
|
|
|
}
|
|
@@ -1498,6 +1502,10 @@ int usbnet_resume (struct usb_interface *intf)
|
|
|
int retval;
|
|
|
|
|
|
if (!--dev->suspend_count) {
|
|
|
+ /* resume interrupt URBs */
|
|
|
+ if (dev->interrupt && test_bit(EVENT_DEV_OPEN, &dev->flags))
|
|
|
+ usb_submit_urb(dev->interrupt, GFP_NOIO);
|
|
|
+
|
|
|
spin_lock_irq(&dev->txq.lock);
|
|
|
while ((res = usb_get_from_anchor(&dev->deferred))) {
|
|
|
|