Commit feeaefd3 authored by Serge Semin's avatar Serge Semin Committed by Linus Walleij

gpio: dwapb: Use resource managed GPIO-chip add data method

Since the resource managed version of gpiochip_add_data() will handle the
GPIO-chip data automated cleanup we can freely remove the DW APB GPIO
driver code responsible for that. After doing so the DW APB GPIO driver
removal callback can be also fully discarded since there is nothing left
to be done for it. All the cleanups are now performed by means of the
device managed framework.
Signed-off-by: default avatarSerge Semin <Sergey.Semin@baikalelectronics.ru>
Reviewed-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
Link: https://lore.kernel.org/r/20200730152808.2955-11-Sergey.Semin@baikalelectronics.ruSigned-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent daa3f58d
...@@ -91,7 +91,6 @@ struct dwapb_gpio_port_irqchip { ...@@ -91,7 +91,6 @@ struct dwapb_gpio_port_irqchip {
struct dwapb_gpio_port { struct dwapb_gpio_port {
struct gpio_chip gc; struct gpio_chip gc;
struct dwapb_gpio_port_irqchip *pirq; struct dwapb_gpio_port_irqchip *pirq;
bool is_registered;
struct dwapb_gpio *gpio; struct dwapb_gpio *gpio;
#ifdef CONFIG_PM_SLEEP #ifdef CONFIG_PM_SLEEP
struct dwapb_context *ctx; struct dwapb_context *ctx;
...@@ -519,32 +518,16 @@ static int dwapb_gpio_add_port(struct dwapb_gpio *gpio, ...@@ -519,32 +518,16 @@ static int dwapb_gpio_add_port(struct dwapb_gpio *gpio,
if (pp->idx == 0) if (pp->idx == 0)
dwapb_configure_irqs(gpio, port, pp); dwapb_configure_irqs(gpio, port, pp);
err = gpiochip_add_data(&port->gc, port); err = devm_gpiochip_add_data(gpio->dev, &port->gc, port);
if (err) { if (err) {
dev_err(gpio->dev, "failed to register gpiochip for port%d\n", dev_err(gpio->dev, "failed to register gpiochip for port%d\n",
port->idx); port->idx);
return err; return err;
} }
port->is_registered = true;
return 0; return 0;
} }
static void dwapb_gpio_unregister(struct dwapb_gpio *gpio)
{
unsigned int m;
for (m = 0; m < gpio->nr_ports; ++m) {
struct dwapb_gpio_port *port = &gpio->ports[m];
if (!port->is_registered)
continue;
gpiochip_remove(&port->gc);
}
}
static void dwapb_get_irq(struct device *dev, struct fwnode_handle *fwnode, static void dwapb_get_irq(struct device *dev, struct fwnode_handle *fwnode,
struct dwapb_port_property *pp) struct dwapb_port_property *pp)
{ {
...@@ -738,23 +721,8 @@ static int dwapb_gpio_probe(struct platform_device *pdev) ...@@ -738,23 +721,8 @@ static int dwapb_gpio_probe(struct platform_device *pdev)
for (i = 0; i < gpio->nr_ports; i++) { for (i = 0; i < gpio->nr_ports; i++) {
err = dwapb_gpio_add_port(gpio, &pdata->properties[i], i); err = dwapb_gpio_add_port(gpio, &pdata->properties[i], i);
if (err) if (err)
goto out_unregister;
}
platform_set_drvdata(pdev, gpio);
return 0;
out_unregister:
dwapb_gpio_unregister(gpio);
return err; return err;
} }
static int dwapb_gpio_remove(struct platform_device *pdev)
{
struct dwapb_gpio *gpio = platform_get_drvdata(pdev);
dwapb_gpio_unregister(gpio);
return 0; return 0;
} }
...@@ -858,7 +826,6 @@ static struct platform_driver dwapb_gpio_driver = { ...@@ -858,7 +826,6 @@ static struct platform_driver dwapb_gpio_driver = {
.acpi_match_table = dwapb_acpi_match, .acpi_match_table = dwapb_acpi_match,
}, },
.probe = dwapb_gpio_probe, .probe = dwapb_gpio_probe,
.remove = dwapb_gpio_remove,
}; };
module_platform_driver(dwapb_gpio_driver); module_platform_driver(dwapb_gpio_driver);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment