usb-redir: Notify our peer when we reject a device due to a speed mismatch
authorHans de Goede <hdegoede@redhat.com>
Fri, 30 Mar 2012 07:53:54 +0000 (09:53 +0200)
committerGerd Hoffmann <kraxel@redhat.com>
Tue, 17 Apr 2012 08:23:28 +0000 (10:23 +0200)
Also cleanup (reset) our device state when we reject a device due to a
speed mismatch.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
hw/usb/redirect.c

index 4288324..94ab463 100644 (file)
@@ -836,7 +836,13 @@ static void usbredir_do_attach(void *opaque)
 {
     USBRedirDevice *dev = opaque;
 
-    usb_device_attach(&dev->dev);
+    if (usb_device_attach(&dev->dev) != 0) {
+        usbredir_device_disconnect(dev);
+        if (usbredirparser_peer_has_cap(dev->parser, usb_redir_cap_filter)) {
+            usbredirparser_send_filter_reject(dev->parser);
+            usbredirparser_do_write(dev->parser);
+        }
+    }
 }
 
 /*