Received: by 2002:a25:b794:0:0:0:0:0 with SMTP id n20csp6455411ybh; Thu, 8 Aug 2019 00:17:46 -0700 (PDT) X-Google-Smtp-Source: APXvYqyFqP/pgoZ8b1G9igpw99Z5+PnyF9W1Maa67ffFKJStupoy+aUEjTmgo8J/sSNBq2OhjL/P X-Received: by 2002:aa7:9210:: with SMTP id 16mr14262489pfo.11.1565248666521; Thu, 08 Aug 2019 00:17:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565248666; cv=none; d=google.com; s=arc-20160816; b=RaklK7CzTJDWSIUyD/6fKn5CuaDBK3YRlRJrg//0OzB9QNLaG89zVxTtJ3wY6Lhgqk 1ENerO+FMvBfPWxa8A8ircY2KpckJst5beKr8ObnMt58p8cilRN+eCZ3K8Xt2IZd086t feqS883/u2etnuKjQaSu6yrw/CpwImH/BkDqxkLakUidG+gT/ZnAUDzqbWEVGriiZuvZ sZKMk8MqzepWfHa37zQil1A09/+QMC5nk0MMHFty3ee2RSTw3rpcL5VFkZ548BtdzYrJ sVvRXBu9/IX3qK9OO8JOr5Q00Cvg+a141k4d3xPfg7re/2/r+29CyoX6whHS0xxmgETg SxWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=Do5CFtVi9NCcTSKZkexhPtuQR5/W3q/75hgi7FAin40=; b=Yvb08VDRbvdTpMUCHBJIZlRJC2Jhg6Shnj3xm2WO/Z9YHsq/eBz3XJ2HWXrkCp8yBn hbWBcbn9PkAlSU8E4eKntqAzjNyyqakgqrkczsiDK7CKzeeE03r/QWhktTPyMLqjhvDF PjvgSYbsLaz4jp+gp+y+4AKSY7FZNw5rqnbAYYFRyq0PowqcX9P49EStMiPsBaIQm4m5 UOsWuRyV2nXIl1W9nYPfRk2Eu7fDV3rFCt8xk3790eUujOje6WBR4loa1zYrPb/jzR2T 65FPLKnf6vIOE0sMfVgr8hEIwicuPvS5ve8gShBVkHCa0ohUfBPQSMDNUgLAZ+tB9bmy Ldsg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=qZt1LDH0; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n187si55168530pga.165.2019.08.08.00.17.30; Thu, 08 Aug 2019 00:17:46 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=qZt1LDH0; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731371AbfHHHQY (ORCPT + 99 others); Thu, 8 Aug 2019 03:16:24 -0400 Received: from mail-pl1-f195.google.com ([209.85.214.195]:42694 "EHLO mail-pl1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725817AbfHHHQY (ORCPT ); Thu, 8 Aug 2019 03:16:24 -0400 Received: by mail-pl1-f195.google.com with SMTP id ay6so43188538plb.9; Thu, 08 Aug 2019 00:16:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=Do5CFtVi9NCcTSKZkexhPtuQR5/W3q/75hgi7FAin40=; b=qZt1LDH00qJJ9fE/ZsizY14Te+pYIXCNKV1YW6ghgPk/omgGaqm8JsiuLqo0sQdbhv OumkjpNc7WibBEjFe9wBtFlngXA9kebZuztxaYe4DTmImanlv8QxETfIaCc1r3bwz+Jy +Df6l6e+l/f0ThjK/DsxE01kCb6FdBPdpi3ZT5PVuII1k8zLysyBTD4LHenr7be1emKv MbSR1mVoM/fMJV2nuAyaaoJWXIq+oVHIszHYiucuXeY7K3imA3155gqwBA6U79HHe3bt Vr0A1cNCWlSBzqjS9yKvNTkY+DtjQdI0/7sVQ9crtDXPfNYPO4KtA1a96ikanMt3QALG qmfA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=Do5CFtVi9NCcTSKZkexhPtuQR5/W3q/75hgi7FAin40=; b=qTbbWNYdYGbFl4exhhy8TAK+x1V9QQYgkYVDuIlwIxhow8/DVBiw7skHHgy0ObYBzx qvLVGFbzYfgfh/BUQ+W5M/ClJjq/oLWsEJLXnsIpadUOElwmhiimXHAr2yAYOpLvBz+K JEnseDmfDUQmLXu94i21IJP9NGrbncLhYR88ypyRHYtEoqO8h6Fhu1bFzWieGaZKy9+0 wyYrWGz9f9M5PLFqpPR3ln1ZcENBIQUML77QaX7pH1Az/pFyHGiN6GYs0Yq+g1aIvHsK aIqg35a0kpJfnWDouuLVuww6PvROfO7IqoJWkYvmpKSHXnP6t4+Gnk8HDF4BlOi8S6ZK +lXQ== X-Gm-Message-State: APjAAAVPayIuKFFmlfgbijArT0cEBegzwJb4MgAMcmJkv5KlJdfWOxwe /40cEoSnYYSL2NbiUi7GYKk= X-Received: by 2002:a17:902:1004:: with SMTP id b4mr2353592pla.340.1565248584001; Thu, 08 Aug 2019 00:16:24 -0700 (PDT) Received: from localhost.localdomain ([122.163.44.6]) by smtp.gmail.com with ESMTPSA id m4sm158947802pff.108.2019.08.08.00.16.21 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Thu, 08 Aug 2019 00:16:23 -0700 (PDT) From: Nishka Dasgupta To: agross@kernel.org, kishon@ti.com, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Nishka Dasgupta Subject: [PATCH] phy: qualcomm: phy-qcom-qmp: Add of_node_put() before return Date: Thu, 8 Aug 2019 12:46:12 +0530 Message-Id: <20190808071612.14071-1-nishkadg.linux@gmail.com> X-Mailer: git-send-email 2.19.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Each iteration of for_each_available_child_of_node() puts the previous node, but in the case of a return from the middle of the loop, there is no put, thus causing a memory leak. Hence create a new label, err_node_put, that puts the previous node (child) before returning the required value. Also include the statement pm_runtime_disable() under this label in order to avoid repetition among mid-loop return conditions. Edit the mid-loop return statements to instead go to this new label err_node_put. Issue found with Coccinelle. Signed-off-by: Nishka Dasgupta --- drivers/phy/qualcomm/phy-qcom-qmp.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/drivers/phy/qualcomm/phy-qcom-qmp.c b/drivers/phy/qualcomm/phy-qcom-qmp.c index 34ff6434da8f..e7b8283acce8 100644 --- a/drivers/phy/qualcomm/phy-qcom-qmp.c +++ b/drivers/phy/qualcomm/phy-qcom-qmp.c @@ -2093,8 +2093,7 @@ static int qcom_qmp_phy_probe(struct platform_device *pdev) if (ret) { dev_err(dev, "failed to create lane%d phy, %d\n", id, ret); - pm_runtime_disable(dev); - return ret; + goto err_node_put; } /* @@ -2105,8 +2104,7 @@ static int qcom_qmp_phy_probe(struct platform_device *pdev) if (ret) { dev_err(qmp->dev, "failed to register pipe clock source\n"); - pm_runtime_disable(dev); - return ret; + goto err_node_put; } id++; } @@ -2118,6 +2116,11 @@ static int qcom_qmp_phy_probe(struct platform_device *pdev) pm_runtime_disable(dev); return PTR_ERR_OR_ZERO(phy_provider); + +err_node_put: + pm_runtime_disable(dev); + of_node_put(child); + return ret; } static struct platform_driver qcom_qmp_phy_driver = { -- 2.19.1