Received: by 10.223.148.5 with SMTP id 5csp7609432wrq; Thu, 18 Jan 2018 07:27:46 -0800 (PST) X-Google-Smtp-Source: ACJfBot2NDHSAuREqQ+aeCIvwK9RpmI1Lwei5DqiI504ueIYDvZ8ntGc15HkuPEfQ1bPMK5/vFoJ X-Received: by 10.99.95.3 with SMTP id t3mr34849133pgb.302.1516289266721; Thu, 18 Jan 2018 07:27:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516289266; cv=none; d=google.com; s=arc-20160816; b=XV1bTVFdGo5Lvg+l+TvS2f70/y9lfZmkJgygb9EyDDTWmVL8FkRQOZdX+cGNXs5sr6 OGZlIA6wolZ5YFYR64Xr6/LMfWlbYSGtYrADqn8UVGo39+HYCaWSack7kAZqYEfjkO0u OskzVxdRJVBIQYngrrtNQ/9up/M0KsMkO2ZJW20ZovN1JNd5CHbEWGpXz7BWW0rMbxSL hwELAaFU0+QFRqFUdkjqzse3b+zzu5fbn9rn8UBo/iEoeZL/futrtY7UHdGoKZwgCbaR Gu0/o94MuIPmdftE10ttFSKUFdMkw8Au+VIOxVEEdPRWoassJ950CuY9KeHOPYt8LXzw anfg== 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:organization:from:references:cc:to:subject :dkim-signature:arc-authentication-results; bh=o5aOgpt+XEZiRaYX84io3FWn03RVSOnhHoIPish+b4o=; b=tCvWtt7djBvI75ib08/oiK/P9wxIenC7Qqi1cW76OReONpgaFSlxYI4ncKtu5inInf JBTqoKLR0GxCkIAO+EovQ8MPgumW3Y85nWzlFD/+KV+NcGy9Fd0TPZipK9kQyIB94jta OjXbZTbifdq4BnynmrK5Y3oZeczKF459L4u8xcApjNcq9OtmglJ3IWeorYBcZslrLwuH I3nhl2RNyWlG1hUnFGpqXbdLqsbSRUMTj1Q1W0ihZV2kdYq4VuzyqbV02XgYUuk32NMJ OYHFuMIWNmvrls2rnvjVlKhY6AOAE6n7F4SiqT6JMbjxJRYA9WKd+qbFABDydaGiLSik OPmA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=HCAfM2N6; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r1si6106182pgp.308.2018.01.18.07.27.32; Thu, 18 Jan 2018 07:27:46 -0800 (PST) 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=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=HCAfM2N6; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932706AbeARP0F (ORCPT + 99 others); Thu, 18 Jan 2018 10:26:05 -0500 Received: from mail-wr0-f193.google.com ([209.85.128.193]:46577 "EHLO mail-wr0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932618AbeARPZ7 (ORCPT ); Thu, 18 Jan 2018 10:25:59 -0500 Received: by mail-wr0-f193.google.com with SMTP id g21so22921347wrb.13 for ; Thu, 18 Jan 2018 07:25:59 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:organization:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=o5aOgpt+XEZiRaYX84io3FWn03RVSOnhHoIPish+b4o=; b=HCAfM2N6xEikC66+HyloI4ety6tqy0BZZcA6jO3FBXLaosDzEYqgaMfTu8/DtLwISc dZAt0lgonGb5NLrakVCzzh1QRQZPweMha4qiORKbwYE3vK+qmaN5b+9aDENu9DSPuCN1 ADgXC4l2n21Pnl2JLpmCDVmFcrIl4PrLK10ZoOnEmXn5CrYglNrN2E6x4MB08geD524m JcAj0y369UcM9eSvD2yQfTtez9HkxLVk7VKkHh0mSFaXYnNJFKZ13gEsC4Zw+zzrhdad Uee5E74c40i+W+TeSNzUZ+KjjWIAF69YfXxsnf7daiOCTvq/n9XG9/l91STTtc/w2AXR Tl1w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:organization :message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=o5aOgpt+XEZiRaYX84io3FWn03RVSOnhHoIPish+b4o=; b=eMBiHj1sJnw7bOi9BnZZLHcKJvpv58peBjKOJnRDMo0djT/UyhwcrPlQFNuLHn/C7U EWUHLSWQmoxhQLUoIsL4a6+uA4kOmmqky7cfkqWY/iWBdLrylYYjds/dEiWsTyva+Xv3 onx/hS9IwH84+hQNHym3f26m7HbM3wBJOGSSScH0Y2OT5K/UirTQqwa7Z/YB4OFhh5y/ Uo0H4J5cmO+GIXrEoGBzCg/fLXEp9OPFKeSWUBWW26BgQJ/ovO9stthx5e8LlBMxZMnc eW9LwI7Rj/6HqrqSy9o8RhvWKhbyLjcRcoVQ+Fm+F1+cxRnr1quPXMAmDBUwCYAkjjjt q03w== X-Gm-Message-State: AKwxytdGrwF7F72odNU0U/6nc7PwHo2+pjp0JRhF7/sEYtrYO6Kr7VLV J6ClcLJmEPDz4Mf9MMl8nsYhd+rF4x8= X-Received: by 10.223.198.198 with SMTP id c6mr4826283wrh.159.1516289157879; Thu, 18 Jan 2018 07:25:57 -0800 (PST) Received: from [10.1.2.12] ([90.63.244.31]) by smtp.gmail.com with ESMTPSA id g41sm10850097wrg.4.2018.01.18.07.25.57 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 18 Jan 2018 07:25:57 -0800 (PST) Subject: Re: [PATCH 2/2] clk: meson: use devm_of_clk_add_hw_provider To: Jerome Brunet Cc: Kevin Hilman , Carlo Caione , Michael Turquette , Stephen Boyd , linux-amlogic@lists.infradead.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org References: <20180118120831.8349-1-jbrunet@baylibre.com> <20180118120831.8349-3-jbrunet@baylibre.com> From: Neil Armstrong Organization: Baylibre Message-ID: Date: Thu, 18 Jan 2018 16:25:56 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.5.0 MIME-Version: 1.0 In-Reply-To: <20180118120831.8349-3-jbrunet@baylibre.com> 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 18/01/2018 13:08, Jerome Brunet wrote: > There is no remove callbacks in meson's clock controllers and > of_clk_del_provider is never called if of_clk_add_hw_provider has been > executed, introducing a potential memory leak. > Fixing this by the using the devm variant. > > In reality, the leak would never happen since these controllers are > never unloaded once in use ... still, this is worth cleaning. > > Signed-off-by: Jerome Brunet > --- > drivers/clk/meson/axg.c | 4 ++-- > drivers/clk/meson/gxbb.c | 5 +++-- > drivers/clk/meson/meson8b.c | 4 ++-- > 3 files changed, 7 insertions(+), 6 deletions(-) > > diff --git a/drivers/clk/meson/axg.c b/drivers/clk/meson/axg.c > index 87aba8e871a0..02f4401d7bc3 100644 > --- a/drivers/clk/meson/axg.c > +++ b/drivers/clk/meson/axg.c > @@ -923,8 +923,8 @@ static int axg_clkc_probe(struct platform_device *pdev) > } > } > > - return of_clk_add_hw_provider(dev->of_node, of_clk_hw_onecell_get, > - clkc_data->hw_onecell_data); > + return devm_of_clk_add_hw_provider(dev, of_clk_hw_onecell_get, > + clkc_data->hw_onecell_data); > } > > static struct platform_driver axg_driver = { > diff --git a/drivers/clk/meson/gxbb.c b/drivers/clk/meson/gxbb.c > index ba1023983d79..472a3cfbfbc5 100644 > --- a/drivers/clk/meson/gxbb.c > +++ b/drivers/clk/meson/gxbb.c > @@ -2028,8 +2028,9 @@ static int gxbb_clkc_probe(struct platform_device *pdev) > goto iounmap; > } > > - return of_clk_add_hw_provider(dev->of_node, of_clk_hw_onecell_get, > - clkc_data->hw_onecell_data); > + > + return devm_of_clk_add_hw_provider(dev, of_clk_hw_onecell_get, > + clkc_data->hw_onecell_data); > > iounmap: > iounmap(clk_base); > diff --git a/drivers/clk/meson/meson8b.c b/drivers/clk/meson/meson8b.c > index 3ffea80c1308..abac079ff77f 100644 > --- a/drivers/clk/meson/meson8b.c > +++ b/drivers/clk/meson/meson8b.c > @@ -878,8 +878,8 @@ static int meson8b_clkc_probe(struct platform_device *pdev) > return ret; > } > > - return of_clk_add_hw_provider(dev->of_node, of_clk_hw_onecell_get, > - &meson8b_hw_onecell_data); > + return devm_of_clk_add_hw_provider(dev, of_clk_hw_onecell_get, > + &meson8b_hw_onecell_data); > } > > static const struct of_device_id meson8b_clkc_match_table[] = { > Well devm is allocating a devm structure to unregister the clocks when removed, which will never happen so this allocation is useless. Anyway it's cleaner if we do some other stuff after this call in the future. Acked-by: Neil Armstrong