mirror of
https://github.com/adulau/aha.git
synced 2025-01-05 15:43:22 +00:00
ARM: OMAP3: Fixed spurious IRQ issue for GPIO interrupts
Flush posted write to IRQSTATUS register in GPIO IRQ handler. This eliminates the below error for all peripherals that use GPIO interrupts. <4>Spurious irq 95: 0xffffffdf, please flush posted write for irq 31 Signed-off-by: Roger Quadros <ext-roger.quadros@nokia.com> Signed-off-by: Tony Lindgren <tony@atomide.com>
This commit is contained in:
parent
c485ab50dd
commit
bedfd15410
1 changed files with 5 additions and 1 deletions
|
@ -758,8 +758,12 @@ static void _clear_gpio_irqbank(struct gpio_bank *bank, int gpio_mask)
|
||||||
|
|
||||||
/* Workaround for clearing DSP GPIO interrupts to allow retention */
|
/* Workaround for clearing DSP GPIO interrupts to allow retention */
|
||||||
#if defined(CONFIG_ARCH_OMAP24XX) || defined(CONFIG_ARCH_OMAP34XX)
|
#if defined(CONFIG_ARCH_OMAP24XX) || defined(CONFIG_ARCH_OMAP34XX)
|
||||||
|
reg = bank->base + OMAP24XX_GPIO_IRQSTATUS2;
|
||||||
if (cpu_is_omap24xx() || cpu_is_omap34xx())
|
if (cpu_is_omap24xx() || cpu_is_omap34xx())
|
||||||
__raw_writel(gpio_mask, bank->base + OMAP24XX_GPIO_IRQSTATUS2);
|
__raw_writel(gpio_mask, reg);
|
||||||
|
|
||||||
|
/* Flush posted write for the irq status to avoid spurious interrupts */
|
||||||
|
__raw_readl(reg);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue