public inbox for cip-dev@lists.cip-project.org
 help / color / mirror / Atom feed
* [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property
@ 2019-11-08 11:59 Johnson CH Chen (陳昭勳)
  2019-11-08 13:18 ` Fabrizio Castro
  0 siblings, 1 reply; 5+ messages in thread
From: Johnson CH Chen (陳昭勳) @ 2019-11-08 11:59 UTC (permalink / raw)
  To: cip-dev

Hi Fabrizio Castro,

I find a kernel panic issue by gpio when I upgrade kernel to 4.4.182-cip34 with Freescale LS1021A (gpiochip is mpc8xxx series):

Kernel log shows ?Unable to handle kernel NULL pointer dereference at virtual address 000000b4.?

Subsequently, I find the commit baff4777cdb80256cd24dede2a3d0af761356307 (gpiolib: Support 'gpio-reserved-ranges' property) could result in kernel panic because the code ?*np= chip->dev->of_node? is executed when chip->dev is NULL:

diff --git a/drivers/gpio/gpiolib-of.c b/drivers/gpio/gpiolib-of.c
index 5fe34a9df3e6..ec642bf1d976 100644
--- a/drivers/gpio/gpiolib-of.c
+++ b/drivers/gpio/gpiolib-of.c

+static void of_gpiochip_init_valid_mask(struct gpio_chip *chip)
+{
+      int len, i;
+      u32 start, count;
+      struct device_node *np = chip->dev->of_node;
+
+      len = of_property_count_u32_elems(np,  "gpio-reserved-ranges");
+      if (len < 0 || len % 2 != 0)
+              return;
+
+      for (i = 0; i < len; i += 2) {
+              of_property_read_u32_index(np, "gpio-reserved-ranges",
+                                         i, &start);
+              of_property_read_u32_index(np, "gpio-reserved-ranges",
+                                         i + 1, &count);
+              if (start >= chip->ngpio || start + count >= chip->ngpio)
+                      continue;
+
+              bitmap_clear(chip->valid_mask, start, count);
+      }
+};
+

diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
index adb474089733..487a86495163 100644
--- a/drivers/gpio/gpiolib.c
+++ b/drivers/gpio/gpiolib.c
@@ -292,6 +292,43 @@ static unsigned long *gpiochip_allocate_mask(struct gpio_chip *chip)
      return p;
}

+static int gpiochip_init_valid_mask(struct gpio_chip *gpiochip)
+{
+#ifdef CONFIG_OF_GPIO
+      int size;
+      struct device_node *np = gpiochip->dev->of_node;
+
+      size = of_property_count_u32_elems(np,  "gpio-reserved-ranges");
+      if (size > 0 && size % 2 == 0)
+              gpiochip->need_valid_mask = true;
+#endif
+
+      if (!gpiochip->need_valid_mask)
+              return 0;
+
+      gpiochip->valid_mask = gpiochip_allocate_mask(gpiochip);
+      if (!gpiochip->valid_mask)
+              return -ENOMEM;
+
+      return 0;
+}
+

Could you help me understand why we need to replaced chip->of_node with chip->dev->of_node?

The following two items I try have no kernel panic:

1. For gpio drivers:

It?s fine and no kernel panic issue if probe(struct platform_device *pdev) in gpio drivers executes the following codes:

struct cpio_chip *gc;
gc->dev = &pdev->dev; //Put platform?s dev to gpiochip?s dev, and of_node info in pdev->dev->of_node also put in gpiochip structure.

But some gpio drivers doesn?t do this, such as gpio-mpc8xxx.c (mpc8xxx series), and result in kernel panic when use this commit.

2. For gpiolib:

//set the following code in gpiolib.c and gpiolib-of.c
struct device_node *np = gpiochip->of_node;

Device node of platform will put in gpio chip when of_mm_gpiochip_add() is executed:

int of_mm_gpiochip_add(struct device_node *np,
                       struct of_mm_gpio_chip *mm_gc)
{
        int ret = -ENOMEM;
        struct gpio_chip *gc = &mm_gc->gc;
?..
        mm_gc->gc.of_node = np;
}

It?s seems chip->of_node is good.

Thanks,
Johnson
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.cip-project.org/pipermail/cip-dev/attachments/20191108/02a5be16/attachment-0001.html>

^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property
  2019-11-08 11:59 [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property Johnson CH Chen (陳昭勳)
@ 2019-11-08 13:18 ` Fabrizio Castro
  2019-11-08 14:25   ` Johnson CH Chen (陳昭勳)
  2019-11-08 21:27   ` Pavel Machek
  0 siblings, 2 replies; 5+ messages in thread
From: Fabrizio Castro @ 2019-11-08 13:18 UTC (permalink / raw)
  To: cip-dev

Hi Johnson,

Thank you for reporting this.

> From: Johnson CH Chen (???) <JohnsonCH.Chen@moxa.com>
> Subject: [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property
> 
> Hi Fabrizio Castro,
> 
> 
> 
> I find a kernel panic issue by gpio when I upgrade kernel to 4.4.182-cip34 with Freescale LS1021A (gpiochip is mpc8xxx series):
> 
> 
> 
> Kernel log shows ?Unable to handle kernel NULL pointer dereference at virtual address 000000b4.?
> 
> 
> 
> Subsequently, I find the commit baff4777cdb80256cd24dede2a3d0af761356307 (gpiolib: Support 'gpio-reserved-ranges' property)
> could result in kernel panic because the code ?*np= chip->dev->of_node? is executed when chip->dev is NULL:
> 
> 
> 
> diff --git a/drivers/gpio/gpiolib-of.c b/drivers/gpio/gpiolib-of.c
> 
> index 5fe34a9df3e6..ec642bf1d976 100644
> 
> --- a/drivers/gpio/gpiolib-of.c
> 
> +++ b/drivers/gpio/gpiolib-of.c
> 
> 
> 
> +static void of_gpiochip_init_valid_mask(struct gpio_chip *chip)
> 
> +{
> 
> +      int len, i;
> 
> +      u32 start, count;
> 
> +      struct device_node *np = chip->dev->of_node;
> 
> +
> 
> +      len = of_property_count_u32_elems(np,  "gpio-reserved-ranges");
> 
> +      if (len < 0 || len % 2 != 0)
> 
> +              return;
> 
> +
> 
> +      for (i = 0; i < len; i += 2) {
> 
> +              of_property_read_u32_index(np, "gpio-reserved-ranges",
> 
> +                                         i, &start);
> 
> +              of_property_read_u32_index(np, "gpio-reserved-ranges",
> 
> +                                         i + 1, &count);
> 
> +              if (start >= chip->ngpio || start + count >= chip->ngpio)
> 
> +                      continue;
> 
> +
> 
> +              bitmap_clear(chip->valid_mask, start, count);
> 
> +      }
> 
> +};
> 
> +
> 
> 
> 
> diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
> 
> index adb474089733..487a86495163 100644
> 
> --- a/drivers/gpio/gpiolib.c
> 
> +++ b/drivers/gpio/gpiolib.c
> 
> @@ -292,6 +292,43 @@ static unsigned long *gpiochip_allocate_mask(struct gpio_chip *chip)
> 
>       return p;
> 
> }
> 
> 
> 
> +static int gpiochip_init_valid_mask(struct gpio_chip *gpiochip)
> 
> +{
> 
> +#ifdef CONFIG_OF_GPIO
> 
> +      int size;
> 
> +      struct device_node *np = gpiochip->dev->of_node;
> 
> +
> 
> +      size = of_property_count_u32_elems(np,  "gpio-reserved-ranges");
> 
> +      if (size > 0 && size % 2 == 0)
> 
> +              gpiochip->need_valid_mask = true;
> 
> +#endif
> 
> +
> 
> +      if (!gpiochip->need_valid_mask)
> 
> +              return 0;
> 
> +
> 
> +      gpiochip->valid_mask = gpiochip_allocate_mask(gpiochip);
> 
> +      if (!gpiochip->valid_mask)
> 
> +              return -ENOMEM;
> 
> +
> 
> +      return 0;
> 
> +}
> 
> +
> 
> 
> 
> Could you help me understand why we need to replaced chip->of_node with chip->dev->of_node?

It looks like that solved the issues I was seeing, but it was short sighted as some drivers don't
initialize that.

I think I need to make some adjustments to this patch, and I also think I need to backport patch:
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?h=v5.4-rc6&id=6ff0497402ef7269ee6a72f62eb85adaa7a4768e

I need to make a couple of experiments, and I'll send something across for you to try if you don't
mind.

Thanks,
Fab

> 
> 
> 
> The following two items I try have no kernel panic:
> 
> 
> 
> 1. For gpio drivers:
> 
> 
> 
> It?s fine and no kernel panic issue if probe(struct platform_device *pdev) in gpio drivers executes the following codes:
> 
> 
> 
> struct cpio_chip *gc;
> 
> gc->dev = &pdev->dev; //Put platform?s dev to gpiochip?s dev, and of_node info in pdev->dev->of_node also put in gpiochip
> structure.
> 
> 
> 
> But some gpio drivers doesn?t do this, such as gpio-mpc8xxx.c (mpc8xxx series), and result in kernel panic when use this commit.
> 
> 
> 
> 2. For gpiolib:
> 
> 
> 
> //set the following code in gpiolib.c and gpiolib-of.c
> 
> struct device_node *np = gpiochip->of_node;
> 
> 
> 
> Device node of platform will put in gpio chip when of_mm_gpiochip_add() is executed:
> 
> 
> 
> int of_mm_gpiochip_add(struct device_node *np,
> 
>                        struct of_mm_gpio_chip *mm_gc)
> 
> {
> 
>         int ret = -ENOMEM;
> 
>         struct gpio_chip *gc = &mm_gc->gc;
> 
> ?..
> 
>         mm_gc->gc.of_node = np;
> 
> }
> 
> 
> 
> It?s seems chip->of_node is good.
> 
> 
> 
> Thanks,
> 
> Johnson

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property
  2019-11-08 13:18 ` Fabrizio Castro
@ 2019-11-08 14:25   ` Johnson CH Chen (陳昭勳)
  2019-11-08 21:27   ` Pavel Machek
  1 sibling, 0 replies; 5+ messages in thread
From: Johnson CH Chen (陳昭勳) @ 2019-11-08 14:25 UTC (permalink / raw)
  To: cip-dev

Hi Fab,

Thanks your info. It seems be the same problem for of_node inconsistency of gpiolib. I am glad to test the patch and some patches you provide me later.

Thanks,
Johnson


?? iOS ? Outlook<https://aka.ms/o0ukef>
________________________________
???: Fabrizio Castro <fabrizio.castro@bp.renesas.com>
????: Friday, November 8, 2019 9:18:30 PM
???: Johnson CH Chen (???) <JohnsonCH.Chen@moxa.com>
??: cip-dev at lists.cip-project.org <cip-dev@lists.cip-project.org>; Biju Das <biju.das@bp.renesas.com>
??: RE: [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property

Hi Johnson,

Thank you for reporting this.

> From: Johnson CH Chen (???) <JohnsonCH.Chen@moxa.com>
> Subject: [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property
>
> Hi Fabrizio Castro,
>
>
>
> I find a kernel panic issue by gpio when I upgrade kernel to 4.4.182-cip34 with Freescale LS1021A (gpiochip is mpc8xxx series):
>
>
>
> Kernel log shows ?Unable to handle kernel NULL pointer dereference at virtual address 000000b4.?
>
>
>
> Subsequently, I find the commit baff4777cdb80256cd24dede2a3d0af761356307 (gpiolib: Support 'gpio-reserved-ranges' property)
> could result in kernel panic because the code ?*np= chip->dev->of_node? is executed when chip->dev is NULL:
>
>
>
> diff --git a/drivers/gpio/gpiolib-of.c b/drivers/gpio/gpiolib-of.c
>
> index 5fe34a9df3e6..ec642bf1d976 100644
>
> --- a/drivers/gpio/gpiolib-of.c
>
> +++ b/drivers/gpio/gpiolib-of.c
>
>
>
> +static void of_gpiochip_init_valid_mask(struct gpio_chip *chip)
>
> +{
>
> +      int len, i;
>
> +      u32 start, count;
>
> +      struct device_node *np = chip->dev->of_node;
>
> +
>
> +      len = of_property_count_u32_elems(np,  "gpio-reserved-ranges");
>
> +      if (len < 0 || len % 2 != 0)
>
> +              return;
>
> +
>
> +      for (i = 0; i < len; i += 2) {
>
> +              of_property_read_u32_index(np, "gpio-reserved-ranges",
>
> +                                         i, &start);
>
> +              of_property_read_u32_index(np, "gpio-reserved-ranges",
>
> +                                         i + 1, &count);
>
> +              if (start >= chip->ngpio || start + count >= chip->ngpio)
>
> +                      continue;
>
> +
>
> +              bitmap_clear(chip->valid_mask, start, count);
>
> +      }
>
> +};
>
> +
>
>
>
> diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
>
> index adb474089733..487a86495163 100644
>
> --- a/drivers/gpio/gpiolib.c
>
> +++ b/drivers/gpio/gpiolib.c
>
> @@ -292,6 +292,43 @@ static unsigned long *gpiochip_allocate_mask(struct gpio_chip *chip)
>
>       return p;
>
> }
>
>
>
> +static int gpiochip_init_valid_mask(struct gpio_chip *gpiochip)
>
> +{
>
> +#ifdef CONFIG_OF_GPIO
>
> +      int size;
>
> +      struct device_node *np = gpiochip->dev->of_node;
>
> +
>
> +      size = of_property_count_u32_elems(np,  "gpio-reserved-ranges");
>
> +      if (size > 0 && size % 2 == 0)
>
> +              gpiochip->need_valid_mask = true;
>
> +#endif
>
> +
>
> +      if (!gpiochip->need_valid_mask)
>
> +              return 0;
>
> +
>
> +      gpiochip->valid_mask = gpiochip_allocate_mask(gpiochip);
>
> +      if (!gpiochip->valid_mask)
>
> +              return -ENOMEM;
>
> +
>
> +      return 0;
>
> +}
>
> +
>
>
>
> Could you help me understand why we need to replaced chip->of_node with chip->dev->of_node?

It looks like that solved the issues I was seeing, but it was short sighted as some drivers don't
initialize that.

I think I need to make some adjustments to this patch, and I also think I need to backport patch:
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?h=v5.4-rc6&id=6ff0497402ef7269ee6a72f62eb85adaa7a4768e

I need to make a couple of experiments, and I'll send something across for you to try if you don't
mind.

Thanks,
Fab

>
>
>
> The following two items I try have no kernel panic:
>
>
>
> 1. For gpio drivers:
>
>
>
> It?s fine and no kernel panic issue if probe(struct platform_device *pdev) in gpio drivers executes the following codes:
>
>
>
> struct cpio_chip *gc;
>
> gc->dev = &pdev->dev; //Put platform?s dev to gpiochip?s dev, and of_node info in pdev->dev->of_node also put in gpiochip
> structure.
>
>
>
> But some gpio drivers doesn?t do this, such as gpio-mpc8xxx.c (mpc8xxx series), and result in kernel panic when use this commit.
>
>
>
> 2. For gpiolib:
>
>
>
> //set the following code in gpiolib.c and gpiolib-of.c
>
> struct device_node *np = gpiochip->of_node;
>
>
>
> Device node of platform will put in gpio chip when of_mm_gpiochip_add() is executed:
>
>
>
> int of_mm_gpiochip_add(struct device_node *np,
>
>                        struct of_mm_gpio_chip *mm_gc)
>
> {
>
>         int ret = -ENOMEM;
>
>         struct gpio_chip *gc = &mm_gc->gc;
>
> ?..
>
>         mm_gc->gc.of_node = np;
>
> }
>
>
>
> It?s seems chip->of_node is good.
>
>
>
> Thanks,
>
> Johnson

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.cip-project.org/pipermail/cip-dev/attachments/20191108/24940fb1/attachment-0001.html>

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property
  2019-11-08 13:18 ` Fabrizio Castro
  2019-11-08 14:25   ` Johnson CH Chen (陳昭勳)
@ 2019-11-08 21:27   ` Pavel Machek
  2019-11-11  4:08     ` Johnson CH Chen (陳昭勳)
  1 sibling, 1 reply; 5+ messages in thread
From: Pavel Machek @ 2019-11-08 21:27 UTC (permalink / raw)
  To: cip-dev

Hi!

> Thank you for reporting this.

Is it -cip problem, or -stable problem?

Best regards,
								Pavel
-- 
DENX Software Engineering GmbH,      Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 195 bytes
Desc: not available
URL: <http://lists.cip-project.org/pipermail/cip-dev/attachments/20191108/19a5cab4/attachment.sig>

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property
  2019-11-08 21:27   ` Pavel Machek
@ 2019-11-11  4:08     ` Johnson CH Chen (陳昭勳)
  0 siblings, 0 replies; 5+ messages in thread
From: Johnson CH Chen (陳昭勳) @ 2019-11-11  4:08 UTC (permalink / raw)
  To: cip-dev

Hi,

I try stable kernel (Linux 4.4.194) with my system. It's good and without gpio's kernel panic phenomena. Just for your reference.

Thanks,
Johnson
-----Original Message-----
From: Pavel Machek <pavel@denx.de> 
Sent: Saturday, November 9, 2019 5:27 AM
To: Fabrizio Castro <fabrizio.castro@bp.renesas.com>
Cc: Johnson CH Chen (???) <JohnsonCH.Chen@moxa.com>; cip-dev at lists.cip-project.org; Biju Das <biju.das@bp.renesas.com>
Subject: Re: [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property

Hi!

> Thank you for reporting this.

Is it -cip problem, or -stable problem?

Best regards,
								Pavel
-- 
DENX Software Engineering GmbH,      Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2019-11-11  4:08 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-11-08 11:59 [cip-dev] [PATCH] gpiolib: Support 'gpio-reserved-ranges' property Johnson CH Chen (陳昭勳)
2019-11-08 13:18 ` Fabrizio Castro
2019-11-08 14:25   ` Johnson CH Chen (陳昭勳)
2019-11-08 21:27   ` Pavel Machek
2019-11-11  4:08     ` Johnson CH Chen (陳昭勳)

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox