diff options
author | Gerd Hoffmann <kraxel@redhat.com> | 2012-01-12 12:51:48 +0100 |
---|---|---|
committer | Gerd Hoffmann <kraxel@redhat.com> | 2012-02-10 11:31:57 +0100 |
commit | f53c398aa603cea135ee58fd15249aeff7b9c7ea (patch) | |
tree | b36b1a2b09a720a3d9e20a838914f3549cc90b16 /hw/usb.h | |
parent | 1977f93dacf60466cd23b562ae498446b77d3b48 (diff) | |
download | qemu-f53c398aa603cea135ee58fd15249aeff7b9c7ea.zip qemu-f53c398aa603cea135ee58fd15249aeff7b9c7ea.tar.gz qemu-f53c398aa603cea135ee58fd15249aeff7b9c7ea.tar.bz2 |
usb: USBPacket: add status, rename owner -> ep
Add enum to track the status of USBPackets, use that instead of the
owner pointer to figure whenever a usb packet is currently in flight
or not. Add some more packet status sanity checks. Also rename the
USBEndpoint pointer from "owner" to "ep".
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Diffstat (limited to 'hw/usb.h')
-rw-r--r-- | hw/usb.h | 19 |
1 files changed, 16 insertions, 3 deletions
@@ -289,8 +289,7 @@ typedef struct USBPortOps { void (*wakeup)(USBPort *port); /* * Note that port->dev will be different then the device from which - * the packet originated when a hub is involved, if you want the orginating - * device use p->owner + * the packet originated when a hub is involved. */ void (*complete)(USBPort *port, USBPacket *p); } USBPortOps; @@ -309,15 +308,24 @@ struct USBPort { typedef void USBCallback(USBPacket * packet, void *opaque); /* Structure used to hold information about an active USB packet. */ +typedef enum USBPacketState { + USB_PACKET_UNDEFINED = 0, + USB_PACKET_SETUP, + USB_PACKET_ASYNC, + USB_PACKET_COMPLETE, + USB_PACKET_CANCELED, +} USBPacketState; + struct USBPacket { /* Data fields for use by the driver. */ int pid; uint8_t devaddr; uint8_t devep; + USBEndpoint *ep; QEMUIOVector iov; int result; /* transfer length or USB_RET_* status code */ /* Internal use by the USB layer. */ - USBEndpoint *owner; + USBPacketState state; }; void usb_packet_init(USBPacket *p); @@ -329,6 +337,11 @@ void usb_packet_copy(USBPacket *p, void *ptr, size_t bytes); void usb_packet_skip(USBPacket *p, size_t bytes); void usb_packet_cleanup(USBPacket *p); +static inline bool usb_packet_is_inflight(USBPacket *p) +{ + return p->state == USB_PACKET_ASYNC; +} + USBDevice *usb_find_device(USBPort *port, uint8_t addr); int usb_handle_packet(USBDevice *dev, USBPacket *p); |