]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - arch/arm/mach-omap2/irq.c
ARM: OMAP3: Mask interrupts when disabling interrupts
[linux-2.6-omap-h63xx.git] / arch / arm / mach-omap2 / irq.c
index 9c9e307360dbadb72b70047e4d5c3c014f4f11ed..b44dcaeef738b06140a54437dee4dc91a67a1b77 100644 (file)
@@ -96,7 +96,7 @@ static void omap_mask_irq(unsigned int irq)
        int offset = irq & (~(IRQ_BITS_PER_REG - 1));
 
        if (cpu_is_omap34xx()) {
-               int spurious;
+               int spurious = 0;
 
                /*
                 * INT_34XX_GPT12_IRQ is also the spurious irq. Maybe because
@@ -123,6 +123,11 @@ static void omap_unmask_irq(unsigned int irq)
        intc_bank_write_reg(1 << irq, &irq_banks[0], INTC_MIR_CLEAR0 + offset);
 }
 
+static void omap_disable_irq(unsigned int irq)
+{
+       omap_mask_irq(irq);
+}
+
 static void omap_mask_ack_irq(unsigned int irq)
 {
        omap_mask_irq(irq);
@@ -134,6 +139,7 @@ static struct irq_chip omap_irq_chip = {
        .ack    = omap_mask_ack_irq,
        .mask   = omap_mask_irq,
        .unmask = omap_unmask_irq,
+       .disable = omap_disable_irq,
 };
 
 static void __init omap_irq_bank_init_one(struct omap_irq_bank *bank)