Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751663AbbLUUqM (ORCPT ); Mon, 21 Dec 2015 15:46:12 -0500 Received: from galahad.ideasonboard.com ([185.26.127.97]:50785 "EHLO galahad.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750802AbbLUUqJ (ORCPT ); Mon, 21 Dec 2015 15:46:09 -0500 From: Laurent Pinchart To: Julia Lawall Cc: kernel-janitors@vger.kernel.org, Linus Walleij , linux-sh@vger.kernel.org, linux-gpio@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 3/5] pinctrl: sh-pfc: add missing of_node_put Date: Mon, 21 Dec 2015 22:46:07 +0200 Message-ID: <8848273.KV8URmu3um@avalon> User-Agent: KMail/4.14.8 (Linux/4.1.12-gentoo; KDE/4.14.8; x86_64; ; ) In-Reply-To: <1450715988-4770-4-git-send-email-Julia.Lawall@lip6.fr> References: <1450715988-4770-1-git-send-email-Julia.Lawall@lip6.fr> <1450715988-4770-4-git-send-email-Julia.Lawall@lip6.fr> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1697 Lines: 70 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, > &index); > - 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 majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/