Received: by 10.192.165.148 with SMTP id m20csp121020imm; Wed, 9 May 2018 09:45:14 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqa5z4GrfvctZyXLZcARC5FwJ/5g4+AxRezI6d+1LxF1QU20nXushHKXYI3We6n6mjsBjRY X-Received: by 2002:a17:902:74c9:: with SMTP id f9-v6mr46921560plt.385.1525884314715; Wed, 09 May 2018 09:45:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525884314; cv=none; d=google.com; s=arc-20160816; b=R7F6kYaYKY8P2Ty/Jmpg2/XHIuY7neS7T5tnKRYGf3Coyvo1Y3qqd9KfpSDKZ9Jrza DkVMWNccV+9oFHOZjzBPTp4kgkwT71peMuZO4TyXr7tiIhqTzqbguO8IIe0FrFbPBRps 6TyTo3PXnqNtM15rqb7VR/vZY0aSh38uQTRgtw+BjzqAMmwNK7h13M/yj/yk3MH5cgX/ VIdy3d3lYU7pXP6kCLOSb/r7ztyZxFxgq23aiXVr7p8XpkuKff+w58giYpEqUq6vkg9h SQrWMs3y9I0mzVBfY8Te63R8Qgmn9UhkfEsQkTr2p+CCYc0iYkQFRvqOTgjCqyC/9a1c ViXw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:autocrypt:openpgp:from:references:cc:to:subject :arc-authentication-results; bh=GHdmuEnOzqxIHcxDzBCpRQl9dx5pYkNuwojTwoQeT/k=; b=wJatFF1IeYPg4Rsp8GfkHv+IV4zP3DdKjVA2FVg18wIP1gs9NMAksTSsekVOBDuA0Y FvVcXkKLgMhLsbdescpNdh48igCFq4xBdRiEjEi0ta6mRHCUt7tdJAeUHSYDqiemg5u8 fKrgX46vffnsXZT8IXHpSTy8L+iBkHLWDP/QoZSiPxzmG5PsnxOcrT2EDSzY/WhUAjH0 YTZtBq5q7MDtbWLaw+HF8Y+oqf/rnscEvye4zOSTxrkWdi02pLodiPsE7whI5HY2pJ5t dlkK0znL0BVHqjYtAOVbXShodM4MQ+rNT0R+ZYi/gt7OiZ+S0G1E7udJuyUxAfDQjp1a bDoA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c20-v6si18798487pls.557.2018.05.09.09.44.59; Wed, 09 May 2018 09:45:14 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965595AbeEIQop (ORCPT + 99 others); Wed, 9 May 2018 12:44:45 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:60183 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S964989AbeEIQon (ORCPT ); Wed, 9 May 2018 12:44:43 -0400 Received: from 1.general.cking.uk.vpn ([10.172.193.212]) by youngberry.canonical.com with esmtpsa (TLS1.0:DHE_RSA_AES_128_CBC_SHA1:16) (Exim 4.76) (envelope-from ) id 1fGSCn-0003lb-K0; Wed, 09 May 2018 16:44:41 +0000 Subject: Re: [PATCH] clk: boston: fix memory leak of 'onecell' on error return paths To: Paul Burton , Dan Carpenter Cc: Michael Turquette , Stephen Boyd , linux-mips@linux-mips.org, linux-clk@vger.kernel.org, kernel-janitors@vger.kernel.org, linux-kernel@vger.kernel.org References: <20180509134031.11611-1-colin.king@canonical.com> <20180509140135.4dndt3baomtxups5@mwanda> <20180509163311.alvyibwwuwkumyxf@pburton-laptop> From: Colin Ian King Openpgp: preference=signencrypt Autocrypt: addr=colin.king@canonical.com; prefer-encrypt=mutual; keydata= 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 Message-ID: <3fbc876f-cf9d-6184-96c2-f372a4406ab8@canonical.com> Date: Wed, 9 May 2018 17:44:40 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180509163311.alvyibwwuwkumyxf@pburton-laptop> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 09/05/18 17:33, Paul Burton wrote: > Hi Colin & Dan, > > On Wed, May 09, 2018 at 05:01:35PM +0300, Dan Carpenter wrote: >> On Wed, May 09, 2018 at 02:40:31PM +0100, Colin King wrote: >>> From: Colin Ian King >>> >>> There are several error return paths that don't free up onecell >>> and hence we have some memory leaks. Add an error exit path that >>> kfree's onecell to fix the leaks. >>> >>> Signed-off-by: Colin Ian King >>> --- >>> drivers/clk/imgtec/clk-boston.c | 15 +++++++++++---- >>> 1 file changed, 11 insertions(+), 4 deletions(-) >>> >>> diff --git a/drivers/clk/imgtec/clk-boston.c b/drivers/clk/imgtec/clk-boston.c >>> index 15af423cc0c9..d6bc468ff551 100644 >>> --- a/drivers/clk/imgtec/clk-boston.c >>> +++ b/drivers/clk/imgtec/clk-boston.c >>> @@ -73,27 +73,34 @@ static void __init clk_boston_setup(struct device_node *np) >>> hw = clk_hw_register_fixed_rate(NULL, "input", NULL, 0, in_freq); >>> if (IS_ERR(hw)) { >>> pr_err("failed to register input clock: %ld\n", PTR_ERR(hw)); >>> - return; >>> + goto error; >> >> I hate vague label names like "error" and "out"... >> >> There are a bunch of other resources that we should free if we decide >> it's worth freeing things. > > Agreed - for example unregistering the clocks that we'd be discarding > references to by freeing onecell. > >> Can this even boot without the clk? > > Nope. If this clock setup fails then whether you free this memory or not > you're going to be unable to do anything useful with it. > > I imagine this patch is the result of some static analysis rather than a > problem being observed at runtime? Indeed. I propose ignoring this then as it's fairly terminal if one can't get memory anyhow in the early boot. Colin > > Thanks, > Paul > >> When >> the label names says what is freed, then you mentally only have to keep >> track of the most recently allocated resource. So if >> >> hw = clk_hw_register_fixed_rate(NULL, "input", NULL, 0, in_freq); >> >> succeeds then the next goto is going to "goto free_clk_input;". >> >> regards, >> dan carpenter