usb: dwc3: gadget: fixing dequeue of TRBs
authorSebastian Andrzej Siewior <bigeasy@linutronix.de>
Fri, 19 Aug 2011 17:59:12 +0000 (19:59 +0200)
committerFelipe Balbi <balbi@ti.com>
Fri, 9 Sep 2011 10:01:54 +0000 (13:01 +0300)
A TRB which is dequeued seems to have its HWO bits set to 1. Therefore
we ignore it if we dequeue it after the command is completed.

Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: Felipe Balbi <balbi@ti.com>
drivers/usb/dwc3/gadget.c

index cebaef7..56f0e46 100644 (file)
@@ -1309,11 +1309,17 @@ static int dwc3_cleanup_done_reqs(struct dwc3 *dwc, struct dwc3_ep *dep,
 
                dwc3_trb_to_nat(req->trb, &trb);
 
-               if (trb.hwo) {
+               if (trb.hwo && status != -ESHUTDOWN)
+                       /*
+                        * We continue despite the error. There is not much we
+                        * can do. If we don't clean in up we loop for ever. If
+                        * we skip the TRB than it gets overwritten reused after
+                        * a while since we use them in a ring buffer. a BUG()
+                        * would help. Lets hope that if this occures, someone
+                        * fixes the root cause instead of looking away :)
+                        */
                        dev_err(dwc->dev, "%s's TRB (%p) still owned by HW\n",
                                        dep->name, req->trb);
-                       continue;
-               }
                count = trb.length;
 
                if (dep->direction) {