aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRussell King <rmk+kernel@arm.linux.org.uk>2015-06-16 18:06:35 -0400
committerThomas Gleixner <tglx@linutronix.de>2015-06-18 08:03:08 -0400
commit7f77c5c39d2eb50e7362f29f654a2c221b6a5b83 (patch)
treef44fe73417f42f50820df588638e38a208963ab3
parent86f5e73304651c3eeec0a1fce90bb3e1d610e3b9 (diff)
ARM: gemini: Fix race in installing GPIO chained IRQ handler
The gemini code was installing its chained interrupt handler (which enables the interrupt) before it was setting its data, which is bad if the IRQ was previously pending. Avoid this problem by converting it to irq_set_chained_handler_and_data(). Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Cc: Alexandre Courbot <gnurou@gmail.com> Cc: Hans Ulli Kroll <ulli.kroll@googlemail.com> Cc: Jason Cooper <jason@lakedaemon.net> Cc: Lee Jones <lee.jones@linaro.org> Cc: Linus Walleij <linus.walleij@linaro.org> Cc: Thierry Reding <thierry.reding@gmail.com> Cc: linux-arm-kernel@lists.infradead.org Link: http://lkml.kernel.org/r/E1Z4z07-0002SO-Gv@rmk-PC.arm.linux.org.uk Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r--arch/arm/mach-gemini/gpio.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/arm/mach-gemini/gpio.c b/arch/arm/mach-gemini/gpio.c
index f8cb5710d6ee..3292f2e6ed6f 100644
--- a/arch/arm/mach-gemini/gpio.c
+++ b/arch/arm/mach-gemini/gpio.c
@@ -223,8 +223,8 @@ void __init gemini_gpio_init(void)
223 set_irq_flags(j, IRQF_VALID); 223 set_irq_flags(j, IRQF_VALID);
224 } 224 }
225 225
226 irq_set_chained_handler(IRQ_GPIO(i), gpio_irq_handler); 226 irq_set_chained_handler_and_data(IRQ_GPIO(i), gpio_irq_handler,
227 irq_set_handler_data(IRQ_GPIO(i), (void *)i); 227 (void *)i);
228 } 228 }
229 229
230 BUG_ON(gpiochip_add(&gemini_gpio_chip)); 230 BUG_ON(gpiochip_add(&gemini_gpio_chip));