From: Nikita Yushchenko <nyushche...@dev.rtsoft.ru>

This avoids leak of IRQ mapping on error paths, and makes it possible
to use devm_request_irq() without facing unmap-while-handler-installed
issues.

Signed-off-by: Nikita Yushchenko <nyushche...@dev.rtsoft.ru>
---
 drivers/pinctrl/pinctrl-bcm2835.c    |    6 +++++-
 drivers/pinctrl/pinctrl-exynos.c     |   11 ++++++-----
 drivers/pinctrl/pinctrl-exynos5440.c |    2 +-
 drivers/pinctrl/pinctrl-rockchip.c   |    6 +++++-
 drivers/pinctrl/pinctrl-s3c24xx.c    |    6 +++---
 drivers/pinctrl/pinctrl-s3c64xx.c    |    6 +++---
 drivers/pinctrl/pinctrl-single.c     |    6 +++++-
 drivers/pinctrl/pinctrl-sunxi.c      |    6 +++---
 8 files changed, 31 insertions(+), 18 deletions(-)

diff --git a/drivers/pinctrl/pinctrl-bcm2835.c 
b/drivers/pinctrl/pinctrl-bcm2835.c
index 3d907de..320dcf4 100644
--- a/drivers/pinctrl/pinctrl-bcm2835.c
+++ b/drivers/pinctrl/pinctrl-bcm2835.c
@@ -1012,7 +1012,11 @@ static int bcm2835_pinctrl_probe(struct platform_device 
*pdev)
                for_each_set_bit(offset, &events, 32)
                        bcm2835_gpio_wr(pc, GPEDS0 + i * 4, BIT(offset));
 
-               pc->irq[i] = irq_of_parse_and_map(np, i);
+               pc->irq[i] = devm_irq_of_parse_and_map(dev, np, i);
+               if (pc->irq[i] <= 0) {
+                       dev_err(dev, "unable to locate IRQ for bank %d\n", i);
+                       return pc->irq[i] ? pc->irq[i] : -EINVAL;
+               }
                pc->irq_data[i].pc = pc;
                pc->irq_data[i].bank = i;
                spin_lock_init(&pc->irq_lock[i]);
