Skip to content
Snippets Groups Projects
Commit 8aac6e9c authored by Stephen Warren's avatar Stephen Warren Committed by Marek Vasut
Browse files

usb: ci_udc: set ep->req.actual after transfer


At least drivers/usb/gadget/storage_common.c expects that ep->req.actual
contain the number of bytes actually transferred. (At least in practice,
I observed it failing to work correctly unless this was the case).

However, ci_udc.c modifies ep->req.length instead. I assume that .length
 is supposed to represent the allocated buffer size, whereas .actual is
supposed to represent the actual number of bytes transferred. In the OUT
transaction case, this may happen simply because the host sends a smaller
 packet than the max possible size, which is quite legal. In the IN case,
transferring fewer bytes than requested could presumably happen as an
error.

Modify handle_ep_complete() to write to .actual rather than modifying
.length.

Signed-off-by: default avatarStephen Warren <swarren@nvidia.com>
parent f5c03006
No related branches found
No related tags found
No related merge requests found
...@@ -321,7 +321,7 @@ static void ci_debounce(struct ci_ep *ep, int in) ...@@ -321,7 +321,7 @@ static void ci_debounce(struct ci_ep *ep, int in)
if (addr == ba) if (addr == ba)
return; /* not a bounce */ return; /* not a bounce */
memcpy(ep->req.buf, ep->b_buf, ep->req.length); memcpy(ep->req.buf, ep->b_buf, ep->req.actual);
free: free:
/* Large payloads use allocated buffer, free it. */ /* Large payloads use allocated buffer, free it. */
if (ep->b_buf != ep->b_fast) if (ep->b_buf != ep->b_fast)
...@@ -388,7 +388,7 @@ static void handle_ep_complete(struct ci_ep *ep) ...@@ -388,7 +388,7 @@ static void handle_ep_complete(struct ci_ep *ep)
num, in ? "in" : "out", item->info, item->page0); num, in ? "in" : "out", item->info, item->page0);
len = (item->info >> 16) & 0x7fff; len = (item->info >> 16) & 0x7fff;
ep->req.length -= len; ep->req.actual = ep->req.length - len;
ci_debounce(ep, in); ci_debounce(ep, in);
DBG("ept%d %s complete %x\n", DBG("ept%d %s complete %x\n",
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment