diff options
author | balrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-10-04 22:55:53 +0000 |
---|---|---|
committer | balrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-10-04 22:55:53 +0000 |
commit | 4d043a09007d4d06c07b941d881ee298a026961e (patch) | |
tree | 81ff339cc3f6f2bb05fb58cf29b664f624982463 /usb-linux.c | |
parent | b9dc033c0dea8e1113110a903799c5b31bb2104d (diff) | |
download | qemu-4d043a09007d4d06c07b941d881ee298a026961e.zip qemu-4d043a09007d4d06c07b941d881ee298a026961e.tar.gz qemu-4d043a09007d4d06c07b941d881ee298a026961e.tar.bz2 |
Quiet warnings introduced with the USB iso support.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3329 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'usb-linux.c')
-rw-r--r-- | usb-linux.c | 89 |
1 files changed, 46 insertions, 43 deletions
diff --git a/usb-linux.c b/usb-linux.c index 6de6e40..53d501d 100644 --- a/usb-linux.c +++ b/usb-linux.c @@ -84,9 +84,9 @@ typedef struct PendingURB { struct PendingURB *next; } PendingURB; -PendingURB *pending_urbs = NULL; +static PendingURB *pending_urbs = NULL; -int add_pending_urb(struct usbdevfs_urb *urb) +static int add_pending_urb(struct usbdevfs_urb *urb) { PendingURB *purb = qemu_mallocz(sizeof(PendingURB)); if (purb) { @@ -101,7 +101,7 @@ int add_pending_urb(struct usbdevfs_urb *urb) return 0; } -int del_pending_urb(struct usbdevfs_urb *urb) +static int del_pending_urb(struct usbdevfs_urb *urb) { PendingURB *purb = pending_urbs; PendingURB *prev = NULL; @@ -123,7 +123,8 @@ int del_pending_urb(struct usbdevfs_urb *urb) return 0; } -PendingURB *get_pending_urb(struct usbdevfs_urb *urb) +#ifdef USE_ASYNCIO +static PendingURB *get_pending_urb(struct usbdevfs_urb *urb) { PendingURB *purb = pending_urbs; @@ -136,6 +137,7 @@ PendingURB *get_pending_urb(struct usbdevfs_urb *urb) } return NULL; } +#endif static int usb_host_update_interfaces(USBHostDevice *dev, int configuration) { @@ -338,9 +340,46 @@ static int usb_host_handle_data(USBDevice *dev, USBPacket *p) } } -static void usb_linux_bh_cb(void *opaque); +#ifdef USE_ASYNCIO +static void usb_linux_bh_cb(void *opaque) +{ + PendingURB *pending_urb = (PendingURB *)opaque; + USBHostDevice *s = pending_urb->dev; + struct usbdevfs_urb *purb = NULL; + USBPacket *p = s->packet; + int ret; + + /* FIXME: handle purb->status */ + qemu_free(pending_urb->bh); + del_pending_urb(pending_urb->urb); + + if (!p) { + s->urbs_ready++; + return; + } + + ret = ioctl(s->fd, USBDEVFS_REAPURBNDELAY, &purb); + if (ret < 0) { + printf("usb_linux_bh_cb: REAPURBNDELAY ioctl=%d errno=%d\n", + ret, errno); + return; + } + +#ifdef DEBUG_ISOCH + if (purb == pending_urb->urb) { + printf("usb_linux_bh_cb: urb mismatch reaped=%p pending=%p\n", + purb, urb); + } +#endif + + p->len = purb->actual_length; + usb_packet_complete(p); + qemu_free(purb); + s->packet = NULL; +} -void isoch_done(int signum, siginfo_t *info, void *context) { +static void isoch_done(int signum, siginfo_t *info, void *context) +{ struct usbdevfs_urb *urb = (struct usbdevfs_urb *)info->si_addr; USBHostDevice *s = (USBHostDevice *)urb->usercontext; PendingURB *purb; @@ -360,6 +399,7 @@ void isoch_done(int signum, siginfo_t *info, void *context) { } } } +#endif static int usb_host_handle_isoch(USBDevice *dev, USBPacket *p) { @@ -447,43 +487,6 @@ static int usb_host_handle_isoch(USBDevice *dev, USBPacket *p) #endif } -static void usb_linux_bh_cb(void *opaque) -{ - PendingURB *pending_urb = (PendingURB *)opaque; - USBHostDevice *s = pending_urb->dev; - struct usbdevfs_urb *purb = NULL; - USBPacket *p = s->packet; - int ret; - - /* FIXME: handle purb->status */ - qemu_free(pending_urb->bh); - del_pending_urb(pending_urb->urb); - - if (!p) { - s->urbs_ready++; - return; - } - - ret = ioctl(s->fd, USBDEVFS_REAPURBNDELAY, &purb); - if (ret < 0) { - printf("usb_linux_bh_cb: REAPURBNDELAY ioctl=%d errno=%d\n", - ret, errno); - return; - } - -#ifdef DEBUG_ISOCH - if (purb == pending_urb->urb) { - printf("usb_linux_bh_cb: urb mismatch reaped=%p pending=%p\n", - purb, urb); - } -#endif - - p->len = purb->actual_length; - usb_packet_complete(p); - qemu_free(purb); - s->packet = NULL; -} - /* returns 1 on problem encountered or 0 for success */ static int usb_linux_update_endp_table(USBHostDevice *s) { |