gpiolib: irqchip: use irq_find_mapping while removing irqchip
authorGrygorii Strashko <grygorii.strashko@ti.com>
Thu, 25 Sep 2014 16:09:23 +0000 (19:09 +0300)
committerLinus Walleij <linus.walleij@linaro.org>
Fri, 26 Sep 2014 08:40:11 +0000 (10:40 +0200)
There is no guarantee that VIRQs will be allocated sequentially
for gpio irqchip in gpiochip_irqchip_add().
Therefore, it's unsafe to dispose VIRQ in gpiochip_irqchip_remove()
basing on index relatively to stored irq_base value.

Hence, use irq_find_mapping for VIRQ finding  in gpiochip_irqchip_remove()
instead of irq_base + index.

Reported-by: Wang, Yalin <Yalin.Wang@sonymobile.com>
Signed-off-by: Grygorii Strashko <grygorii.strashko@ti.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpiolib.c

index 6fdae789ccc9e439a93eb07eb3806bf5968b4916..550e575c6ffb8343afe7f21eb4aca04ef8f91118 100644 (file)
@@ -514,7 +514,8 @@ static void gpiochip_irqchip_remove(struct gpio_chip *gpiochip)
        /* Remove all IRQ mappings and delete the domain */
        if (gpiochip->irqdomain) {
                for (offset = 0; offset < gpiochip->ngpio; offset++)
-                       irq_dispose_mapping(gpiochip->irq_base + offset);
+                       irq_dispose_mapping(
+                               irq_find_mapping(gpiochip->irqdomain, offset));
                irq_domain_remove(gpiochip->irqdomain);
        }