Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp4049161imm; Mon, 14 May 2018 01:39:05 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqaR3ydTvdHrNlckGzZkJUsEZ5jNq6pKT6RDHVQ72CCl91bfFruBryrv25kjJvRUi5JwMcj X-Received: by 2002:a65:550d:: with SMTP id f13-v6mr7797795pgr.324.1526287145874; Mon, 14 May 2018 01:39:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526287145; cv=none; d=google.com; s=arc-20160816; b=CSvsZwlnkBBfLbZ2/JgB81hEJoilYiQsBYc9NYEiprvFIKCR9SmkysgtRygCz5+O8l E1YDa6uwlF9xYg9Z93lpGVebRPq93fs1aHl2n92YTonTWeWRjYO7j6lJS4/9ZOBBYKcV oHLMicPhz90tdJ/hWAfYcedFBp3M/DemJMfa50sxl0P4yLfqswxLtoDrrtk9lwO7/mHc os3fkuvOonIf70iwwpIA3vwGcQtU+8tlZ/5KTnJfEJU3A8fxbb5LUpcJl3oYDZucAfgs pZ6CLzcS0/FUrzljzJU7tSopr7Cek5yL2TrfjR3WTLjqGODMlRevYl4PoPaARQRES0AE iBgA== 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:from:references:cc:to:subject:arc-authentication-results; bh=GBy3P1cbSF7sFCWlR0s+cpjkTO6X4IXydcdj6572euI=; b=lJc8zHksb+8cAmYvQVceAcOwu0uo3T47MUGHb8nHyO6h8Y6tQFiC+NEjiGmZYRrz+B qfq9ZEBlNcFYMU7oLoMYYZlR1rqlAghnl5T6G4lbsL4RZwXuC7TDTSkZWA7q0vInq/T9 Xe9ZCtB2mJ0dagyJlpjYScnvQLC4teIQgDylNTI+84wzodMEER14CekdeygPoN9Wg1fR oeDP9u8Ot1mBMSF2Gl3FN9tvVVm/Ukz/+1AXD5OjsbQEdyhVYerzctP1nZBJXgeoEYnn RR0BNm4TPBh+H2hKZR5yfTWrEKOp+kmkOOCMs4rYvsXAxZA17c+/U7Vi5W3b3xxJirt3 mazg== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p7-v6si7091330pgd.96.2018.05.14.01.38.51; Mon, 14 May 2018 01:39:05 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752501AbeENIh3 (ORCPT + 99 others); Mon, 14 May 2018 04:37:29 -0400 Received: from metis.ext.pengutronix.de ([85.220.165.71]:35183 "EHLO metis.ext.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752476AbeENIhZ (ORCPT ); Mon, 14 May 2018 04:37:25 -0400 Received: from [2001:67c:670:100:7c06:bf8a:7e39:c388] by metis.ext.pengutronix.de with esmtp (Exim 4.89) (envelope-from ) id 1fI8yy-0005oo-41; Mon, 14 May 2018 10:37:24 +0200 Subject: Re: [PATCH 1/3] thermal: imx: remove cpufreq cooling registration To: Anson Huang , shawnguo@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, fabio.estevam@nxp.com, robh+dt@kernel.org, mark.rutland@arm.com, rjw@rjwysocki.net, viresh.kumar@linaro.org, rui.zhang@intel.com, edubezval@gmail.com Cc: devicetree@vger.kernel.org, linux-pm@vger.kernel.org, Linux-imx@nxp.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org References: <1526285359-17978-1-git-send-email-Anson.Huang@nxp.com> From: Bastian Stender Message-ID: <5a449fc0-4d3e-c7c7-0e9a-43efb4b909cf@pengutronix.de> Date: Mon, 14 May 2018 10:37:21 +0200 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: <1526285359-17978-1-git-send-email-Anson.Huang@nxp.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-SA-Exim-Connect-IP: 2001:67c:670:100:7c06:bf8a:7e39:c388 X-SA-Exim-Mail-From: bst@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 05/14/2018 10:09 AM, Anson Huang wrote: > This patch removes cpufreq cooling registration in > thermal .probe function, cpufreq cooling should be > done in cpufreq driver when it is ready. > > Signed-off-by: Anson Huang It seems you are trying to achieve something similar to a patch I sent a couple of month ago. Unfortunately I did not have the time to rework it yet: https://patchwork.kernel.org/patch/10059085/ Some of the comments might apply here too. Regards, Bastian > --- > drivers/thermal/imx_thermal.c | 16 ---------------- > 1 file changed, 16 deletions(-) > > diff --git a/drivers/thermal/imx_thermal.c b/drivers/thermal/imx_thermal.c > index c30dc21..8eedb97 100644 > --- a/drivers/thermal/imx_thermal.c > +++ b/drivers/thermal/imx_thermal.c > @@ -9,7 +9,6 @@ > > #include > #include > -#include > #include > #include > #include > @@ -207,7 +206,6 @@ static struct thermal_soc_data thermal_imx7d_data = { > struct imx_thermal_data { > struct cpufreq_policy *policy; > struct thermal_zone_device *tz; > - struct thermal_cooling_device *cdev; > enum thermal_device_mode mode; > struct regmap *tempmon; > u32 c1, c2; /* See formula in imx_init_calib() */ > @@ -729,22 +727,12 @@ static int imx_thermal_probe(struct platform_device *pdev) > return -EPROBE_DEFER; > } > > - data->cdev = cpufreq_cooling_register(data->policy); > - if (IS_ERR(data->cdev)) { > - ret = PTR_ERR(data->cdev); > - dev_err(&pdev->dev, > - "failed to register cpufreq cooling device: %d\n", ret); > - cpufreq_cpu_put(data->policy); > - return ret; > - } > - > data->thermal_clk = devm_clk_get(&pdev->dev, NULL); > if (IS_ERR(data->thermal_clk)) { > ret = PTR_ERR(data->thermal_clk); > if (ret != -EPROBE_DEFER) > dev_err(&pdev->dev, > "failed to get thermal clk: %d\n", ret); > - cpufreq_cooling_unregister(data->cdev); > cpufreq_cpu_put(data->policy); > return ret; > } > @@ -759,7 +747,6 @@ static int imx_thermal_probe(struct platform_device *pdev) > ret = clk_prepare_enable(data->thermal_clk); > if (ret) { > dev_err(&pdev->dev, "failed to enable thermal clk: %d\n", ret); > - cpufreq_cooling_unregister(data->cdev); > cpufreq_cpu_put(data->policy); > return ret; > } > @@ -775,7 +762,6 @@ static int imx_thermal_probe(struct platform_device *pdev) > dev_err(&pdev->dev, > "failed to register thermal zone device %d\n", ret); > clk_disable_unprepare(data->thermal_clk); > - cpufreq_cooling_unregister(data->cdev); > cpufreq_cpu_put(data->policy); > return ret; > } > @@ -811,7 +797,6 @@ static int imx_thermal_probe(struct platform_device *pdev) > dev_err(&pdev->dev, "failed to request alarm irq: %d\n", ret); > clk_disable_unprepare(data->thermal_clk); > thermal_zone_device_unregister(data->tz); > - cpufreq_cooling_unregister(data->cdev); > cpufreq_cpu_put(data->policy); > return ret; > } > @@ -831,7 +816,6 @@ static int imx_thermal_remove(struct platform_device *pdev) > clk_disable_unprepare(data->thermal_clk); > > thermal_zone_device_unregister(data->tz); > - cpufreq_cooling_unregister(data->cdev); > cpufreq_cpu_put(data->policy); > > return 0; > -- Pengutronix e.K. Industrial Linux Solutions http://www.pengutronix.de/ Peiner Str. 6-8, 31137 Hildesheim, Germany Amtsgericht Hildesheim, HRA 2686