* [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