summaryrefslogtreecommitdiffstats
path: root/drivers/usb/misc
diff options
context:
space:
mode:
authorAndiry Xu <andiry.xu@amd.com>2010-08-09 13:56:15 -0700
committerGreg Kroah-Hartman <gregkh@suse.de>2010-08-23 20:50:16 -0700
commit14184f9b8047026f1812f49df074e89dad3a09bc (patch)
tree5492adad4d8ce5d263abbdad713c13a35b08202c /drivers/usb/misc
parenta1669b2c64a9c8b031e0ac5cbf2692337a577f7c (diff)
downloadtalos-op-linux-14184f9b8047026f1812f49df074e89dad3a09bc.tar.gz
talos-op-linux-14184f9b8047026f1812f49df074e89dad3a09bc.zip
USB: xHCI: update ring dequeue pointer when process missed tds
This patch fixes a isoc transfer bug reported by Sander Eikelenboom. When ep->skip is set, endpoint ring dequeue pointer should be updated when processed every missed td. Although ring dequeue pointer will also be updated when ep->skip is clear, leave it intact during missed tds processing may cause two issues: 1). If the very next valid transfer following missed tds is a short transfer, its actual_length will be miscalculated; 2). If there are too many missed tds during transfer, new inserted tds may found the transfer ring full and urb enqueue fails. Reported-by: Sander Eikelenboom <linux@eikelenboom.it> Tested-by: Sander Eikelenboom <linux@eikelenboom.it> Signed-off-by: Andiry Xu <andiry.xu@amd.com> Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/misc')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud