sh: fix INTC to use set_irq_chained_handler() for redirects
authorMagnus Damm <damm@opensource.se>
Tue, 9 Feb 2010 07:17:20 +0000 (07:17 +0000)
committerPaul Mundt <lethal@linux-sh.org>
Tue, 9 Feb 2010 09:24:31 +0000 (18:24 +0900)
This patch updates the shared INTC code to use
set_irq_chained_handler() for intc_redirect_irq().

With this in place request_irq() on a merged irq
which has been redirected will now return -EINVAL
instead of 0 together with a crash. This thanks to
the protection of the IRQ_NOREQUEST flag set for
chained interrupt handlers.

Signed-off-by: Magnus Damm <damm@opensource.se>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
drivers/sh/intc.c

index 3a687396dfa28cf71e6d37f363b40615c74d2e85..66594eb4477d7867ef6d7fb73d67be45976b86e0 100644 (file)
@@ -896,8 +896,8 @@ void __init register_intc_controller(struct intc_desc *desc)
                        vect2->enum_id = 0;
 
                        /* redirect this interrupts to the first one */
-                       set_irq_chip_and_handler_name(irq2, &d->chip,
-                                       intc_redirect_irq, "redirect");
+                       set_irq_chained_handler(irq2, intc_redirect_irq);
+                       set_irq_chip(irq2, &d->chip);
                        set_irq_data(irq2, (void *)irq);
                }
        }