diff --git a/drivers/pinctrl/pinctrl-exynos.c b/drivers/pinctrl/pinctrl-exynos.c
index 07c8130..128af30 100644
--- a/drivers/pinctrl/pinctrl-exynos.c
+++ b/drivers/pinctrl/pinctrl-exynos.c
@@ -549,8 +549,9 @@ static int exynos_eint_wkup_init(struct 
samsung_pinctrl_drv_data *d)
                }
 
                for (idx = 0; idx < bank->nr_pins; ++idx) {
-                       irq = irq_of_parse_and_map(bank->of_node, idx);
-                       if (!irq) {
+                       irq = devm_irq_of_parse_and_map(dev, bank->of_node,
+                                       idx);
+                       if (irq <= 0) {
                                dev_err(dev, "irq number for eint-%s-%d not 
found\n",
                                                        bank->name, idx);
                                continue;
@@ -565,10 +566,10 @@ static int exynos_eint_wkup_init(struct 
samsung_pinctrl_drv_data *d)
        if (!muxed_banks)
                return 0;
 
-       irq = irq_of_parse_and_map(wkup_np, 0);
-       if (!irq) {
+       irq = devm_irq_of_parse_and_map(dev, wkup_np, 0);
+       if (irq <= 0) {
                dev_err(dev, "irq number for muxed EINTs not found\n");
-               return 0;
+               return irq ? irq : -EINVAL;
        }
 
        muxed_data = devm_kzalloc(dev, sizeof(*muxed_data)
diff --git a/drivers/pinctrl/pinctrl-exynos5440.c 
b/drivers/pinctrl/pinctrl-exynos5440.c
index 8fe2ab0..efb1e8d 100644
--- a/drivers/pinctrl/pinctrl-exynos5440.c
+++ b/drivers/pinctrl/pinctrl-exynos5440.c
@@ -966,7 +966,7 @@ static int exynos5440_gpio_irq_init(struct platform_device 
*pdev,
        }
 
        for (i = 0; i < EXYNOS5440_MAX_GPIO_INT; i++) {
-               irq = irq_of_parse_and_map(dev->of_node, i);
+               irq = devm_irq_of_parse_and_map(dev, dev->of_node, i);
                if (irq <= 0) {
                        dev_err(dev, "irq parsing failed\n");
                        return -EINVAL;
diff --git a/drivers/pinctrl/pinctrl-rockchip.c 
b/drivers/pinctrl/pinctrl-rockchip.c
index 96c60d2..622a130 100644
--- a/drivers/pinctrl/pinctrl-rockchip.c
+++ b/drivers/pinctrl/pinctrl-rockchip.c
@@ -1398,7 +1398,11 @@ static int rockchip_get_bank_data(struct 
rockchip_pin_bank *bank,
                bank->bank_type = COMMON_BANK;
        }
 
-       bank->irq = irq_of_parse_and_map(bank->of_node, 0);
+       bank->irq = devm_irq_of_parse_and_map(dev, bank->of_node, 0);
+       if (bank->irq < 0) {
+               dev_err(dev, "cannot find IRQ for bank\n");
+               return bank->irq;
+       }
 
        bank->clk = of_clk_get(bank->of_node, 0);
        if (IS_ERR(bank->clk))
diff --git a/drivers/pinctrl/pinctrl-s3c24xx.c 
b/drivers/pinctrl/pinctrl-s3c24xx.c
index ad3eaad..93d8e2f 100644
--- a/drivers/pinctrl/pinctrl-s3c24xx.c
+++ b/drivers/pinctrl/pinctrl-s3c24xx.c
@@ -507,10 +507,10 @@ static int s3c24xx_eint_init(struct 
samsung_pinctrl_drv_data *d)
        for (i = 0; i < NUM_EINT_IRQ; ++i) {
                unsigned int irq;
 
-               irq = irq_of_parse_and_map(eint_np, i);
-               if (!irq) {
+               irq = devm_irq_of_parse_and_map(dev, eint_np, i);
+               if (irq <= 0) {
                        dev_err(dev, "failed to get wakeup EINT IRQ %d\n", i);
-                       return -ENXIO;
+                       return irq ? irq : -ENXIO;
                }
 
                eint_data->parents[i] = irq;
diff --git a/drivers/pinctrl/pinctrl-s3c64xx.c 
b/drivers/pinctrl/pinctrl-s3c64xx.c
index 89143c9..f0c9188 100644
--- a/drivers/pinctrl/pinctrl-s3c64xx.c
+++ b/drivers/pinctrl/pinctrl-s3c64xx.c
@@ -725,10 +725,10 @@ static int s3c64xx_eint_eint0_init(struct 
samsung_pinctrl_drv_data *d)
        for (i = 0; i < NUM_EINT0_IRQ; ++i) {
                unsigned int irq;
 
-               irq = irq_of_parse_and_map(eint0_np, i);
-               if (!irq) {
+               irq = devm_irq_of_parse_and_map(dev, eint0_np, i);
+               if (irq <= 0) {
                        dev_err(dev, "failed to get wakeup EINT IRQ %d\n", i);
-                       return -ENXIO;
+                       return irq ? irq : -ENXIO;
                }
 
                irq_set_chained_handler(irq, s3c64xx_eint0_handlers[i]);
diff --git a/drivers/pinctrl/pinctrl-single.c b/drivers/pinctrl/pinctrl-single.c
index 2960557..0b9b017 100644
--- a/drivers/pinctrl/pinctrl-single.c
+++ b/drivers/pinctrl/pinctrl-single.c
@@ -1988,7 +1988,11 @@ static int pcs_probe(struct platform_device *pdev)
        if (ret < 0)
                goto free;
 
-       pcs->socdata.irq = irq_of_parse_and_map(np, 0);
+       pcs->socdata.irq = devm_irq_of_parse_and_map(&pdev->dev, np, 0);
+       if (pcs->socdata.irq < 0) {
+               ret = pcs->socdata.irq;
+               goto free;
+       }
        if (pcs->socdata.irq)
                pcs->flags |= PCS_FEAT_IRQ;
 
diff --git a/drivers/pinctrl/pinctrl-sunxi.c b/drivers/pinctrl/pinctrl-sunxi.c
index f9fabe9..e0759e2 100644
--- a/drivers/pinctrl/pinctrl-sunxi.c
+++ b/drivers/pinctrl/pinctrl-sunxi.c
@@ -886,9 +886,9 @@ static int sunxi_pinctrl_probe(struct platform_device *pdev)
 
        clk_prepare_enable(clk);
 
-       pctl->irq = irq_of_parse_and_map(node, 0);
-       if (!pctl->irq) {
-               ret = -EINVAL;
+       pctl->irq = devm_irq_of_parse_and_map(&pdev->dev, node, 0);
+       if (pctl->irq <= 0) {
+               ret = pctl->irq ? pctl->irq : -EINVAL;
                goto gpiochip_error;
        }
 
-- 
1.7.10.4

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to