pinctrl: ocelot: Always register GPIO driver
authorLars Povlsen <lars.povlsen@microchip.com>
Wed, 13 May 2020 12:55:19 +0000 (14:55 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 18 May 2020 07:28:51 +0000 (09:28 +0200)
This fixes the situation where the GPIO controller is not
used as an interrupt controller as well.

Previously, the driver would silently fail to register even the
GPIO's. With this change, the driver will only register as an
interrupt controller if a parent interrupt is provided.

Reviewed-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Lars Povlsen <lars.povlsen@microchip.com>
Link: https://lore.kernel.org/r/20200513125532.24585-2-lars.povlsen@microchip.com
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/pinctrl-ocelot.c

index ed8eac6c14944c9616d9133ab59dc21451443a22..d4ac65b1efc0b8bd0ecdbe3420c8e695b1ef4eaf 100644 (file)
@@ -751,21 +751,21 @@ static int ocelot_gpiochip_register(struct platform_device *pdev,
        gc->of_node = info->dev->of_node;
        gc->label = "ocelot-gpio";
 
-       irq = irq_of_parse_and_map(pdev->dev.of_node, 0);
-       if (irq <= 0)
-               return irq;
-
-       girq = &gc->irq;
-       girq->chip = &ocelot_irqchip;
-       girq->parent_handler = ocelot_irq_handler;
-       girq->num_parents = 1;
-       girq->parents = devm_kcalloc(&pdev->dev, 1, sizeof(*girq->parents),
-                                    GFP_KERNEL);
-       if (!girq->parents)
-               return -ENOMEM;
-       girq->parents[0] = irq;
-       girq->default_type = IRQ_TYPE_NONE;
-       girq->handler = handle_edge_irq;
+       irq = irq_of_parse_and_map(gc->of_node, 0);
+       if (irq) {
+               girq = &gc->irq;
+               girq->chip = &ocelot_irqchip;
+               girq->parent_handler = ocelot_irq_handler;
+               girq->num_parents = 1;
+               girq->parents = devm_kcalloc(&pdev->dev, 1,
+                                            sizeof(*girq->parents),
+                                            GFP_KERNEL);
+               if (!girq->parents)
+                       return -ENOMEM;
+               girq->parents[0] = irq;
+               girq->default_type = IRQ_TYPE_NONE;
+               girq->handler = handle_edge_irq;
+       }
 
        ret = devm_gpiochip_add_data(&pdev->dev, gc, info);
        if (ret)