usb: s3c-otg: Fix short packet for request size > ep.maxpacket
authorRoger Quadros <rogerq@ti.com>
Tue, 19 Apr 2016 12:20:39 +0000 (15:20 +0300)
committerMarek Vasut <marex@denx.de>
Mon, 25 Apr 2016 15:56:30 +0000 (17:56 +0200)
Request size can be greater than ep.packet and still end in a
short packet. We need to tackle this case as end of transfer
(if short_not_ok is not set) as indicated in USB 2.0 Specification [1],
else we get stuck up on certain protocols like fastboot.

[1] - USB2.0 Specification, Section 5.3.2 Pipes

Reported-by: Steve Rae <steve.rae@broadcom.com>
Signed-off-by: Roger Quadros <rogerq@ti.com>
Tested-by: Steve Rae <steve.rae@broadcom.com>
Tested-by: Lukasz Majewski <l.majewski@samsung.com>
drivers/usb/gadget/dwc2_udc_otg_xfer_dma.c

index bce9c30ef610a74c19ab9fb3f7065dba5b22de08..9aa0f338104900291048fc5ba35e33c4b85da612 100644 (file)
@@ -229,7 +229,7 @@ static void complete_rx(struct dwc2_udc *dev, u8 ep_num)
                                ROUND(xfer_size, CONFIG_SYS_CACHELINE_SIZE));
 
        req->req.actual += min(xfer_size, req->req.length - req->req.actual);
-       is_short = (xfer_size < ep->ep.maxpacket);
+       is_short = !!(xfer_size % ep->ep.maxpacket);
 
        debug_cond(DEBUG_OUT_EP != 0,
                   "%s: RX DMA done : ep = %d, rx bytes = %d/%d, "