usb: renesas_usbhs: protect mod->irq_{bemp,brdy}sts by spin lock
This patch protects the mod->irq_bempsts and mod->irq_brdysts by spin lock in the usbhs_status_get_each_irq() because other functions will write them during spin lock. Otherwise, the driver will clears the BRDYSTS and/or BEMPSTS wrongly, and then, the transaction will not finish. Also since the driver should use the INTSTS0 and BRDYSTS and BEMPSTS as the same timing, the patch protects them. Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> Signed-off-by: Felipe Balbi <balbi@ti.com>
This commit is contained in:
parent
8355b2b308
commit
c4d8199ba1
@ -213,7 +213,10 @@ static int usbhs_status_get_each_irq(struct usbhs_priv *priv,
|
|||||||
{
|
{
|
||||||
struct usbhs_mod *mod = usbhs_mod_get_current(priv);
|
struct usbhs_mod *mod = usbhs_mod_get_current(priv);
|
||||||
u16 intenb0, intenb1;
|
u16 intenb0, intenb1;
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
|
/******************** spin lock ********************/
|
||||||
|
usbhs_lock(priv, flags);
|
||||||
state->intsts0 = usbhs_read(priv, INTSTS0);
|
state->intsts0 = usbhs_read(priv, INTSTS0);
|
||||||
state->intsts1 = usbhs_read(priv, INTSTS1);
|
state->intsts1 = usbhs_read(priv, INTSTS1);
|
||||||
|
|
||||||
@ -229,6 +232,8 @@ static int usbhs_status_get_each_irq(struct usbhs_priv *priv,
|
|||||||
state->bempsts &= mod->irq_bempsts;
|
state->bempsts &= mod->irq_bempsts;
|
||||||
state->brdysts &= mod->irq_brdysts;
|
state->brdysts &= mod->irq_brdysts;
|
||||||
}
|
}
|
||||||
|
usbhs_unlock(priv, flags);
|
||||||
|
/******************** spin unlock ******************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check whether the irq enable registers and the irq status are set
|
* Check whether the irq enable registers and the irq status are set
|
||||||
|
Loading…
x
Reference in New Issue
Block a user