aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/dwc3
diff options
context:
space:
mode:
authorPratyush Anand <pratyush.anand@st.com>2012-07-02 00:51:55 -0400
committerFelipe Balbi <balbi@ti.com>2012-07-02 03:04:02 -0400
commit6f17f74b3d8345663f5fcfd834145685110075bd (patch)
tree6c9ded5a65bc3d6a2c4930f677863273d3cb976e /drivers/usb/dwc3
parente274a31e29b6a097c32f526493f4ebce10856dcb (diff)
usb: dwc3: return error in case of run/stop timeout
Although timeout has never been experienced, still to make it meaningful, its better to return error if it ever occurs. Signed-off-by: Pratyush Anand <pratyush.anand@st.com> Signed-off-by: Felipe Balbi <balbi@ti.com>
Diffstat (limited to 'drivers/usb/dwc3')
-rw-r--r--drivers/usb/dwc3/gadget.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c
index 39626e366a82..aedc1c5cfac1 100644
--- a/drivers/usb/dwc3/gadget.c
+++ b/drivers/usb/dwc3/gadget.c
@@ -1408,7 +1408,7 @@ static int dwc3_gadget_set_selfpowered(struct usb_gadget *g,
1408 return 0; 1408 return 0;
1409} 1409}
1410 1410
1411static void dwc3_gadget_run_stop(struct dwc3 *dwc, int is_on) 1411static int dwc3_gadget_run_stop(struct dwc3 *dwc, int is_on)
1412{ 1412{
1413 u32 reg; 1413 u32 reg;
1414 u32 timeout = 500; 1414 u32 timeout = 500;
@@ -1440,7 +1440,7 @@ static void dwc3_gadget_run_stop(struct dwc3 *dwc, int is_on)
1440 } 1440 }
1441 timeout--; 1441 timeout--;
1442 if (!timeout) 1442 if (!timeout)
1443 break; 1443 return -ETIMEDOUT;
1444 udelay(1); 1444 udelay(1);
1445 } while (1); 1445 } while (1);
1446 1446
@@ -1448,20 +1448,23 @@ static void dwc3_gadget_run_stop(struct dwc3 *dwc, int is_on)
1448 dwc->gadget_driver 1448 dwc->gadget_driver
1449 ? dwc->gadget_driver->function : "no-function", 1449 ? dwc->gadget_driver->function : "no-function",
1450 is_on ? "connect" : "disconnect"); 1450 is_on ? "connect" : "disconnect");
1451
1452 return 0;
1451} 1453}
1452 1454
1453static int dwc3_gadget_pullup(struct usb_gadget *g, int is_on) 1455static int dwc3_gadget_pullup(struct usb_gadget *g, int is_on)
1454{ 1456{
1455 struct dwc3 *dwc = gadget_to_dwc(g); 1457 struct dwc3 *dwc = gadget_to_dwc(g);
1456 unsigned long flags; 1458 unsigned long flags;
1459 int ret;
1457 1460
1458 is_on = !!is_on; 1461 is_on = !!is_on;
1459 1462
1460 spin_lock_irqsave(&dwc->lock, flags); 1463 spin_lock_irqsave(&dwc->lock, flags);
1461 dwc3_gadget_run_stop(dwc, is_on); 1464 ret = dwc3_gadget_run_stop(dwc, is_on);
1462 spin_unlock_irqrestore(&dwc->lock, flags); 1465 spin_unlock_irqrestore(&dwc->lock, flags);
1463 1466
1464 return 0; 1467 return ret;
1465} 1468}
1466 1469
1467static int dwc3_gadget_start(struct usb_gadget *g, 1470static int dwc3_gadget_start(struct usb_gadget *g,