usb: dwc3: gadget: Fix starting microframe for ISOC
authorJohn Youn <John.Youn@synopsys.com>
Thu, 26 Jan 2017 19:58:40 +0000 (11:58 -0800)
committerFelipe Balbi <felipe.balbi@linux.intel.com>
Tue, 11 Apr 2017 07:58:19 +0000 (10:58 +0300)
The gadget wants to set the starting microframe for the first ISOC TRB
to 4 microframes in the future, but it does so by multiplying the
dep->interval. This only works if dep->interval = 1. For other intervals
it will put it 4 *intervals* in the future which may be way too much.

Fix so that it always adds just one interval or at least 4 microframes.

Signed-off-by: John Youn <johnyoun@synopsys.com>
Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
drivers/usb/dwc3/gadget.c

index 1a90877f8b96e88ca3fa7b93a3992b10c9e1344f..640e4aa5482d66a1f3e434b9aacd45778dc1c095 100644 (file)
@@ -1184,8 +1184,11 @@ static void __dwc3_gadget_start_isoc(struct dwc3 *dwc,
                return;
        }
 
-       /* 4 micro frames in the future */
-       uf = cur_uf + dep->interval * 4;
+       /*
+        * Schedule the first trb for one interval in the future or at
+        * least 4 microframes.
+        */
+       uf = cur_uf + max_t(u32, 4, dep->interval);
 
        __dwc3_gadget_kick_transfer(dep, uf);
 }