Received: by 10.213.65.68 with SMTP id h4csp50263imn; Mon, 26 Mar 2018 14:54:04 -0700 (PDT) X-Google-Smtp-Source: AG47ELsaqAJqZW8o0mN9994b/IXP1F9sR8ADlMMQe2grxQKSjAeNL2SCIoSg8zCAGfOV3b3FYWWN X-Received: by 10.99.175.79 with SMTP id s15mr14966730pgo.388.1522101244926; Mon, 26 Mar 2018 14:54:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522101244; cv=none; d=google.com; s=arc-20160816; b=olB4AqIcrxaSbcL/pCoKFveaICJn2hRO5Oephh7au00UMuJOnd3VRtDWNGccBeWEMn dJDh4sKFq8Ae5XkR8Dlnq8C0nZ9yXoTJoXnxJfV3F3/WHbA7l2AKRnhu/eEOz7HRa1Uq YlS4oQNwh3vlvhwPHOr3zRe6SmuM67z/aA9e25Rwn9Srodsz8o2rjkWu6lCWNcmSEO/Y TX7U7MpAh2R8nzkteANB0iRo1FBqIPdIB3BRV0akRGInxUGUTDgP8PeA6kpLZGKAeOJK Gpd7OoYYh5ZfuIKpD+VM/CEnutDDRZNukT9IHK9vTHVYqOBpE9JjNCiQWV+YmyWk77n9 GURw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from:dkim-signature:arc-authentication-results; bh=mVhYGSdMoz1ADru+I8I+F8iI43upOg5Vuuesch4tFhI=; b=DFohaCbi1+ICmuKe3pD0hMMlIibAK75prmiuayvx2dUXhiyB3z8QUUNS/R0Eb/yLkd kDMBy+7Leg7gky7sW4lCmwo+3mbV9LCJqHOWIA13opgJk5dd019e1pOfU7VJsKein9RT CIj+XTrTlfyKSvNYyRaKYl//3s0jS+0++RRIZX3HE1RGG+5xdMK6wTrekWmYkHflRaI3 zK3HEwDV5NArSk5br2Jxteom0weRW3eTpzIW952niDzDR18cIMGLLlZaGAIexgDvrCKO qPzg5sodRSzZl4LHHPfOW29D0J7wN+bZLmQo+BD9XYrQ9ql+5hP3CVf4GBcXkh6NG4vQ 69TQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=C5bZ8dIH; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l6-v6si14935479plt.62.2018.03.26.14.53.49; Mon, 26 Mar 2018 14:54:04 -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=@ti.com header.s=ti-com-17Q1 header.b=C5bZ8dIH; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751932AbeCZVw4 (ORCPT + 99 others); Mon, 26 Mar 2018 17:52:56 -0400 Received: from lelnx194.ext.ti.com ([198.47.27.80]:40491 "EHLO lelnx194.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751132AbeCZVwz (ORCPT ); Mon, 26 Mar 2018 17:52:55 -0400 Received: from dlelxv90.itg.ti.com ([172.17.2.17]) by lelnx194.ext.ti.com (8.15.1/8.15.1) with ESMTP id w2QLqp8t019226; Mon, 26 Mar 2018 16:52:51 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ti.com; s=ti-com-17Q1; t=1522101171; bh=2/rx0f0M4qcd/aXmWL+8HbIm0EIXI1WH5b28xdJ28U8=; h=From:To:CC:Subject:Date; b=C5bZ8dIHxMoBzK9JGmh61vciw64au7AOfAlNWTCvSMaE7GPyy8cKBvvSUvJHJVjff ESPrppvklTvaEIC4LREMtJXKcN6NgjjGqol+hhXrljXEPvD/Xcozg3Evk/f+MVqWx2 AdH0YlaOowAMxYLJHAIj/TecX5ViDO78Xoi2mLfs= Received: from DLEE105.ent.ti.com (dlee105.ent.ti.com [157.170.170.35]) by dlelxv90.itg.ti.com (8.14.3/8.13.8) with ESMTP id w2QLqpWb024833; Mon, 26 Mar 2018 16:52:51 -0500 Received: from DLEE112.ent.ti.com (157.170.170.23) by DLEE105.ent.ti.com (157.170.170.35) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1261.35; Mon, 26 Mar 2018 16:52:50 -0500 Received: from dflp32.itg.ti.com (10.64.6.15) by DLEE112.ent.ti.com (157.170.170.23) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1261.35 via Frontend Transport; Mon, 26 Mar 2018 16:52:50 -0500 Received: from legion.dal.design.ti.com (legion.dal.design.ti.com [128.247.22.53]) by dflp32.itg.ti.com (8.14.3/8.13.8) with ESMTP id w2QLqosE030803; Mon, 26 Mar 2018 16:52:50 -0500 Received: from localhost (irmo.dhcp.ti.com [128.247.58.153]) by legion.dal.design.ti.com (8.11.7p1+Sun/8.11.7) with ESMTP id w2QLqox17385; Mon, 26 Mar 2018 16:52:50 -0500 (CDT) From: Suman Anna To: Viresh Kumar CC: "Rafael J. Wysocki" , Dave Gerlach , Tero Kristo , , , Suman Anna , Zumeng Chen Subject: [PATCH] cpufreq: ti-cpufreq: Fix couple of minor issues in probe() Date: Mon, 26 Mar 2018 16:52:44 -0500 Message-ID: <20180326215244.26304-1-s-anna@ti.com> X-Mailer: git-send-email 2.16.2 MIME-Version: 1.0 Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 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; } -- 2.16.2