Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752929AbbKPRMe (ORCPT ); Mon, 16 Nov 2015 12:12:34 -0500 Received: from mail-gw1-out.broadcom.com ([216.31.210.62]:11602 "EHLO mail-gw1-out.broadcom.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752631AbbKPRMa (ORCPT ); Mon, 16 Nov 2015 12:12:30 -0500 X-IronPort-AV: E=Sophos;i="5.20,303,1444719600"; d="scan'208";a="80749691" Subject: Re: [PATCH 7/7] phy: cygnus: pcie: add missing of_node_put To: Julia Lawall , Kishon Vijay Abraham I References: <1447673600-8881-1-git-send-email-Julia.Lawall@lip6.fr> <1447673600-8881-8-git-send-email-Julia.Lawall@lip6.fr> CC: , Scott Branden , Jon Mason , , , , Russell King - ARM Linux , Thomas Petazzoni , Andrew Lunn , "Bjorn Helgaas" , Jason Cooper From: Ray Jui Message-ID: <564A0E7A.4080105@broadcom.com> Date: Mon, 16 Nov 2015 09:12:26 -0800 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:38.0) Gecko/20100101 Thunderbird/38.3.0 MIME-Version: 1.0 In-Reply-To: <1447673600-8881-8-git-send-email-Julia.Lawall@lip6.fr> Content-Type: text/plain; charset="windows-1252"; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2738 Lines: 98 Hi Julia, On 11/16/2015 3:33 AM, Julia Lawall wrote: > for_each_available_child_of_node performs an of_node_get on each iteration, > so a return from the middle of the loop requires an of_node_put. > > A simplified version of the semantic patch that finds this problem is as > follows (http://coccinelle.lip6.fr): > > // > @@ > expression root,e; > local idexpression child; > @@ > > for_each_available_child_of_node(root, child) { > ... when != of_node_put(child) > when != e = child > ( > return child; > | > * return ...; > ) > ... > } > // > > Signed-off-by: Julia Lawall > > --- > drivers/phy/phy-bcm-cygnus-pcie.c | 16 ++++++++++++---- > 1 file changed, 12 insertions(+), 4 deletions(-) > > diff --git a/drivers/phy/phy-bcm-cygnus-pcie.c b/drivers/phy/phy-bcm-cygnus-pcie.c > index 7ad72b7..082c03f 100644 > --- a/drivers/phy/phy-bcm-cygnus-pcie.c > +++ b/drivers/phy/phy-bcm-cygnus-pcie.c > @@ -128,6 +128,7 @@ static int cygnus_pcie_phy_probe(struct platform_device *pdev) > struct phy_provider *provider; > struct resource *res; > unsigned cnt = 0; > + int ret; > > if (of_get_child_count(node) == 0) { > dev_err(dev, "PHY no child node\n"); > @@ -154,24 +155,28 @@ static int cygnus_pcie_phy_probe(struct platform_device *pdev) > if (of_property_read_u32(child, "reg", &id)) { > dev_err(dev, "missing reg property for %s\n", > child->name); > - return -EINVAL; > + ret = -EINVAL; > + goto put_child; > } > > if (id >= MAX_NUM_PHYS) { > dev_err(dev, "invalid PHY id: %u\n", id); > - return -EINVAL; > + ret = -EINVAL; > + goto put_child; > } > > if (core->phys[id].phy) { > dev_err(dev, "duplicated PHY id: %u\n", id); > - return -EINVAL; > + ret = -EINVAL; > + goto put_child; > } > > p = &core->phys[id]; > p->phy = devm_phy_create(dev, child, &cygnus_pcie_phy_ops); > if (IS_ERR(p->phy)) { > dev_err(dev, "failed to create PHY\n"); > - return PTR_ERR(p->phy); > + ret = PTR_ERR(p->phy); > + goto put_child; > } > > p->core = core; > @@ -191,6 +196,9 @@ static int cygnus_pcie_phy_probe(struct platform_device *pdev) > dev_dbg(dev, "registered %u PCIe PHY(s)\n", cnt); > > return 0; > +put_child: > + of_node_put(child); > + return ret; > } > > static const struct of_device_id cygnus_pcie_phy_match_table[] = { > This fix looks good to me. Thanks! Reviewed-by: Ray Jui -- 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/