diff mbox series

gpio: gpio-tps68470: remove platform_set_drvdata() + cleanup probe

Message ID 20210514094108.28890-1-aardelean@deviqon.com
State Accepted
Commit 91d594b2db51f680ba52862d1bbe14801b4dcd54
Headers show
Series gpio: gpio-tps68470: remove platform_set_drvdata() + cleanup probe | expand

Commit Message

Alexandru Ardelean May 14, 2021, 9:41 a.m. UTC
The platform_set_drvdata() call is only useful if we need to retrieve back
the private information.
Since the driver doesn't do that, it's not useful to have it.

If this is removed, we can also just do a direct return on
devm_gpiochip_add_data(). We don't need to print that this call failed as
there are other ways to log/see this during probe.

Signed-off-by: Alexandru Ardelean <aardelean@deviqon.com>
---
 drivers/gpio/gpio-tps68470.c | 12 +-----------
 1 file changed, 1 insertion(+), 11 deletions(-)

Comments

Bartosz Golaszewski May 21, 2021, 1:52 p.m. UTC | #1
On Fri, May 14, 2021 at 11:41 AM Alexandru Ardelean
<aardelean@deviqon.com> wrote:
>

> The platform_set_drvdata() call is only useful if we need to retrieve back

> the private information.

> Since the driver doesn't do that, it's not useful to have it.

>

> If this is removed, we can also just do a direct return on

> devm_gpiochip_add_data(). We don't need to print that this call failed as

> there are other ways to log/see this during probe.

>

> Signed-off-by: Alexandru Ardelean <aardelean@deviqon.com>

> ---

>  drivers/gpio/gpio-tps68470.c | 12 +-----------

>  1 file changed, 1 insertion(+), 11 deletions(-)

>

> diff --git a/drivers/gpio/gpio-tps68470.c b/drivers/gpio/gpio-tps68470.c

> index f7f5f770e0fb..423b7bc30ae8 100644

> --- a/drivers/gpio/gpio-tps68470.c

> +++ b/drivers/gpio/gpio-tps68470.c

