genirq: check chip->ack before calling
authorWang Chen <wangchen@cn.fujitsu.com>
Mon, 29 Dec 2008 05:35:11 +0000 (13:35 +0800)
committerIngo Molnar <mingo@elte.hu>
Mon, 29 Dec 2008 11:22:29 +0000 (12:22 +0100)
Impact: fix theoretical NULL dereference

The generic irq layer doesn't know whether irq_chip has ack routine on some
architectures or not. Upon that, before calling chip->ack, we should check
that it's not NULL.

Signed-off-by: Wang Chen <wangchen@cn.fujitsu.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
kernel/irq/chip.c

index 6eb3c7952b6496fc9c5f8da49b982d79866e1504..0ad02d76a0c4b783487740c27a47bc0d8323b66f 100644 (file)
@@ -290,7 +290,8 @@ static inline void mask_ack_irq(struct irq_desc *desc, int irq)
                desc->chip->mask_ack(irq);
        else {
                desc->chip->mask(irq);
-               desc->chip->ack(irq);
+               if (desc->chip->ack)
+                       desc->chip->ack(irq);
        }
 }
 
@@ -475,7 +476,8 @@ handle_edge_irq(unsigned int irq, struct irq_desc *desc)
        kstat_incr_irqs_this_cpu(irq, desc);
 
        /* Start handling the irq */
-       desc->chip->ack(irq);
+       if (desc->chip->ack)
+               desc->chip->ack(irq);
        desc = irq_remap_to_desc(irq, desc);
 
        /* Mark the IRQ currently in progress.*/