diff options
author | Felipe Balbi <felipe.balbi@nokia.com> | 2008-11-24 06:06:53 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2009-01-07 13:00:01 -0500 |
commit | c48a5155252fd9cba7bedc59e5f8a339a3454d58 (patch) | |
tree | 6de25e14731e56ba0ddf5b07d137237be40e9ba5 /drivers/usb | |
parent | b6a49b8490fe6f22f0027a3f05eb498918f09303 (diff) |
USB: musb: check if set_irq_wake succeded and remember it
Without it, in platforms that don't provide irq_chip.set_wake(),
like omap, musb will WARN() on driver removal.
Signed-off-by: Felipe Balbi <felipe.balbi@nokia.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb')
-rw-r--r-- | drivers/usb/musb/musb_core.c | 8 | ||||
-rw-r--r-- | drivers/usb/musb/musb_core.h | 1 |
2 files changed, 7 insertions, 2 deletions
diff --git a/drivers/usb/musb/musb_core.c b/drivers/usb/musb/musb_core.c index 8b14437331c7..83720f61fdba 100644 --- a/drivers/usb/musb/musb_core.c +++ b/drivers/usb/musb/musb_core.c | |||
@@ -1840,7 +1840,7 @@ static void musb_free(struct musb *musb) | |||
1840 | musb_gadget_cleanup(musb); | 1840 | musb_gadget_cleanup(musb); |
1841 | #endif | 1841 | #endif |
1842 | 1842 | ||
1843 | if (musb->nIrq >= 0) { | 1843 | if (musb->nIrq >= 0 && musb->irq_wake) { |
1844 | disable_irq_wake(musb->nIrq); | 1844 | disable_irq_wake(musb->nIrq); |
1845 | free_irq(musb->nIrq, musb); | 1845 | free_irq(musb->nIrq, musb); |
1846 | } | 1846 | } |
@@ -1993,8 +1993,12 @@ bad_config: | |||
1993 | } | 1993 | } |
1994 | musb->nIrq = nIrq; | 1994 | musb->nIrq = nIrq; |
1995 | /* FIXME this handles wakeup irqs wrong */ | 1995 | /* FIXME this handles wakeup irqs wrong */ |
1996 | if (enable_irq_wake(nIrq) == 0) | 1996 | if (enable_irq_wake(nIrq) == 0) { |
1997 | musb->irq_wake = 1; | ||
1997 | device_init_wakeup(dev, 1); | 1998 | device_init_wakeup(dev, 1); |
1999 | } else { | ||
2000 | musb->irq_wake = 0; | ||
2001 | } | ||
1998 | 2002 | ||
1999 | pr_info("%s: USB %s mode controller at %p using %s, IRQ %d\n", | 2003 | pr_info("%s: USB %s mode controller at %p using %s, IRQ %d\n", |
2000 | musb_driver_name, | 2004 | musb_driver_name, |
diff --git a/drivers/usb/musb/musb_core.h b/drivers/usb/musb/musb_core.h index b3d605073071..d45d258e63f0 100644 --- a/drivers/usb/musb/musb_core.h +++ b/drivers/usb/musb/musb_core.h | |||
@@ -359,6 +359,7 @@ struct musb { | |||
359 | struct otg_transceiver xceiv; | 359 | struct otg_transceiver xceiv; |
360 | 360 | ||
361 | int nIrq; | 361 | int nIrq; |
362 | unsigned irq_wake:1; | ||
362 | 363 | ||
363 | struct musb_hw_ep endpoints[MUSB_C_NUM_EPS]; | 364 | struct musb_hw_ep endpoints[MUSB_C_NUM_EPS]; |
364 | #define control_ep endpoints | 365 | #define control_ep endpoints |