summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul Zimmerman <Paul.Zimmerman@synopsys.com>2012-02-25 02:32:15 +0100
committerFelipe Balbi <balbi@ti.com>2012-03-02 11:12:09 +0100
commitaee63e3cb6b0396b99c6387a47cb90a7417f3957 (patch)
tree76468eed5464d6fca184f725467060518d23b5cd
parentusb: dwc3: pci: fix failure path in dwc3_pci_probe() (diff)
downloadlinux-aee63e3cb6b0396b99c6387a47cb90a7417f3957.tar.xz
linux-aee63e3cb6b0396b99c6387a47cb90a7417f3957.zip
usb: dwc3: shorten long delay in dwc3_gadget_set_link_state()
The loop in dwc3_gadget_set_link_state() was using a udelay(500), which is a long time to delay in interrupt context. Change it to udelay(5) and increase the loop count to match. Signed-off-by: Paul Zimmerman <paulz@synopsys.com> Signed-off-by: Felipe Balbi <balbi@ti.com>
-rw-r--r--drivers/usb/dwc3/gadget.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c
index fac11491850f..e2633dd03f8c 100644
--- a/drivers/usb/dwc3/gadget.c
+++ b/drivers/usb/dwc3/gadget.c
@@ -95,11 +95,11 @@ int dwc3_gadget_set_test_mode(struct dwc3 *dwc, int mode)
* @state: the state to put link into
*
* Caller should take care of locking. This function will
- * return 0 on success or -EINVAL.
+ * return 0 on success or -ETIMEDOUT.
*/
int dwc3_gadget_set_link_state(struct dwc3 *dwc, enum dwc3_link_state state)
{
- int retries = 100;
+ int retries = 10000;
u32 reg;
reg = dwc3_readl(dwc->regs, DWC3_DCTL);
@@ -113,11 +113,10 @@ int dwc3_gadget_set_link_state(struct dwc3 *dwc, enum dwc3_link_state state)
while (--retries) {
reg = dwc3_readl(dwc->regs, DWC3_DSTS);
- /* in HS, means ON */
if (DWC3_DSTS_USBLNKST(reg) == state)
return 0;
- udelay(500);
+ udelay(5);
}
dev_vdbg(dwc->dev, "link state change request timed out\n");