summaryrefslogtreecommitdiffstats
path: root/drivers/usb/musb/jz4740.c
diff options
context:
space:
mode:
authorFelipe Balbi <felipe.balbi@linux.intel.com>2017-02-17 10:12:44 +0100
committerFelipe Balbi <felipe.balbi@linux.intel.com>2017-03-06 09:09:37 +0100
commitcf3113d893d4427b166ec8695460efa7aa660923 (patch)
tree17aec6d6e8f05d453cd4a7547052e0bbeab3e87c /drivers/usb/musb/jz4740.c
parentusb: gadget: function: f_fs: pass companion descriptor along (diff)
downloadlinux-cf3113d893d4427b166ec8695460efa7aa660923.tar.xz
linux-cf3113d893d4427b166ec8695460efa7aa660923.zip
usb: dwc3: gadget: properly increment dequeue pointer on ep_dequeue
If request was already started, this means we had to stop the transfer. With that we also need to ignore all TRBs used by the request, however TRBs can only be modified after completion of END_TRANSFER command. So what we have to do here is wait for END_TRANSFER completion and only after that jump over TRBs by clearing HWO and incrementing dequeue pointer. Note that we have 2 possible types of transfers here: i) Linear buffer request ii) SG-list based request SG-list based requests will have r->num_pending_sgs set to a valid number (> 0). Linear requests, normally use a single TRB. For each of these two cases, if r->unaligned flag is set, one extra TRB has been used to align transfer size to wMaxPacketSize. All of these cases need to be taken into consideration so we don't mess up our TRB ring pointers. Tested-by: Janusz Dziedzic <januszx.dziedzic@intel.com> Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
Diffstat (limited to 'drivers/usb/musb/jz4740.c')
0 files changed, 0 insertions, 0 deletions