[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date: Mon, 11 Nov 2013 22:09:55 +0100
From: Michal Nazarewicz <mina86@...a86.com>
To: Alan Stern <stern@...land.harvard.edu>
Cc: David Cohen <david.a.cohen@...ux.intel.com>,
linux-usb@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCHv2 2/2] check quirk to pad epout buf size when not aligned to maxpacketsize
On Mon, Nov 11 2013, Alan Stern wrote:
> On Mon, 11 Nov 2013, Michal Nazarewicz wrote:
>
>> Check gadget.quirk_ep_out_aligned_size to decide if buffer size requires
>> to be aligned to maxpacketsize of an out endpoint. ffs_epfile_io() needs
>> to pad epout buffer to match above condition if quirk is found.
>>
>> Signed-off-by: Michal Nazarewicz <mina86@...a86.com>
>
> I think this is still wrong.
>
>> @@ -824,7 +832,7 @@ static ssize_t ffs_epfile_io(struct file *file,
>> req->context = &done;
>> req->complete = ffs_epfile_io_complete;
>> req->buf = data;
>> - req->length = len;
>> + req->length = data_len;
>
> IIUC, req->length should still be set to len, not to data_len.
>
>>
>> ret = usb_ep_queue(ep->ep, req, GFP_ATOMIC);
>>
>> @@ -836,9 +844,16 @@ static ssize_t ffs_epfile_io(struct file *file,
>> ret = -EINTR;
>> usb_ep_dequeue(ep->ep, req);
>> } else {
>> + /*
>> + * XXX We may end up silently droping data here.
>> + * Since data_len (i.e. req->length) may be bigger
>> + * than len (after being rounded up to maxpacketsize),
>> + * we may end up with more data then user space has
>> + * space for.
>> + */
>
> Then this will never come up. If the host sends a packet that's too
> long, you'll get a -EOVERFLOW error.
>
>> ret = ep->status;
>> if (read && ret > 0 &&
>> - unlikely(copy_to_user(buf, data, ret)))
>> + unlikely(copy_to_user(buf, data, min(ret, len))))
>> ret = -EFAULT;
>> }
>> }
>
> The reason for the quirk is that the controller may write all the
> incoming data to the buffer, even if this is more data than the driver
> requested.
If that's the case, then it indeed solves the problem of silently
throwing away data. I guess it makes more sense then my understanding
of the quirk.
--
Best regards, _ _
.o. | Liege of Serenely Enlightened Majesty of o' \,=./ `o
..o | Computer Science, Michał “mina86” Nazarewicz (o o)
ooo +--<mpn@...gle.com>--<xmpp:mina86@...ber.org>--ooO--(_)--Ooo--
Download attachment "signature.asc" of type "application/pgp-signature" (836 bytes)
Powered by blists - more mailing lists