[PATCHv2 02/10] ARM: vic: MULTI_IRQ_HANDLER handler

Linus Walleij linus.walleij at linaro.org
Thu Nov 3 09:00:15 EDT 2011


On Thu, Nov 3, 2011 at 1:51 PM, Russell King - ARM Linux
<linux at arm.linux.org.uk> wrote:

>        stat = readl_relaxed(vic->base + VIC_IRQ_STATUS);
>        while (stat) {
>                while (stat) {
>                        irq = ffs(stat) - 1;
>                        stat &= ~(1 << irq);
>                        handle_irq(irq);
>                }
>                stat = readl_relaxed(vic->base + VIC_IRQ_STATUS);
>        }
>
> This ensures that we process all interrupts found pending before we
> re-check for any new interrupts pending.  Arguably this is a much
> fairer implementation (and may mean if things get irrevokably stuck,
> things like sysrq via the console uart may still work.)

I really like the looks of this, Jamie can you do it like that?

Maybe some smallish comment about what's going on can be
good for future generations reading that code...

Yours,
Linus Walleij



More information about the linux-arm-kernel mailing list