> @@ -125,7 +125,6 @@ static const char *tps68470_names[TPS68470_N_GPIO] = {

>  static int tps68470_gpio_probe(struct platform_device *pdev)

>  {

>         struct tps68470_gpio_data *tps68470_gpio;

> -       int ret;

>

>         tps68470_gpio = devm_kzalloc(&pdev->dev, sizeof(*tps68470_gpio),

>                                      GFP_KERNEL);

> @@ -146,16 +145,7 @@ static int tps68470_gpio_probe(struct platform_device *pdev)

>         tps68470_gpio->gc.base = -1;

>         tps68470_gpio->gc.parent = &pdev->dev;

>

> -       ret = devm_gpiochip_add_data(&pdev->dev, &tps68470_gpio->gc,

> -                                    tps68470_gpio);

> -       if (ret < 0) {

> -               dev_err(&pdev->dev, "Failed to register gpio_chip: %d\n", ret);

> -               return ret;

> -       }

> -

> -       platform_set_drvdata(pdev, tps68470_gpio);

> -

> -       return ret;

> +       return devm_gpiochip_add_data(&pdev->dev, &tps68470_gpio->gc, tps68470_gpio);

>  }

>

>  static struct platform_driver tps68470_gpio_driver = {

> --

> 2.31.1

>


Applied. I got confused by the dev_get_drvdata() call earlier in probe
but this one's for the parent.

Thanks,
Bart
Alexandru Ardelean May 21, 2021, 5:46 p.m. UTC | #2
On Fri, 21 May 2021 at 16:52, Bartosz Golaszewski
<bgolaszewski@baylibre.com> wrote:
>

> On Fri, May 14, 2021 at 11:41 AM Alexandru Ardelean

> <aardelean@deviqon.com> wrote:

> >

> > The platform_set_drvdata() call is only useful if we need to retrieve back

> > the private information.

> > Since the driver doesn't do that, it's not useful to have it.

> >

> > If this is removed, we can also just do a direct return on

> > devm_gpiochip_add_data(). We don't need to print that this call failed as

> > there are other ways to log/see this during probe.

> >

> > Signed-off-by: Alexandru Ardelean <aardelean@deviqon.com>

> > ---

> >  drivers/gpio/gpio-tps68470.c | 12 +-----------

> >  1 file changed, 1 insertion(+), 11 deletions(-)

> >

> > diff --git a/drivers/gpio/gpio-tps68470.c b/drivers/gpio/gpio-tps68470.c

> > index f7f5f770e0fb..423b7bc30ae8 100644

> > --- a/drivers/gpio/gpio-tps68470.c

> > +++ b/drivers/gpio/gpio-tps68470.c

> > @@ -125,7 +125,6 @@ static const char *tps68470_names[TPS68470_N_GPIO] = {

> >  static int tps68470_gpio_probe(struct platform_device *pdev)

> >  {

> >         struct tps68470_gpio_data *tps68470_gpio;

> > -       int ret;

> >

> >         tps68470_gpio = devm_kzalloc(&pdev->dev, sizeof(*tps68470_gpio),

> >                                      GFP_KERNEL);

> > @@ -146,16 +145,7 @@ static int tps68470_gpio_probe(struct platform_device *pdev)

> >         tps68470_gpio->gc.base = -1;

> >         tps68470_gpio->gc.parent = &pdev->dev;

> >

> > -       ret = devm_gpiochip_add_data(&pdev->dev, &tps68470_gpio->gc,

> > -                                    tps68470_gpio);

> > -       if (ret < 0) {

> > -               dev_err(&pdev->dev, "Failed to register gpio_chip: %d\n", ret);

> > -               return ret;

> > -       }

> > -

> > -       platform_set_drvdata(pdev, tps68470_gpio);

> > -

> > -       return ret;

> > +       return devm_gpiochip_add_data(&pdev->dev, &tps68470_gpio->gc, tps68470_gpio);

> >  }

> >

> >  static struct platform_driver tps68470_gpio_driver = {

> > --

> > 2.31.1

> >

>

> Applied. I got confused by the dev_get_drvdata() call earlier in probe

> but this one's for the parent.


Yes.
I initially got confused as well about it.

This pattern seems to be similar in other drivers as well; usually MFD devices.

>

> Thanks,

> Bart
diff mbox series

Patch

diff --git a/drivers/gpio/gpio-tps68470.c b/drivers/gpio/gpio-tps68470.c
index f7f5f770e0fb..423b7bc30ae8 100644
--- a/drivers/gpio/gpio-tps68470.c
+++ b/drivers/gpio/gpio-tps68470.c
@@ -125,7 +125,6 @@  static const char *tps68470_names[TPS68470_N_GPIO] = {
 static int tps68470_gpio_probe(struct platform_device *pdev)
 {
 	struct tps68470_gpio_data *tps68470_gpio;
-	int ret;
 
 	tps68470_gpio = devm_kzalloc(&pdev->dev, sizeof(*tps68470_gpio),
 				     GFP_KERNEL);
@@ -146,16 +145,7 @@  static int tps68470_gpio_probe(struct platform_device *pdev)
 	tps68470_gpio->gc.base = -1;
 	tps68470_gpio->gc.parent = &pdev->dev;
 
-	ret = devm_gpiochip_add_data(&pdev->dev, &tps68470_gpio->gc,
-				     tps68470_gpio);
-	if (ret < 0) {
-		dev_err(&pdev->dev, "Failed to register gpio_chip: %d\n", ret);
-		return ret;
-	}
-
-	platform_set_drvdata(pdev, tps68470_gpio);
-
-	return ret;
+	return devm_gpiochip_add_data(&pdev->dev, &tps68470_gpio->gc, tps68470_gpio);
 }
 
 static struct platform_driver tps68470_gpio_driver = {