Commit 75bb93be authored by Fabian Vogt's avatar Fabian Vogt Committed by Greg Kroah-Hartman

fotg210-udc: Complete OUT requests on short packets

A short packet indicates the end of a transfer and marks the request as
complete.

Fixes: b84a8dee ("usb: gadget: add Faraday fotg210_udc driver")
Signed-off-by: default avatarFabian Vogt <fabian@ritter-vogt.de>
Link: https://lore.kernel.org/r/20210324141115.9384-8-fabian@ritter-vogt.deSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 3e7c2510
......@@ -849,12 +849,16 @@ static void fotg210_out_fifo_handler(struct fotg210_ep *ep)
{
struct fotg210_request *req = list_entry(ep->queue.next,
struct fotg210_request, queue);
int disgr1 = ioread32(ep->fotg210->reg + FOTG210_DISGR1);
fotg210_start_dma(ep, req);
/* finish out transfer */
/* Complete the request when it's full or a short packet arrived.
* Like other drivers, short_not_ok isn't handled.
*/
if (req->req.length == req->req.actual ||
req->req.actual < ep->ep.maxpacket)
(disgr1 & DISGR1_SPK_INT(ep->epnum - 1)))
fotg210_done(ep, req, 0);
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment