usb-host: fix host close
authorGerd Hoffmann <kraxel@redhat.com>
Fri, 28 Oct 2011 14:13:50 +0000 (16:13 +0200)
committerGerd Hoffmann <kraxel@redhat.com>
Tue, 1 Nov 2011 15:38:36 +0000 (16:38 +0100)
The whole usb_host_close() function is skipped in case the device is not
in attached state.  This is wrong though, only then usb_device_detach()
must be skipped, all other cleanup (especially device reset and closing
the file handle) still needs to be done.  There are code paths where
usb_host_close() is called with the device in detached state already.

This fixes usb-host devices not being released and returned to the host
after removing them with device_del.

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
usb-linux.c

index 7d4d1d7bcf9ad8f70239df63fb47eaa00bb6d612..f086d57edbc774b7ed9ff2c5cea698259a46ca55 100644 (file)
@@ -1349,7 +1349,7 @@ static int usb_host_close(USBHostDevice *dev)
 {
     int i;
 
-    if (dev->fd == -1 || !dev->dev.attached) {
+    if (dev->fd == -1) {
         return -1;
     }
 
@@ -1367,7 +1367,9 @@ static int usb_host_close(USBHostDevice *dev)
     }
     async_complete(dev);
     dev->closing = 0;
-    usb_device_detach(&dev->dev);
+    if (dev->dev.attached) {
+        usb_device_detach(&dev->dev);
+    }
     ioctl(dev->fd, USBDEVFS_RESET);
     close(dev->fd);
     dev->fd = -1;