]> git.proxmox.com Git - qemu.git/commitdiff
usb: fix interface initialization
authorGerd Hoffmann <kraxel@redhat.com>
Tue, 3 Jul 2012 08:15:08 +0000 (10:15 +0200)
committerGerd Hoffmann <kraxel@redhat.com>
Mon, 9 Jul 2012 09:59:55 +0000 (11:59 +0200)
zero is a valid interface number, so don't use it when resetting the
endpoints.

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
hw/usb.h
hw/usb/core.c

index 9cd2f896661986ba2c5f04e2b88cda0e769cb941..7ed8fb8fcf2dc6d94f3331dc988e6d21e267a17b 100644 (file)
--- a/hw/usb.h
+++ b/hw/usb.h
 #define USB_ENDPOINT_XFER_INT          3
 #define USB_ENDPOINT_XFER_INVALID     255
 
+#define USB_INTERFACE_INVALID         255
+
 typedef struct USBBus USBBus;
 typedef struct USBBusOps USBBusOps;
 typedef struct USBPort USBPort;
index fe15be064f4a8c353c2be90028ce0e9a7cd04b63..0614f76f4f1812887a810ce052613c873248c3eb 100644 (file)
@@ -566,8 +566,8 @@ void usb_ep_reset(USBDevice *dev)
         dev->ep_out[ep].pid = USB_TOKEN_OUT;
         dev->ep_in[ep].type = USB_ENDPOINT_XFER_INVALID;
         dev->ep_out[ep].type = USB_ENDPOINT_XFER_INVALID;
-        dev->ep_in[ep].ifnum = 0;
-        dev->ep_out[ep].ifnum = 0;
+        dev->ep_in[ep].ifnum = USB_INTERFACE_INVALID;
+        dev->ep_out[ep].ifnum = USB_INTERFACE_INVALID;
         dev->ep_in[ep].dev = dev;
         dev->ep_out[ep].dev = dev;
         dev->ep_in[ep].pipeline = false;