gpiolib: cleanup chained handler and data
authorDmitry Eremin-Solenikov <dbaryshkov@gmail.com>
Tue, 12 May 2015 17:12:23 +0000 (20:12 +0300)
committerLinus Walleij <linus.walleij@linaro.org>
Wed, 13 May 2015 11:02:36 +0000 (13:02 +0200)
Clean up chained handler and handler data if they were set by
gpiochip_set_chained_irqchip().

Signed-off-by: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpiolib.c
include/linux/gpio/driver.h

index 2ce3df3504e6e7de4d99bc433754008bf267bca2..59cb4303e2515e83b8b2a4d6a1ef239cefed106e 100644 (file)
@@ -443,6 +443,8 @@ void gpiochip_set_chained_irqchip(struct gpio_chip *gpiochip,
                 */
                irq_set_handler_data(parent_irq, gpiochip);
                irq_set_chained_handler(parent_irq, parent_handler);
+
+               gpiochip->irq_parent = parent_irq;
        }
 
        /* Set the parent IRQ for all affected IRQs */
@@ -551,6 +553,11 @@ static void gpiochip_irqchip_remove(struct gpio_chip *gpiochip)
 
        acpi_gpiochip_free_interrupts(gpiochip);
 
+       if (gpiochip->irq_parent) {
+               irq_set_chained_handler(gpiochip->irq_parent, NULL);
+               irq_set_handler_data(gpiochip->irq_parent, NULL);
+       }
+
        /* Remove all IRQ mappings and delete the domain */
        if (gpiochip->irqdomain) {
                for (offset = 0; offset < gpiochip->ngpio; offset++)
index 2c1e639f66bd72199fb170e8c7d54b99023d0131..96a678842cdeef7e0d4200329565351e20278410 100644 (file)
@@ -121,6 +121,7 @@ struct gpio_chip {
        unsigned int            irq_base;
        irq_flow_handler_t      irq_handler;
        unsigned int            irq_default_type;
+       int                     irq_parent;
 #endif
 
 #if defined(CONFIG_OF_GPIO)