[v1,1/2] gpiolib: of: Prepare of_mm_gpiochip_add_data() for fwnode
Commit Message
GPIO library is getting rid of of_node, fwnode should be utilized instead.
Prepare of_mm_gpiochip_add_data() for fwnode.
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
---
drivers/gpio/gpiolib-of.c | 13 +++++++------
1 file changed, 7 insertions(+), 6 deletions(-)
Comments
On Wed, Nov 09, 2022 at 05:07:33PM +0200, Andy Shevchenko wrote:
> GPIO library is getting rid of of_node, fwnode should be utilized instead.
> Prepare of_mm_gpiochip_add_data() for fwnode.
I believe this is the last preparatory patch to get rid of of_node from
GPIO chip data structure.
After rc1 I will send that clean up and it would be nice to start next cycle
of_node free.
On Wed, Nov 09, 2022 at 05:07:33PM +0200, Andy Shevchenko wrote:
> GPIO library is getting rid of of_node, fwnode should be utilized instead.
> Prepare of_mm_gpiochip_add_data() for fwnode.
>
> Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> ---
> drivers/gpio/gpiolib-of.c | 13 +++++++------
> 1 file changed, 7 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/gpio/gpiolib-of.c b/drivers/gpio/gpiolib-of.c
> index 4be3c21aa718..feeb9e8e846d 100644
> --- a/drivers/gpio/gpiolib-of.c
> +++ b/drivers/gpio/gpiolib-of.c
> @@ -919,14 +919,15 @@ int of_mm_gpiochip_add_data(struct device_node *np,
> struct of_mm_gpio_chip *mm_gc,
> void *data)
> {
> + struct fwnode_handle *fwnode = of_fwnode_handle(np);
> int ret = -ENOMEM;
> struct gpio_chip *gc = &mm_gc->gc;
>
> - gc->label = kasprintf(GFP_KERNEL, "%pOF", np);
> + gc->label = kasprintf(GFP_KERNEL, "%pfw", fwnode);
> if (!gc->label)
> goto err0;
>
> - mm_gc->regs = of_iomap(np, 0);
> + mm_gc->regs = fwnode_iomap(fwnode, 0);
> if (!mm_gc->regs)
> goto err1;
>
> @@ -935,8 +936,8 @@ int of_mm_gpiochip_add_data(struct device_node *np,
> if (mm_gc->save_regs)
> mm_gc->save_regs(mm_gc);
>
> - of_node_put(mm_gc->gc.of_node);
> - mm_gc->gc.of_node = of_node_get(np);
> + fwnode_handle_put(mm_gc->gc.fwnode);
> + mm_gc->gc.fwnode = fwnode_handle_get(fwnode);
Can we reduce the patch to
fwnode_handle_put(mm_gc->gc.fwnode);
mm_gc->gc.fwnode = fwnode_handle_get(of_fwnode_handle(np));
?
I do not see a reason for converting the rest of invocations to fwnode
given that this is clearly an OF API.
Thanks.
On Wed, Nov 9, 2022 at 4:07 PM Andy Shevchenko
<andriy.shevchenko@linux.intel.com> wrote:
> GPIO library is getting rid of of_node, fwnode should be utilized instead.
> Prepare of_mm_gpiochip_add_data() for fwnode.
>
> Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
I actually want to get rid of of_mm_gpiochip_add_data() altogether and
just replace all of them with regular gpio_chip, as stated in the GPIO TODO.
Hmmm... who is using this...
$ git grep of_mm_gpiochip_add_data
arch/powerpc/platforms/4xx/gpio.c: ret =
of_mm_gpiochip_add_data(np, mm_gc, ppc4xx_gc);
arch/powerpc/platforms/8xx/cpm1.c: return
of_mm_gpiochip_add_data(np, mm_gc, cpm1_gc);
arch/powerpc/platforms/8xx/cpm1.c: return
of_mm_gpiochip_add_data(np, mm_gc, cpm1_gc);
arch/powerpc/sysdev/cpm_common.c: return
of_mm_gpiochip_add_data(np, mm_gc, cpm2_gc);
drivers/gpio/gpio-altera.c: ret = of_mm_gpiochip_add_data(node,
&altera_gc->mmchip, altera_gc);
drivers/gpio/gpio-mm-lantiq.c: return
of_mm_gpiochip_add_data(pdev->dev.of_node, &chip->mmchip, chip);
drivers/gpio/gpio-mpc5200.c: ret =
of_mm_gpiochip_add_data(ofdev->dev.of_node, &chip->mmchip, chip);
drivers/gpio/gpio-mpc5200.c: ret =
of_mm_gpiochip_add_data(ofdev->dev.of_node, &chip->mmchip, chip);
drivers/soc/fsl/qe/gpio.c: ret =
of_mm_gpiochip_add_data(np, mm_gc, qe_gc);
Aha PPC and MIPS, OK so not the most familiar territory for either of us to go
and fix.
I guess it's fine if you refactor this for the time being, but let's make it
go away soon.
Acked-by: Linus Walleij <linus.walleij@linaro.org>
Yours,
Linus Walleij
On Wed, Nov 09, 2022 at 01:19:30PM -0800, Dmitry Torokhov wrote:
> On Wed, Nov 09, 2022 at 05:07:33PM +0200, Andy Shevchenko wrote:
...
> > - of_node_put(mm_gc->gc.of_node);
> > - mm_gc->gc.of_node = of_node_get(np);
> > + fwnode_handle_put(mm_gc->gc.fwnode);
> > + mm_gc->gc.fwnode = fwnode_handle_get(fwnode);
>
> Can we reduce the patch to
>
> fwnode_handle_put(mm_gc->gc.fwnode);
> mm_gc->gc.fwnode = fwnode_handle_get(of_fwnode_handle(np));
>
> ?
Sure. As Linus pointed out, it's anyway temporary.
> I do not see a reason for converting the rest of invocations to fwnode
> given that this is clearly an OF API.
...which should go away.
@@ -919,14 +919,15 @@ int of_mm_gpiochip_add_data(struct device_node *np,
struct of_mm_gpio_chip *mm_gc,
void *data)
{
+ struct fwnode_handle *fwnode = of_fwnode_handle(np);
int ret = -ENOMEM;
struct gpio_chip *gc = &mm_gc->gc;
- gc->label = kasprintf(GFP_KERNEL, "%pOF", np);
+ gc->label = kasprintf(GFP_KERNEL, "%pfw", fwnode);
if (!gc->label)
goto err0;
- mm_gc->regs = of_iomap(np, 0);
+ mm_gc->regs = fwnode_iomap(fwnode, 0);
if (!mm_gc->regs)
goto err1;
@@ -935,8 +936,8 @@ int of_mm_gpiochip_add_data(struct device_node *np,
if (mm_gc->save_regs)
mm_gc->save_regs(mm_gc);
- of_node_put(mm_gc->gc.of_node);
- mm_gc->gc.of_node = of_node_get(np);
+ fwnode_handle_put(mm_gc->gc.fwnode);
+ mm_gc->gc.fwnode = fwnode_handle_get(fwnode);
ret = gpiochip_add_data(gc, data);
if (ret)
@@ -944,12 +945,12 @@ int of_mm_gpiochip_add_data(struct device_node *np,
return 0;
err2:
- of_node_put(np);
+ fwnode_handle_put(fwnode);
iounmap(mm_gc->regs);
err1:
kfree(gc->label);
err0:
- pr_err("%pOF: GPIO chip registration failed with status %d\n", np, ret);
+ pr_err("%pfw: GPIO chip registration failed with status %d\n", fwnode, ret);
return ret;
}
EXPORT_SYMBOL_GPL(of_mm_gpiochip_add_data);