usb: r8a66597-hdc disable interrupts fix
This patch improves disable_controller() in the r8a66597-hdc driver to disable all interrupts and clear status flags. It also makes sure that disable_controller() is called during probe(). This fixes the relatively rare case of unexpected pending interrupts after kexec reboot. Signed-off-by: Magnus Damm <damm@opensource.se> Acked-by: Yoshihiro Shimoda <shimoda.yoshihiro@renesas.com> Signed-off-by: Paul Mundt <lethal@linux-sh.org>
This commit is contained in:
parent
e8708ef7e8
commit
e5ff15bec9
@ -216,8 +216,17 @@ static void disable_controller(struct r8a66597 *r8a66597)
|
||||
{
|
||||
int port;
|
||||
|
||||
/* disable interrupts */
|
||||
r8a66597_write(r8a66597, 0, INTENB0);
|
||||
r8a66597_write(r8a66597, 0, INTSTS0);
|
||||
r8a66597_write(r8a66597, 0, INTENB1);
|
||||
r8a66597_write(r8a66597, 0, BRDYENB);
|
||||
r8a66597_write(r8a66597, 0, BEMPENB);
|
||||
r8a66597_write(r8a66597, 0, NRDYENB);
|
||||
|
||||
/* clear status */
|
||||
r8a66597_write(r8a66597, 0, BRDYSTS);
|
||||
r8a66597_write(r8a66597, 0, NRDYSTS);
|
||||
r8a66597_write(r8a66597, 0, BEMPSTS);
|
||||
|
||||
for (port = 0; port < r8a66597->max_root_hub; port++)
|
||||
r8a66597_disable_port(r8a66597, port);
|
||||
@ -2466,6 +2475,12 @@ static int __devinit r8a66597_probe(struct platform_device *pdev)
|
||||
r8a66597->rh_timer.data = (unsigned long)r8a66597;
|
||||
r8a66597->reg = (unsigned long)reg;
|
||||
|
||||
/* make sure no interrupts are pending */
|
||||
ret = r8a66597_clock_enable(r8a66597);
|
||||
if (ret < 0)
|
||||
goto clean_up3;
|
||||
disable_controller(r8a66597);
|
||||
|
||||
for (i = 0; i < R8A66597_MAX_NUM_PIPE; i++) {
|
||||
INIT_LIST_HEAD(&r8a66597->pipe_queue[i]);
|
||||
init_timer(&r8a66597->td_timer[i]);
|
||||
|
Loading…
Reference in New Issue
Block a user