Commit 1805bf9f authored by Tony Lindgren's avatar Tony Lindgren

musb_hdrc: Mask tusb interrupts while being handled

This should allow using both edge or level GPIO interrupts.
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent 6f7af483
...@@ -722,10 +722,14 @@ static irqreturn_t tusb_interrupt(int irq, void *__hci) ...@@ -722,10 +722,14 @@ static irqreturn_t tusb_interrupt(int irq, void *__hci)
struct musb *musb = __hci; struct musb *musb = __hci;
void __iomem *base = musb->ctrl_base; void __iomem *base = musb->ctrl_base;
unsigned long flags; unsigned long flags;
u32 int_src; u32 int_mask, int_src;
spin_lock_irqsave(&musb->Lock, flags); spin_lock_irqsave(&musb->Lock, flags);
/* Mask all interrupts to allow using both edge and level GPIO irq */
int_mask = musb_readl(base, TUSB_INT_MASK);
musb_writel(base, TUSB_INT_MASK, ~TUSB_INT_MASK_RESERVED_BITS);
int_src = musb_readl(base, TUSB_INT_SRC) & ~TUSB_INT_SRC_RESERVED_BITS; int_src = musb_readl(base, TUSB_INT_SRC) & ~TUSB_INT_SRC_RESERVED_BITS;
DBG(3, "TUSB IRQ %08x\n", int_src); DBG(3, "TUSB IRQ %08x\n", int_src);
...@@ -813,6 +817,8 @@ static irqreturn_t tusb_interrupt(int irq, void *__hci) ...@@ -813,6 +817,8 @@ static irqreturn_t tusb_interrupt(int irq, void *__hci)
int_src & ~TUSB_INT_MASK_RESERVED_BITS); int_src & ~TUSB_INT_MASK_RESERVED_BITS);
musb_platform_try_idle(musb); musb_platform_try_idle(musb);
musb_writel(base, TUSB_INT_MASK, int_mask);
spin_unlock_irqrestore(&musb->Lock, flags); spin_unlock_irqrestore(&musb->Lock, flags);
return IRQ_HANDLED; return IRQ_HANDLED;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment