diff options
author | Hans de Goede <hdegoede@redhat.com> | 2013-09-18 14:47:02 +0200 |
---|---|---|
committer | Hans de Goede <hdegoede@redhat.com> | 2013-10-07 18:14:12 +0200 |
commit | ea37e641f239b15a756572849fc46402dbacc6ad (patch) | |
tree | 015d5c86ca18299636f7e3f3f8eafd8c74119ca7 | |
parent | fdd69282bf4ffc66a625c42d0f32ace63ea08fe0 (diff) |
usb-host-libusb: Set stream id when submitting bulk-stream transfersstable-1.5
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
-rw-r--r-- | hw/usb/host-libusb.c | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/hw/usb/host-libusb.c b/hw/usb/host-libusb.c index 4e87e38aa..e049de879 100644 --- a/hw/usb/host-libusb.c +++ b/hw/usb/host-libusb.c @@ -1214,10 +1214,22 @@ static void usb_host_handle_data(USBDevice *udev, USBPacket *p) usb_packet_copy(p, r->buffer, size); } ep = p->ep->nr | (r->in ? USB_DIR_IN : 0); - libusb_fill_bulk_transfer(r->xfer, s->dh, ep, - r->buffer, size, - usb_host_req_complete_data, r, - BULK_TIMEOUT); + if (p->stream) { +#if LIBUSBX_API_VERSION >= 0x01000103 + libusb_fill_bulk_stream_transfer(r->xfer, s->dh, ep, p->stream, + r->buffer, size, + usb_host_req_complete_data, r, + BULK_TIMEOUT); +#else + usb_host_req_free(r); + return USB_RET_STALL; +#endif + } else { + libusb_fill_bulk_transfer(r->xfer, s->dh, ep, + r->buffer, size, + usb_host_req_complete_data, r, + BULK_TIMEOUT); + } break; case USB_ENDPOINT_XFER_INT: r = usb_host_req_alloc(s, p, p->pid == USB_TOKEN_IN, p->iov.size); |