gpio: ep93xx: add DT support for gpio-ep93xx
authorNikita Shubin <nikita.shubin@maquefel.me>
Thu, 1 Jun 2023 05:45:39 +0000 (08:45 +0300)
committerNikita Shubin <nikita.shubin@maquefel.me>
Mon, 10 Jun 2024 07:14:33 +0000 (10:14 +0300)
Add OF ID match table.

Signed-off-by: Nikita Shubin <nikita.shubin@maquefel.me>
Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Acked-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
drivers/gpio/gpio-ep93xx.c

index a55f635585f4bcea9e6b1725b257e879a32ee942..ab798c848215ad9241ccb39d82f0e5d27fed09c5 100644 (file)
 #include <linux/init.h>
 #include <linux/module.h>
 #include <linux/platform_device.h>
+#include <linux/interrupt.h>
 #include <linux/io.h>
 #include <linux/irq.h>
 #include <linux/slab.h>
 #include <linux/gpio/driver.h>
 #include <linux/bitops.h>
 #include <linux/seq_file.h>
-#include <linux/interrupt.h>
 
 struct ep93xx_gpio_irq_chip {
        void __iomem *base;
@@ -138,7 +138,8 @@ static void ep93xx_gpio_irq_mask_ack(struct irq_data *d)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
        struct ep93xx_gpio_irq_chip *eic = to_ep93xx_gpio_irq_chip(gc);
-       int port_mask = BIT(irqd_to_hwirq(d));
+       irq_hw_number_t hwirq = irqd_to_hwirq(d);
+       int port_mask = BIT(hwirq);
 
        if (irqd_get_trigger_type(d) == IRQ_TYPE_EDGE_BOTH)
                eic->int_type2 ^= port_mask; /* switch edge direction */
@@ -147,26 +148,28 @@ static void ep93xx_gpio_irq_mask_ack(struct irq_data *d)
        ep93xx_gpio_update_int_params(eic);
 
        writeb(port_mask, eic->base + EP93XX_INT_EOI_OFFSET);
-       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
+       gpiochip_disable_irq(gc, hwirq);
 }
 
 static void ep93xx_gpio_irq_mask(struct irq_data *d)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
        struct ep93xx_gpio_irq_chip *eic = to_ep93xx_gpio_irq_chip(gc);
+       irq_hw_number_t hwirq = irqd_to_hwirq(d);
 
-       eic->int_unmasked &= ~BIT(irqd_to_hwirq(d));
+       eic->int_unmasked &= ~BIT(hwirq);
        ep93xx_gpio_update_int_params(eic);
-       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
+       gpiochip_disable_irq(gc, hwirq);
 }
 
 static void ep93xx_gpio_irq_unmask(struct irq_data *d)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
        struct ep93xx_gpio_irq_chip *eic = to_ep93xx_gpio_irq_chip(gc);
+       irq_hw_number_t hwirq = irqd_to_hwirq(d);
 
-       gpiochip_enable_irq(gc, irqd_to_hwirq(d));
-       eic->int_unmasked |= BIT(irqd_to_hwirq(d));
+       gpiochip_enable_irq(gc, hwirq);
+       eic->int_unmasked |= BIT(hwirq);
        ep93xx_gpio_update_int_params(eic);
 }
 
@@ -179,11 +182,11 @@ static int ep93xx_gpio_irq_type(struct irq_data *d, unsigned int type)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
        struct ep93xx_gpio_irq_chip *eic = to_ep93xx_gpio_irq_chip(gc);
-       irq_hw_number_t offset = irqd_to_hwirq(d);
-       int port_mask = BIT(offset);
+       irq_hw_number_t hwirq = irqd_to_hwirq(d);
+       int port_mask = BIT(hwirq);
        irq_flow_handler_t handler;
 
-       gc->direction_input(gc, offset);
+       gc->direction_input(gc, hwirq);
 
        switch (type) {
        case IRQ_TYPE_EDGE_RISING:
@@ -209,7 +212,7 @@ static int ep93xx_gpio_irq_type(struct irq_data *d, unsigned int type)
        case IRQ_TYPE_EDGE_BOTH:
                eic->int_type1 |= port_mask;
                /* set initial polarity based on current input level */
-               if (gc->get(gc, offset))
+               if (gc->get(gc, hwirq))
                        eic->int_type2 &= ~port_mask; /* falling */
                else
                        eic->int_type2 |= port_mask; /* rising */
@@ -285,9 +288,8 @@ static int ep93xx_setup_irqs(struct platform_device *pdev,
        if (girq->num_parents == 0)
                return -EINVAL;
 
-       girq->parents = devm_kcalloc(dev, girq->num_parents,
-                                  sizeof(*girq->parents),
-                                  GFP_KERNEL);
+       girq->parents = devm_kcalloc(dev, girq->num_parents, sizeof(*girq->parents),
+                                    GFP_KERNEL);
        if (!girq->parents)
                return -ENOMEM;
 
@@ -306,7 +308,7 @@ static int ep93xx_setup_irqs(struct platform_device *pdev,
                girq->parent_handler = ep93xx_gpio_f_irq_handler;
 
                for (i = 0; i < girq->num_parents; i++) {
-                       irq = platform_get_irq(pdev, i);
+                       irq = platform_get_irq_optional(pdev, i);
                        if (irq < 0)
                                continue;
 
@@ -359,9 +361,15 @@ static int ep93xx_gpio_probe(struct platform_device *pdev)
        return devm_gpiochip_add_data(&pdev->dev, gc, egc);
 }
 
+static const struct of_device_id ep93xx_gpio_match[] = {
+       { .compatible = "cirrus,ep9301-gpio" },
+       { /* sentinel */ }
+};
+
 static struct platform_driver ep93xx_gpio_driver = {
        .driver         = {
                .name   = "gpio-ep93xx",
+               .of_match_table = ep93xx_gpio_match,
        },
        .probe          = ep93xx_gpio_probe,
 };