Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1627928pxb; Mon, 8 Mar 2021 02:18:21 -0800 (PST) X-Google-Smtp-Source: ABdhPJyJ0ML9iUot/Men11O54vwbHCfkVh1n3WvNZddqFJ897WWozyb46J27uYB1g1ZGUAqsWExX X-Received: by 2002:a50:cf48:: with SMTP id d8mr22067575edk.54.1615198701246; Mon, 08 Mar 2021 02:18:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615198701; cv=none; d=google.com; s=arc-20160816; b=xgVZ999PUln1VJjP+61OrQalmkUJXsrY2NcB+UD9y++5iMAVSLOtJ7EyP+PSGpZPa0 +5i1KF8z1mAwDB8/luQv1yxokF7bVAEc0eoNkrVN4pMZ1oaye8+sI/JCU69oh7XIUeQO gXkXWLWncu4+NV0fYSLhGzXlvcUYhCEvoDnz/cUQBGF3Y7n8CELpwF8Ra/s6uSsLixvW PR/VKkBxXps6jfAfxhxRrV1PB2696mhsrcC85xHbyBaevKOeVzBDOGe1jgH+nSU7hKQV ghGNxFA/ies40hO9WwWnKbhTvnqKBsm7qUzneIo5dh5WjPsbVKKScTZCtTnHQcTmajWd rLgA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=JNKT+YCdxsnp5OOoMbH4ReozRmjAF3TOtsrmy5PADe8=; b=w9mxMo4LUUuBqL3SnOIjhTdjsjVHb3dNZZ+Ap02JL4Y2W+Trf+Frmk0qW3h9P1eFHO FYEHGDyTuLG1dxw6V59CGItHTRjl5OKmPzG3Kmg/WpERV53YzG9tfA4fWIQ4LSZLujcP C8ziYAv7PXX/8SEa4EBH0Z/1c4eFZU6jp9IyhtDwa4Ludcosi+2n0OkMwM/0XJsGejDp rT3Sn7jTOybLl9KeRlPgY8Y0lNuqZIGug6QSjDSukO1VoUS8wNIflCrLVPHyNbSoZKyF 7zO/SO5AEstVH6mUXV3QLDZP6a/pi4DgBHfhyY1PhNHRPMS6S0IagjJ5PWVXncsM3UPR Q/fw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r24si6352277ejo.63.2021.03.08.02.17.59; Mon, 08 Mar 2021 02:18:21 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231134AbhCHJux (ORCPT + 99 others); Mon, 8 Mar 2021 04:50:53 -0500 Received: from foss.arm.com ([217.140.110.172]:35012 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229711AbhCHJul (ORCPT ); Mon, 8 Mar 2021 04:50:41 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 62C2DD6E; Mon, 8 Mar 2021 01:50:41 -0800 (PST) Received: from [192.168.1.179] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 0E9833F73C; Mon, 8 Mar 2021 01:50:39 -0800 (PST) Subject: Re: [PATCH v5 1/4] PM / devfreq: Register devfreq as a cooling device on demand To: Daniel Lezcano , cwchoi00@gmail.com Cc: lukasz.luba@arm.com, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, MyungJoo Ham , Kyungmin Park , Chanwoo Choi References: <20210308091646.28096-1-daniel.lezcano@linaro.org> From: Steven Price Message-ID: Date: Mon, 8 Mar 2021 09:51:23 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <20210308091646.28096-1-daniel.lezcano@linaro.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08/03/2021 09:16, Daniel Lezcano wrote: > Currently the default behavior is to manually having the devfreq > backend to register themselves as a devfreq cooling device. > > Instead of adding the code in the drivers for the thermal cooling > device registering, let's provide a flag in the devfreq's profile to > tell the common devfreq code to register the newly created devfreq as > a cooling device. > > Suggested-by: Chanwoo Choi > Signed-off-by: Daniel Lezcano > --- > V5: > - Changed subject prefix by: PM / devfreq > V4: > - Replaced thermal_cooling_device_unregister() by > devfreq_cooling_unregister() > V3: > - Rebased on linux-pm branch without units.h > - Set the cdev to NULL in case of error > - Added description for the cdev field in the devfreq structure > V2: > - Added is_cooling_device boolean in profile structure > - Register cooling device when the is_cooling_device boolean is set > - Remove devfreq cooling device registration in the backend drivers > V1: > - Register devfreq as a cooling device unconditionnally > --- > drivers/devfreq/devfreq.c | 13 +++++++++++++ > include/linux/devfreq.h | 8 ++++++++ > 2 files changed, 21 insertions(+) > > diff --git a/drivers/devfreq/devfreq.c b/drivers/devfreq/devfreq.c > index bf3047896e41..8a535d4d6083 100644 > --- a/drivers/devfreq/devfreq.c > +++ b/drivers/devfreq/devfreq.c > @@ -11,6 +11,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -26,6 +27,7 @@ > #include > #include > #include > +#include > #include "governor.h" > > #define CREATE_TRACE_POINTS > @@ -935,6 +937,15 @@ struct devfreq *devfreq_add_device(struct device *dev, > > mutex_unlock(&devfreq_list_lock); > > + if (devfreq->profile->is_cooling_device) { > + devfreq->cdev = devfreq_cooling_em_register(devfreq, NULL); > + if (IS_ERR(devfreq->cdev)) { > + dev_info(dev, "Failed to register devfreq " > + "cooling device\n"); Please don't split strings across multiple lines (it makes grepping for them harder). With that fixed: Reviewed-by: Steven Price > + devfreq->cdev = NULL; > + } > + } > + > return devfreq; > > err_init: > @@ -960,6 +971,8 @@ int devfreq_remove_device(struct devfreq *devfreq) > if (!devfreq) > return -EINVAL; > > + devfreq_cooling_unregister(devfreq->cdev); > + > if (devfreq->governor) { > devfreq->governor->event_handler(devfreq, > DEVFREQ_GOV_STOP, NULL); > diff --git a/include/linux/devfreq.h b/include/linux/devfreq.h > index 26ea0850be9b..aba7ace11b72 100644 > --- a/include/linux/devfreq.h > +++ b/include/linux/devfreq.h > @@ -98,11 +98,15 @@ struct devfreq_dev_status { > * @freq_table: Optional list of frequencies to support statistics > * and freq_table must be generated in ascending order. > * @max_state: The size of freq_table. > + * > + * @is_cooling_device: A self-explanatory boolean giving the device a > + * cooling effect property. > */ > struct devfreq_dev_profile { > unsigned long initial_freq; > unsigned int polling_ms; > enum devfreq_timer timer; > + bool is_cooling_device; > > int (*target)(struct device *dev, unsigned long *freq, u32 flags); > int (*get_dev_status)(struct device *dev, > @@ -156,6 +160,7 @@ struct devfreq_stats { > * @suspend_count: suspend requests counter for a device. > * @stats: Statistics of devfreq device behavior > * @transition_notifier_list: list head of DEVFREQ_TRANSITION_NOTIFIER notifier > + * @cdev: Cooling device pointer if the devfreq has cooling property > * @nb_min: Notifier block for DEV_PM_QOS_MIN_FREQUENCY > * @nb_max: Notifier block for DEV_PM_QOS_MAX_FREQUENCY > * > @@ -198,6 +203,9 @@ struct devfreq { > > struct srcu_notifier_head transition_notifier_list; > > + /* Pointer to the cooling device if used for thermal mitigation */ > + struct thermal_cooling_device *cdev; > + > struct notifier_block nb_min; > struct notifier_block nb_max; > }; >