UPSTREAM: usb: dwc3: gadget: don't send extra ZLP
authorJohn Youn <John.Youn@synopsys.com>
Tue, 22 Dec 2015 20:23:20 +0000 (12:23 -0800)
committerWu Liang feng <wulf@rock-chips.com>
Sun, 6 Mar 2016 13:37:24 +0000 (21:37 +0800)
If the request->length is zero, a ZLP should already be sent due to that
and another ZLP is not needed to terminate the transfer.

Fixes: 04c03d10e507 ("usb: dwc3: gadget: handle request->zero")
Signed-off-by: John Youn <johnyoun@synopsys.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
(cherry picked from commit d9261898a4b2c143c28568dc686a1becfc637a99)

Change-Id: Ib976552f93321f6ea52d3f0151c66fd6f2db8b17
Signed-off-by: Wu Liang feng <wulf@rock-chips.com>
drivers/usb/dwc3/gadget.c

index 64b2a8303d33dd1d5220e238d9dedbd52937eeaf..af023a81a0b02160f85e4800594b49aa318190c2 100644 (file)
@@ -1203,7 +1203,8 @@ static int dwc3_gadget_ep_queue(struct usb_ep *ep, struct usb_request *request,
         * extra usb_request ourselves so that it gets handled the same way as
         * any other request.
         */
-       if (ret == 0 && request->zero && (request->length % ep->maxpacket == 0))
+       if (ret == 0 && request->zero && request->length &&
+           (request->length % ep->maxpacket == 0))
                ret = __dwc3_gadget_ep_queue_zlp(dwc, dep);
 
        spin_unlock_irqrestore(&dwc->lock, flags);