diff options
author | Felipe Balbi <balbi@ti.com> | 2013-06-27 03:00:18 -0400 |
---|---|---|
committer | Felipe Balbi <balbi@ti.com> | 2013-07-29 06:56:39 -0400 |
commit | b0d7ffd44ba9cd2dfbf299674418193a5f9ed21a (patch) | |
tree | f94aa3f515255204fab472d80814e1fd8ead1d1e | |
parent | 2b0c49530bc5fdbde93295e5c8f26f55d0de1e04 (diff) |
usb: dwc3: gadget: don't request IRQs in atomic
We cannot request an IRQ with spinlocks held
as that would trigger a sleeping inside
spinlock warning.
Cc: <stable@vger.kernel.org> # v3.10
Reported-by: Stephen Boyd <sboyd@codeaurora.org>
Signed-off-by: Felipe Balbi <balbi@ti.com>
-rw-r--r-- | drivers/usb/dwc3/gadget.c | 39 |
1 files changed, 22 insertions, 17 deletions
diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c index f77083fedc68..14d28d6184f6 100644 --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c | |||
@@ -1508,6 +1508,15 @@ static int dwc3_gadget_start(struct usb_gadget *g, | |||
1508 | int irq; | 1508 | int irq; |
1509 | u32 reg; | 1509 | u32 reg; |
1510 | 1510 | ||
1511 | irq = platform_get_irq(to_platform_device(dwc->dev), 0); | ||
1512 | ret = request_threaded_irq(irq, dwc3_interrupt, dwc3_thread_interrupt, | ||
1513 | IRQF_SHARED | IRQF_ONESHOT, "dwc3", dwc); | ||
1514 | if (ret) { | ||
1515 | dev_err(dwc->dev, "failed to request irq #%d --> %d\n", | ||
1516 | irq, ret); | ||
1517 | goto err0; | ||
1518 | } | ||
1519 | |||
1511 | spin_lock_irqsave(&dwc->lock, flags); | 1520 | spin_lock_irqsave(&dwc->lock, flags); |
1512 | 1521 | ||
1513 | if (dwc->gadget_driver) { | 1522 | if (dwc->gadget_driver) { |
@@ -1515,7 +1524,7 @@ static int dwc3_gadget_start(struct usb_gadget *g, | |||
1515 | dwc->gadget.name, | 1524 | dwc->gadget.name, |
1516 | dwc->gadget_driver->driver.name); | 1525 | dwc->gadget_driver->driver.name); |
1517 | ret = -EBUSY; | 1526 | ret = -EBUSY; |
1518 | goto err0; | 1527 | goto err1; |
1519 | } | 1528 | } |
1520 | 1529 | ||
1521 | dwc->gadget_driver = driver; | 1530 | dwc->gadget_driver = driver; |
@@ -1551,42 +1560,38 @@ static int dwc3_gadget_start(struct usb_gadget *g, | |||
1551 | ret = __dwc3_gadget_ep_enable(dep, &dwc3_gadget_ep0_desc, NULL, false); | 1560 | ret = __dwc3_gadget_ep_enable(dep, &dwc3_gadget_ep0_desc, NULL, false); |
1552 | if (ret) { | 1561 | if (ret) { |
1553 | dev_err(dwc->dev, "failed to enable %s\n", dep->name); | 1562 | dev_err(dwc->dev, "failed to enable %s\n", dep->name); |
1554 | goto err0; | 1563 | goto err2; |
1555 | } | 1564 | } |
1556 | 1565 | ||
1557 | dep = dwc->eps[1]; | 1566 | dep = dwc->eps[1]; |
1558 | ret = __dwc3_gadget_ep_enable(dep, &dwc3_gadget_ep0_desc, NULL, false); | 1567 | ret = __dwc3_gadget_ep_enable(dep, &dwc3_gadget_ep0_desc, NULL, false); |
1559 | if (ret) { | 1568 | if (ret) { |
1560 | dev_err(dwc->dev, "failed to enable %s\n", dep->name); | 1569 | dev_err(dwc->dev, "failed to enable %s\n", dep->name); |
1561 | goto err1; | 1570 | goto err3; |
1562 | } | 1571 | } |
1563 | 1572 | ||
1564 | /* begin to receive SETUP packets */ | 1573 | /* begin to receive SETUP packets */ |
1565 | dwc->ep0state = EP0_SETUP_PHASE; | 1574 | dwc->ep0state = EP0_SETUP_PHASE; |
1566 | dwc3_ep0_out_start(dwc); | 1575 | dwc3_ep0_out_start(dwc); |
1567 | 1576 | ||
1568 | irq = platform_get_irq(to_platform_device(dwc->dev), 0); | ||
1569 | ret = request_threaded_irq(irq, dwc3_interrupt, dwc3_thread_interrupt, | ||
1570 | IRQF_SHARED | IRQF_ONESHOT, "dwc3", dwc); | ||
1571 | if (ret) { | ||
1572 | dev_err(dwc->dev, "failed to request irq #%d --> %d\n", | ||
1573 | irq, ret); | ||
1574 | goto err1; | ||
1575 | } | ||
1576 | |||
1577 | dwc3_gadget_enable_irq(dwc); | 1577 | dwc3_gadget_enable_irq(dwc); |
1578 | 1578 | ||
1579 | spin_unlock_irqrestore(&dwc->lock, flags); | 1579 | spin_unlock_irqrestore(&dwc->lock, flags); |
1580 | 1580 | ||
1581 | return 0; | 1581 | return 0; |
1582 | 1582 | ||
1583 | err1: | 1583 | err3: |
1584 | __dwc3_gadget_ep_disable(dwc->eps[0]); | 1584 | __dwc3_gadget_ep_disable(dwc->eps[0]); |
1585 | 1585 | ||
1586 | err0: | 1586 | err2: |
1587 | dwc->gadget_driver = NULL; | 1587 | dwc->gadget_driver = NULL; |
1588 | |||
1589 | err1: | ||
1588 | spin_unlock_irqrestore(&dwc->lock, flags); | 1590 | spin_unlock_irqrestore(&dwc->lock, flags); |
1589 | 1591 | ||
1592 | free_irq(irq, dwc); | ||
1593 | |||
1594 | err0: | ||
1590 | return ret; | 1595 | return ret; |
1591 | } | 1596 | } |
1592 | 1597 | ||
@@ -1600,9 +1605,6 @@ static int dwc3_gadget_stop(struct usb_gadget *g, | |||
1600 | spin_lock_irqsave(&dwc->lock, flags); | 1605 | spin_lock_irqsave(&dwc->lock, flags); |
1601 | 1606 | ||
1602 | dwc3_gadget_disable_irq(dwc); | 1607 | dwc3_gadget_disable_irq(dwc); |
1603 | irq = platform_get_irq(to_platform_device(dwc->dev), 0); | ||
1604 | free_irq(irq, dwc); | ||
1605 | |||
1606 | __dwc3_gadget_ep_disable(dwc->eps[0]); | 1608 | __dwc3_gadget_ep_disable(dwc->eps[0]); |
1607 | __dwc3_gadget_ep_disable(dwc->eps[1]); | 1609 | __dwc3_gadget_ep_disable(dwc->eps[1]); |
1608 | 1610 | ||
@@ -1610,6 +1612,9 @@ static int dwc3_gadget_stop(struct usb_gadget *g, | |||
1610 | 1612 | ||
1611 | spin_unlock_irqrestore(&dwc->lock, flags); | 1613 | spin_unlock_irqrestore(&dwc->lock, flags); |
1612 | 1614 | ||
1615 | irq = platform_get_irq(to_platform_device(dwc->dev), 0); | ||
1616 | free_irq(irq, dwc); | ||
1617 | |||
1613 | return 0; | 1618 | return 0; |
1614 | } | 1619 | } |
1615 | 1620 | ||