Re: [PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put
Hi Linus, On Tue, Dec 22, 2015 at 1:47 PM, Linus Walleij wrote: > On Mon, Dec 21, 2015 at 5:39 PM, Julia Lawall wrote: >> for_each_child_of_node performs an of_node_get on each iteration, so a >> goto out of the loop requires an of_node_put. >> >> A simplified version of the semantic patch that fixes this problem is as >> follows (http://coccinelle.lip6.fr): > > Patch applied with Laurent's ACK. > > Geert: since I don't think you're gonna send me more pull > requests before the merge window I went ahead and applied > this directly, OK? You're reading my mind ;-) Thanks! Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- ge...@linux-m68k.org In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put
On Mon, Dec 21, 2015 at 5:39 PM, Julia Lawall wrote: > for_each_child_of_node performs an of_node_get on each iteration, so a > goto out of the loop requires an of_node_put. > > A simplified version of the semantic patch that fixes this problem is as > follows (http://coccinelle.lip6.fr): Patch applied with Laurent's ACK. Geert: since I don't think you're gonna send me more pull requests before the merge window I went ahead and applied this directly, OK? Yours, Linus Walleij -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put
Hi Linus, On Tue, Dec 22, 2015 at 1:47 PM, Linus Walleijwrote: > On Mon, Dec 21, 2015 at 5:39 PM, Julia Lawall wrote: >> for_each_child_of_node performs an of_node_get on each iteration, so a >> goto out of the loop requires an of_node_put. >> >> A simplified version of the semantic patch that fixes this problem is as >> follows (http://coccinelle.lip6.fr): > > Patch applied with Laurent's ACK. > > Geert: since I don't think you're gonna send me more pull > requests before the merge window I went ahead and applied > this directly, OK? You're reading my mind ;-) Thanks! Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- ge...@linux-m68k.org In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put
On Mon, Dec 21, 2015 at 5:39 PM, Julia Lawallwrote: > for_each_child_of_node performs an of_node_get on each iteration, so a > goto out of the loop requires an of_node_put. > > A simplified version of the semantic patch that fixes this problem is as > follows (http://coccinelle.lip6.fr): Patch applied with Laurent's ACK. Geert: since I don't think you're gonna send me more pull requests before the merge window I went ahead and applied this directly, OK? Yours, Linus Walleij -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put
Hi Julia, Thank you for the patch. On Monday 21 December 2015 17:39:46 Julia Lawall wrote: > for_each_child_of_node performs an of_node_get on each iteration, so a > goto out of the loop requires an of_node_put. > > A simplified version of the semantic patch that fixes this problem is as > follows (http://coccinelle.lip6.fr): > > // > @@ > local idexpression n; > expression e,e1; > identifier l; > @@ > > for_each_child_of_node(e1,n) { >... > ( >of_node_put(n); > >e = n > >return n; > > + of_node_put(n); > ? goto l; > ) >... > } > l: ... when != n > // > > Signed-off-by: Julia Lawall Reviewed-by: Laurent Pinchart > --- > drivers/pinctrl/sh-pfc/pinctrl.c |4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/drivers/pinctrl/sh-pfc/pinctrl.c > b/drivers/pinctrl/sh-pfc/pinctrl.c index 863c3e3..87b0a59 100644 > --- a/drivers/pinctrl/sh-pfc/pinctrl.c > +++ b/drivers/pinctrl/sh-pfc/pinctrl.c > @@ -273,8 +273,10 @@ static int sh_pfc_dt_node_to_map(struct pinctrl_dev > *pctldev, for_each_child_of_node(np, child) { > ret = sh_pfc_dt_subnode_to_map(pctldev, child, map, num_maps, > ); > - if (ret < 0) > + if (ret < 0) { > + of_node_put(child); > goto done; > + } > } > > /* If no mapping has been found in child nodes try the config node. */ -- Regards, Laurent Pinchart -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
[PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put
for_each_child_of_node performs an of_node_get on each iteration, so a goto out of the loop requires an of_node_put. A simplified version of the semantic patch that fixes this problem is as follows (http://coccinelle.lip6.fr): // @@ local idexpression n; expression e,e1; identifier l; @@ for_each_child_of_node(e1,n) { ... ( of_node_put(n); | e = n | return n; | + of_node_put(n); ? goto l; ) ... } l: ... when != n // Signed-off-by: Julia Lawall --- drivers/pinctrl/sh-pfc/pinctrl.c |4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/pinctrl/sh-pfc/pinctrl.c b/drivers/pinctrl/sh-pfc/pinctrl.c index 863c3e3..87b0a59 100644 --- a/drivers/pinctrl/sh-pfc/pinctrl.c +++ b/drivers/pinctrl/sh-pfc/pinctrl.c @@ -273,8 +273,10 @@ static int sh_pfc_dt_node_to_map(struct pinctrl_dev *pctldev, for_each_child_of_node(np, child) { ret = sh_pfc_dt_subnode_to_map(pctldev, child, map, num_maps, ); - if (ret < 0) + if (ret < 0) { + of_node_put(child); goto done; + } } /* If no mapping has been found in child nodes try the config node. */ -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put
Hi Julia, Thank you for the patch. On Monday 21 December 2015 17:39:46 Julia Lawall wrote: > for_each_child_of_node performs an of_node_get on each iteration, so a > goto out of the loop requires an of_node_put. > > A simplified version of the semantic patch that fixes this problem is as > follows (http://coccinelle.lip6.fr): > > // > @@ > local idexpression n; > expression e,e1; > identifier l; > @@ > > for_each_child_of_node(e1,n) { >... > ( >of_node_put(n); > >e = n > >return n; > > + of_node_put(n); > ? goto l; > ) >... > } > l: ... when != n > // > > Signed-off-by: Julia LawallReviewed-by: Laurent Pinchart > --- > drivers/pinctrl/sh-pfc/pinctrl.c |4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/drivers/pinctrl/sh-pfc/pinctrl.c > b/drivers/pinctrl/sh-pfc/pinctrl.c index 863c3e3..87b0a59 100644 > --- a/drivers/pinctrl/sh-pfc/pinctrl.c > +++ b/drivers/pinctrl/sh-pfc/pinctrl.c > @@ -273,8 +273,10 @@ static int sh_pfc_dt_node_to_map(struct pinctrl_dev > *pctldev, for_each_child_of_node(np, child) { > ret = sh_pfc_dt_subnode_to_map(pctldev, child, map, num_maps, > ); > - if (ret < 0) > + if (ret < 0) { > + of_node_put(child); > goto done; > + } > } > > /* If no mapping has been found in child nodes try the config node. */ -- Regards, Laurent Pinchart -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
[PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put
for_each_child_of_node performs an of_node_get on each iteration, so a goto out of the loop requires an of_node_put. A simplified version of the semantic patch that fixes this problem is as follows (http://coccinelle.lip6.fr): // @@ local idexpression n; expression e,e1; identifier l; @@ for_each_child_of_node(e1,n) { ... ( of_node_put(n); | e = n | return n; | + of_node_put(n); ? goto l; ) ... } l: ... when != n // Signed-off-by: Julia Lawall--- drivers/pinctrl/sh-pfc/pinctrl.c |4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/pinctrl/sh-pfc/pinctrl.c b/drivers/pinctrl/sh-pfc/pinctrl.c index 863c3e3..87b0a59 100644 --- a/drivers/pinctrl/sh-pfc/pinctrl.c +++ b/drivers/pinctrl/sh-pfc/pinctrl.c @@ -273,8 +273,10 @@ static int sh_pfc_dt_node_to_map(struct pinctrl_dev *pctldev, for_each_child_of_node(np, child) { ret = sh_pfc_dt_subnode_to_map(pctldev, child, map, num_maps, ); - if (ret < 0) + if (ret < 0) { + of_node_put(child); goto done; + } } /* If no mapping has been found in child nodes try the config node. */ -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/