usb: musb: do not sleep in atomic context
authorDaniel Mack <zonque@gmail.com>
Wed, 15 Jan 2014 13:09:49 +0000 (14:09 +0100)
committerFelipe Balbi <balbi@ti.com>
Tue, 18 Feb 2014 16:34:07 +0000 (10:34 -0600)
commit30d361bf0f81ece8de42c5e0a4e560270ad72b65
tree6c1e85c58e1d8de250f89ff9511dea6ee308fcef
parentd246c9d55a90722fac9e7284201088eb62adcfc3
usb: musb: do not sleep in atomic context

musb_port_reset() is called from musb_hub_control() which in turn holds
a spinlock, so musb_port_reset() is not allowed to call msleep().

With the asynchronous work helpers in place, this is fortunately easy to
fix by rescheduling the reset deassertion function to after the time
when the wait period is finished.

Note, however, that the MUSB_POWER_RESUME bit is only set on AM33xx
processors under rare conditions such as when to another driver
reporting an error during suspend. Hence, this didn't hit me yet in
normal operation.

Signed-off-by: Daniel Mack <zonque@gmail.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
drivers/usb/musb/musb_core.c
drivers/usb/musb/musb_virthub.c