diff mbox series

[next] gpiolib: check for parent device in devprop_gpiochip_set_names()

Message ID 20200916134327.3435-1-brgl@bgdev.pl
State New
Headers show
Series [next] gpiolib: check for parent device in devprop_gpiochip_set_names() | expand

Commit Message

Bartosz Golaszewski Sept. 16, 2020, 1:43 p.m. UTC
From: Bartosz Golaszewski <bgolaszewski@baylibre.com>

It's possible for a GPIO chip to not have a parent device (whose
properties we inspect for 'gpio-line-names'). In this case we should
simply return from devprop_gpiochip_set_names(). Add an appropriate
check for this use-case.

Fixes: 7cba1a4d5e16 ("gpiolib: generalize devprop_gpiochip_set_names() for device properties")
Reported-by: Anders Roxell <anders.roxell@linaro.org>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
---
 drivers/gpio/gpiolib.c | 3 +++
 1 file changed, 3 insertions(+)

Comments

Andy Shevchenko Sept. 16, 2020, 2:29 p.m. UTC | #1
On Wed, Sep 16, 2020 at 03:43:27PM +0200, Bartosz Golaszewski wrote:
> From: Bartosz Golaszewski <bgolaszewski@baylibre.com>

> 

> It's possible for a GPIO chip to not have a parent device (whose

> properties we inspect for 'gpio-line-names'). In this case we should

> simply return from devprop_gpiochip_set_names(). Add an appropriate

> check for this use-case.


Ah, nice!
Can we also add a small comment in the code, b/c w/o it I would stumble over
and eager to remove looks-as-unneeded check?
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>


> Fixes: 7cba1a4d5e16 ("gpiolib: generalize devprop_gpiochip_set_names() for device properties")

> Reported-by: Anders Roxell <anders.roxell@linaro.org>

> Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>

> ---

>  drivers/gpio/gpiolib.c | 3 +++

>  1 file changed, 3 insertions(+)

> 

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

> index b7b608ef9..ac2c77edc 100644

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

> +++ b/drivers/gpio/gpiolib.c

> @@ -375,6 +375,9 @@ static int devprop_gpiochip_set_names(struct gpio_chip *chip)

>  	int ret, i;

>  	int count;

>  

> +	if (!dev)

> +		return 0;

> +

>  	count = device_property_string_array_count(dev, "gpio-line-names");

>  	if (count < 0)

>  		return 0;

> -- 

> 2.26.1

> 


-- 
With Best Regards,
Andy Shevchenko
Bartosz Golaszewski Sept. 16, 2020, 2:47 p.m. UTC | #2
On Wed, Sep 16, 2020 at 4:29 PM Andy Shevchenko
<andriy.shevchenko@linux.intel.com> wrote:
>

> On Wed, Sep 16, 2020 at 03:43:27PM +0200, Bartosz Golaszewski wrote:

> > From: Bartosz Golaszewski <bgolaszewski@baylibre.com>

> >

> > It's possible for a GPIO chip to not have a parent device (whose

> > properties we inspect for 'gpio-line-names'). In this case we should

> > simply return from devprop_gpiochip_set_names(). Add an appropriate

> > check for this use-case.

>

> Ah, nice!

> Can we also add a small comment in the code, b/c w/o it I would stumble over

> and eager to remove looks-as-unneeded check?

> Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>


Sure, I'll make a v2 then.

Bart
Anders Roxell Sept. 16, 2020, 9:25 p.m. UTC | #3
On Wed, 16 Sep 2020 at 16:47, Bartosz Golaszewski <brgl@bgdev.pl> wrote:
>

> On Wed, Sep 16, 2020 at 4:29 PM Andy Shevchenko

> <andriy.shevchenko@linux.intel.com> wrote:

> >

> > On Wed, Sep 16, 2020 at 03:43:27PM +0200, Bartosz Golaszewski wrote:

> > > From: Bartosz Golaszewski <bgolaszewski@baylibre.com>

> > >

> > > It's possible for a GPIO chip to not have a parent device (whose

> > > properties we inspect for 'gpio-line-names'). In this case we should

> > > simply return from devprop_gpiochip_set_names(). Add an appropriate

> > > check for this use-case.

> >

> > Ah, nice!

> > Can we also add a small comment in the code, b/c w/o it I would stumble over

> > and eager to remove looks-as-unneeded check?

> > Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>


Tested-by: Anders Roxell <anders.roxell@linaro.org>
diff mbox series

Patch

diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
index b7b608ef9..ac2c77edc 100644
--- a/drivers/gpio/gpiolib.c
+++ b/drivers/gpio/gpiolib.c
@@ -375,6 +375,9 @@  static int devprop_gpiochip_set_names(struct gpio_chip *chip)
 	int ret, i;
 	int count;
 
+	if (!dev)
+		return 0;
+
 	count = device_property_string_array_count(dev, "gpio-line-names");
 	if (count < 0)
 		return 0;