From: David Ahern <daahern@cisco.com>
To: Gerd Hoffmann <kraxel@redhat.com>
Cc: qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [PATCH 12/18] usb-linux: split large xfers
Date: Mon, 16 May 2011 20:45:15 -0600 [thread overview]
Message-ID: <4DD1E13B.2010701@cisco.com> (raw)
In-Reply-To: <1305575782-31766-13-git-send-email-kraxel@redhat.com>
On 05/16/11 13:56, Gerd Hoffmann wrote:
> Add support for splitting large transfers into multiple smaller ones.
> This is needed for the upcoming EHCI emulation which allows guests
> to submit requests up to 20k in size. The linux kernel allows 16k
> max size though.
>
> Roughly based on a patch from git://git.kiszka.org/qemu.git ehci
More specifically:
http://www.mail-archive.com/qemu-devel@nongnu.org/msg30337.html
And "roughly based" is a bit of a stretch. The logic for handling 20k
requests in a 16k limit (the focus of this patch) came from the patch
above. This patch is a forward port based on changes made to the USB
code and some code movement.
David
>
> Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
> ---
> usb-linux.c | 68 +++++++++++++++++++++++++++++++++++++---------------------
> 1 files changed, 43 insertions(+), 25 deletions(-)
>
> diff --git a/usb-linux.c b/usb-linux.c
> index b8f7705..b95c119 100644
> --- a/usb-linux.c
> +++ b/usb-linux.c
> @@ -89,6 +89,9 @@ static int usb_fs_type;
> #define ISO_URB_COUNT 3
> #define INVALID_EP_TYPE 255
>
> +/* devio.c limits single requests to 16k */
> +#define MAX_USBFS_BUFFER_SIZE 16384
> +
> typedef struct AsyncURB AsyncURB;
>
> struct endp_data {
> @@ -229,6 +232,7 @@ struct AsyncURB
>
> /* For regular async urbs */
> USBPacket *packet;
> + int more; /* large transfer, more urbs follow */
>
> /* For buffered iso handling */
> int iso_frame_idx; /* -1 means in flight */
> @@ -291,7 +295,7 @@ static void async_complete(void *opaque)
> if (p) {
> switch (aurb->urb.status) {
> case 0:
> - p->len = aurb->urb.actual_length;
> + p->len += aurb->urb.actual_length;
> break;
>
> case -EPIPE:
> @@ -306,7 +310,7 @@ static void async_complete(void *opaque)
>
> if (aurb->urb.type == USBDEVFS_URB_TYPE_CONTROL) {
> usb_generic_async_ctrl_complete(&s->dev, p);
> - } else {
> + } else if (!aurb->more) {
> usb_packet_complete(&s->dev, p);
> }
> }
> @@ -646,7 +650,8 @@ static int usb_host_handle_data(USBDevice *dev, USBPacket *p)
> USBHostDevice *s = DO_UPCAST(USBHostDevice, dev, dev);
> struct usbdevfs_urb *urb;
> AsyncURB *aurb;
> - int ret;
> + int ret, rem;
> + uint8_t *pbuf;
> uint8_t ep;
>
> if (!is_valid(s, p->devep)) {
> @@ -673,32 +678,45 @@ static int usb_host_handle_data(USBDevice *dev, USBPacket *p)
> return usb_host_handle_iso_data(s, p, p->pid == USB_TOKEN_IN);
> }
>
> - aurb = async_alloc(s);
> - aurb->packet = p;
> + rem = p->len;
> + pbuf = p->data;
> + p->len = 0;
> + while (rem) {
> + aurb = async_alloc(s);
> + aurb->packet = p;
>
> - urb = &aurb->urb;
> + urb = &aurb->urb;
> + urb->endpoint = ep;
> + urb->type = USBDEVFS_URB_TYPE_BULK;
> + urb->usercontext = s;
> + urb->buffer = pbuf;
>
> - urb->endpoint = ep;
> - urb->buffer = p->data;
> - urb->buffer_length = p->len;
> - urb->type = USBDEVFS_URB_TYPE_BULK;
> - urb->usercontext = s;
> + if (rem > MAX_USBFS_BUFFER_SIZE) {
> + urb->buffer_length = MAX_USBFS_BUFFER_SIZE;
> + aurb->more = 1;
> + } else {
> + urb->buffer_length = rem;
> + aurb->more = 0;
> + }
> + pbuf += urb->buffer_length;
> + rem -= urb->buffer_length;
>
> - ret = ioctl(s->fd, USBDEVFS_SUBMITURB, urb);
> + ret = ioctl(s->fd, USBDEVFS_SUBMITURB, urb);
>
> - DPRINTF("husb: data submit. ep 0x%x len %u aurb %p\n",
> - urb->endpoint, p->len, aurb);
> + DPRINTF("husb: data submit: ep 0x%x, len %u, more %d, packet %p, aurb %p\n",
> + urb->endpoint, urb->buffer_length, aurb->more, p, aurb);
>
> - if (ret < 0) {
> - DPRINTF("husb: submit failed. errno %d\n", errno);
> - async_free(aurb);
> + if (ret < 0) {
> + DPRINTF("husb: submit failed. errno %d\n", errno);
> + async_free(aurb);
>
> - switch(errno) {
> - case ETIMEDOUT:
> - return USB_RET_NAK;
> - case EPIPE:
> - default:
> - return USB_RET_STALL;
> + switch(errno) {
> + case ETIMEDOUT:
> + return USB_RET_NAK;
> + case EPIPE:
> + default:
> + return USB_RET_STALL;
> + }
> }
> }
>
next prev parent reply other threads:[~2011-05-17 2:45 UTC|newest]
Thread overview: 46+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-05-16 19:56 [Qemu-devel] [PATCH 00/18] usb patch queue: add usb 2.0 Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 01/18] usb: Add Interface Association Descriptor descriptor type Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 02/18] usb: update config descriptors to identify number of interfaces Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 03/18] usb: remove fallback to bNumInterfaces if no .nif Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 04/18] usb: add support for "grouped" interfaces and the Interface Association Descriptor Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 05/18] Bug #757654: UHCI fails to signal stall response patch Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 06/18] usb: Pass the packet to the device's handle_control callback Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 07/18] usb-linux: use usb_generic_handle_packet() Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 08/18] usb-linux: fix device path aka physical port handling Gerd Hoffmann
2011-05-17 16:38 ` Markus Armbruster
2011-05-16 19:56 ` [Qemu-devel] [PATCH 09/18] usb-linux: add hostport property Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 10/18] usb-linux: track aurbs in list Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 11/18] usb-linux: walk async urb list in cancel Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 12/18] usb-linux: split large xfers Gerd Hoffmann
2011-05-17 2:45 ` David Ahern [this message]
2011-05-17 7:10 ` Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 13/18] usb-linux: fix max_packet_size for highspeed Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 14/18] usb: add usb_handle_packet Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 15/18] usb: keep track of packet owner Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 16/18] usb: move cancel callback to USBDeviceInfo Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 17/18] usb-storage: don't call usb_packet_complete twice Gerd Hoffmann
2011-05-16 19:56 ` [Qemu-devel] [PATCH 18/18] usb: add ehci adapter Gerd Hoffmann
2011-05-17 2:47 ` David Ahern
2011-05-17 7:20 ` Gerd Hoffmann
2011-05-17 12:42 ` David Ahern
2011-05-17 13:46 ` Gerd Hoffmann
2011-05-17 14:19 ` David Ahern
2011-05-17 14:36 ` Gerd Hoffmann
2011-05-17 17:15 ` Erik Rull
2011-05-17 13:52 ` David Ahern
2011-05-17 15:02 ` Gerd Hoffmann
2011-05-17 17:05 ` David Ahern
2011-05-17 17:36 ` Hans de Goede
2011-05-17 17:43 ` [Qemu-devel] USB streaming [Re: [PATCH 18/18] usb: add ehci adapter] David Ahern
2011-05-17 18:44 ` Hans de Goede
2011-05-17 19:10 ` David Ahern
2011-05-17 19:18 ` David Ahern
2011-05-18 8:25 ` Hans de Goede
2011-05-17 17:33 ` [Qemu-devel] [PATCH 18/18] usb: add ehci adapter Hans de Goede
2011-05-17 17:00 ` David Ahern
2011-05-17 20:39 ` Blue Swirl
2011-05-17 20:51 ` David Ahern
2011-05-21 10:34 ` Andreas Färber
2011-05-16 20:04 ` [Qemu-devel] [PATCH 00/18] usb patch queue: add usb 2.0 Anthony Liguori
2011-05-17 7:36 ` Gerd Hoffmann
-- strict thread matches above, loose matches on Subject: below --
2011-05-23 9:43 [Qemu-devel] [PULL] usb patch queue: initial usb 2.0 support Gerd Hoffmann
2011-05-23 9:43 ` [Qemu-devel] [PATCH 12/18] usb-linux: split large xfers Gerd Hoffmann
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4DD1E13B.2010701@cisco.com \
--to=daahern@cisco.com \
--cc=kraxel@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).