Received: by 10.213.65.68 with SMTP id h4csp196619imn; Mon, 26 Mar 2018 19:06:00 -0700 (PDT) X-Google-Smtp-Source: AG47ELvfhB97YC6H3FQyQNz/6ZNsHdYPIABOjMK3k5jwpDLUSiDuFEj5NgsLbRLvY5KzNHp1MqMm X-Received: by 10.98.103.69 with SMTP id b66mr34758639pfc.151.1522116360341; Mon, 26 Mar 2018 19:06:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522116360; cv=none; d=google.com; s=arc-20160816; b=z+OcnqNBJBcyDcgyp80IMEBko1gfrOhz66hnObEA9cDxUzpc7+Lx4BRgmI5A6N/0e7 d0dN+OjQkL/mC4UOFX91L4H6K+VdqroBw4iqhxlHFsbxX3eTOQFobQns/h9IOR6FKHWr GHkglvujRL8c2NZ3T0pEDDTXuOft2+vjy8IjrZkNbz53bb0BgAL0ekhL8Vac7nPe2UDG vh+WO+Rndq8XioqY4cO86oPa1I7Oki3AtbP6Gs5jxkZpS+/SbRdITNU65B/Rdcg8ZiQM VArogsMAaPvMzSLqiSh+T0LvJgq+oAfXTIWCGKq1Ac5qLCQpZu0r7dgdiZCo1OtdBhER xMDw== 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:in-reply-to :mime-version:user-agent:date:message-id:from:cc:references:to :subject:dkim-signature:arc-authentication-results; bh=UQKLpS+SmEfKJyqRUFzssddqQ1cAuZ9O3WCbHrbTbj8=; b=qR+JtrE92DHkvbbx0440JHFJHRCX8Lok6FssKWprW5iS/AH/FbwZ2GK6ACbhu/xDYo zwDEcKptlr1ypUXuhAcqiIWExrXOQFfzaKnDCweuLtX3i3o8aGeMA4dgU7Roew9vet5z 3THYHDs77hTvbI0KuUgAhI05oV5IlSy1vnA052s1qaI4GRRugjqftMpYudY71EGCnf7C ApP0+vHDFmf/i5dpWltCz1TXknzJ3kqyuJ9dBR4Wqdb8JRTOoxEY7lOyu6hDkYUwvbWE 71XMI75kjNhxGkkpoAFfESoxw80FfYKeMsxtd09X4CetfCmVqNESVfprQrofrXwmVhD8 xO5Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=VqlBEsym; 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 f2si96072pgt.481.2018.03.26.19.05.45; Mon, 26 Mar 2018 19:06:00 -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=VqlBEsym; 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 S1752278AbeC0CE1 (ORCPT + 99 others); Mon, 26 Mar 2018 22:04:27 -0400 Received: from mail-pf0-f193.google.com ([209.85.192.193]:45005 "EHLO mail-pf0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752209AbeC0CEZ (ORCPT ); Mon, 26 Mar 2018 22:04:25 -0400 Received: by mail-pf0-f193.google.com with SMTP id m68so8279519pfm.11; Mon, 26 Mar 2018 19:04:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:references:cc:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding; bh=UQKLpS+SmEfKJyqRUFzssddqQ1cAuZ9O3WCbHrbTbj8=; b=VqlBEsymZ8ILBd7KPV6HmFUTw7WYfXYPjYIQ67UzwEK6osBsodMIXR1jx2stWNBTSS xPoX3D7j65m+zmFFOEjOxey9GQ7LWs7f4CiMPWmrjDHVmd5FwfcOqI1c+SmufVWycNY1 284KA5CE4MIbgjQpFGu/+M1CC2JyKdVhwvFk2GDDFMocPlO0vbvIfp5eGQA9cQwgWY11 j8fVUaxCQ9m0KucOTOBrPNjkhXpwQYcSEXRMXyrqjAuJon5km682FbsG7e6Eq/r9gcMV v5kwNIxyipRl2+l3DrqV2hqF6YMECjUTQRVU/tt3qA6NhWq97OHEfvG7KWg4Ni156OYU hFYQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:cc:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding; bh=UQKLpS+SmEfKJyqRUFzssddqQ1cAuZ9O3WCbHrbTbj8=; b=E52a1RYYW2yJV39LPG1Q6thxLUJ6OGOM5MD79wIEv1mfQEB700iLguTymHIt+Ks4+o eoKOt6b3VYmuLjWyoDstcheCTTMlDA2mo/PwZV5R9/UDkuDDTunEPV4gwnEGov1bOCuA hlrykn2fjoS6nyTqmZ6LgJ8SnDrHt1cVv7zkh7QkuS/qsVdDZOZIH2BN4hc9bIMn9UXP J61nhe181WO+UC+qLTkw9m0UDFPOCwlS8Q89esR9ZHO7e/PLHwC2Os5Rmm/W528aHGLk kbP0NGItqibvzraI4c9Wbi+Gq0gtrxCDgLslzYJe813S2dv1XJmQBFGXfIr1TsrqhPlP lDcg== X-Gm-Message-State: AElRT7EvFIwjlMAX0GQaOPZ8N4GtxTmxUKh9YEPvfNL3M0Lypzqi6dhI x81LSOcL2FocyWqdDGLazvlDKw== X-Received: by 10.99.185.28 with SMTP id z28mr13011676pge.59.1522116265221; Mon, 26 Mar 2018 19:04:25 -0700 (PDT) Received: from localhost.localdomain ([106.120.101.38]) by smtp.googlemail.com with ESMTPSA id b18sm179916pfi.34.2018.03.26.19.04.22 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 26 Mar 2018 19:04:24 -0700 (PDT) Subject: Re: [PATCH] cpufreq: ti-cpufreq: Fix couple of minor issues in probe() To: Suman Anna , Viresh Kumar References: <20180326215244.26304-1-s-anna@ti.com> Cc: "Rafael J. Wysocki" , Dave Gerlach , Tero Kristo , linux-omap@vger.kernel.org, linux-kernel@vger.kernel.org From: Zumeng Chen Message-ID: <5bbd266a-ddc6-296a-dcea-58dc8da6062a@gmail.com> Date: Tue, 27 Mar 2018 10:10:51 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.8.0 MIME-Version: 1.0 In-Reply-To: <20180326215244.26304-1-s-anna@ti.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 03/27/2018 05:52 AM, Suman Anna wrote: > Commit 05829d9431df ("cpufreq: ti-cpufreq: kfree opp_data when > failure") has fixed a memory leak in the failure path, however > kmemleak still keeps reporting a leak even on successful probes. > This is a false-positive and is mostly a result of the opp_data > variable not being stored anywhere in the probe function. The > patch also returned a positive value on the get_cpu_device() > failure instead of a negative value. > > unreferenced object 0xecae4d80 (size 64): > comm "swapper/0", pid 1, jiffies 4294937673 (age 154.420s) > hex dump (first 32 bytes): > 10 40 d9 ee 74 b7 db ee 00 24 ac ec 20 a3 ea c0 .@..t....$.. ... > 00 26 ac ec 00 00 00 00 00 00 00 00 00 00 00 00 .&.............. > backtrace: > [] platform_drv_probe+0x50/0xac > [] driver_probe_device+0x24c/0x330 > [] bus_for_each_drv+0x54/0xb8 > [<2c6f7021>] __device_attach+0xcc/0x13c > [] bus_probe_device+0x88/0x90 > [] device_add+0x38c/0x5b4 > [<6f1af99b>] platform_device_add+0x100/0x220 > [] platform_device_register_full+0xf0/0x104 > [<4d492439>] ti_cpufreq_init+0x44/0x6c > [<81222e89>] do_one_initcall+0x48/0x190 > [<3bebf42a>] kernel_init_freeable+0x1f4/0x2b8 > [<230ad7df>] kernel_init+0x8/0x110 > [<43a165c3>] ret_from_fork+0x14/0x20 > [< (null)>] (null) > [<87288797>] 0xffffffff > > Fix both issues by replacing the previous logic by using the devres > managed API for allocating the opp_data variable, and simplifying > the get_cpu_device() failure return path. > > Fixes: 05829d9431df ("cpufreq: ti-cpufreq: kfree opp_data when failure") > Cc: Zumeng Chen Acked, I'm aware of the false-postive one, this is good to fix both one, thanks~ Cheers, Zumeng > Signed-off-by: Suman Anna > --- > drivers/cpufreq/ti-cpufreq.c | 7 ++----- > 1 file changed, 2 insertions(+), 5 deletions(-) > > diff --git a/drivers/cpufreq/ti-cpufreq.c b/drivers/cpufreq/ti-cpufreq.c > index a099b7bf74cd..7d353a21935b 100644 > --- a/drivers/cpufreq/ti-cpufreq.c > +++ b/drivers/cpufreq/ti-cpufreq.c > @@ -217,7 +217,7 @@ static int ti_cpufreq_probe(struct platform_device *pdev) > if (!match) > return -ENODEV; > > - opp_data = kzalloc(sizeof(*opp_data), GFP_KERNEL); > + opp_data = devm_kzalloc(&pdev->dev, sizeof(*opp_data), GFP_KERNEL); > if (!opp_data) > return -ENOMEM; > > @@ -226,8 +226,7 @@ static int ti_cpufreq_probe(struct platform_device *pdev) > opp_data->cpu_dev = get_cpu_device(0); > if (!opp_data->cpu_dev) { > pr_err("%s: Failed to get device for CPU0\n", __func__); > - ret = ENODEV; > - goto free_opp_data; > + return -ENODEV; > } > > opp_data->opp_node = dev_pm_opp_of_get_opp_desc_node(opp_data->cpu_dev); > @@ -285,8 +284,6 @@ static int ti_cpufreq_probe(struct platform_device *pdev) > > fail_put_node: > of_node_put(opp_data->opp_node); > -free_opp_data: > - kfree(opp_data); > > return ret; > }