Received: by 2002:a05:7208:9594:b0:7e:5202:c8b4 with SMTP id gs20csp2544865rbb; Wed, 28 Feb 2024 05:24:53 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCVsGhwNWm+/isHkQ4syuOn/7SKybhOutsGGz0kW8GaNfj7Hvne4Bmh7Jlq3qsOP9pygBmmOXFCTNccA/r0KY4C6CKRhVVN+wo7Gynj5/w== X-Google-Smtp-Source: AGHT+IGIeSPyERNMDLySHQxrmnlLaVbL+R2PlgW8g8lGUcv19TcK2RZIklHEkueLn3cTWS9M8aCR X-Received: by 2002:a17:90a:dc0f:b0:29a:b713:8b27 with SMTP id i15-20020a17090adc0f00b0029ab7138b27mr7914630pjv.46.1709126692815; Wed, 28 Feb 2024 05:24:52 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1709126692; cv=pass; d=google.com; s=arc-20160816; b=sEq4fZSDNsCL9wH5PA8JxolkAGzfTXow96TmfgX2S5GiTk3iQ1VOBEsDrqOtxMKuYH +EqlyNdxn7Ya5/I6WlJb56Ck/g157odNnsf2VS40qqK+QlXQ5lyxpBRydgVDmO/JFGc7 ZkiIyrU/FJCCfLIDL5Hrj7SAcwvpqfSi3RIor95Iz8aCABYp6RjlLe48NFHqkTopzyI6 ruh6v+Fw60Im3zv57r3uEQATG6EhKDqEZC0q1wyIDVpD/I/q1JwQi7OaxayaXBe4topV wmmzCNJFW0mJz0YmvoVmdxqz2AHUcxuIrYrkoJ1SkkhNDdz3CYla26+D1Y1QGiPi/FBS fgXA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id; bh=4hJ1G9VbpxAvDF/38xAsoLeXAP3PXUTQyv18gqWpZDE=; fh=hweZDf13CGRvEaRs3Iuo9HPFAEcb5uMY03IMUqMZs/E=; b=0r9NJKCYlqSCgh2s55J/tMGutfO1Pro4BZI5S+zrW4Dusfv5cC6h178tqHqf0ytX9T 1Ry5crTgQZEYp8Z/p9yVbLxT/WTxWuYa5sD8VTpaC53OxeQKHHUQmyR6BbG2d4M/ITyp sJNiCIf/kiHQnqY97U+llMm90ejCXe2/thvWlkGmZi04pMkoBIqBXfs6FMyGpyrIdPn9 GOgLJkEXA6WK+ltFIBH2AF1rL1jj9aYYRw+J1o2POWfr4xlsChecB3gDjBE8YrPkQaVZ iBakRi1ALfGhApwYxam/hgtBJlPuSt4HcZ8qvy7gLC8kuoxJZD7/RM3UlOsNV/AFianZ oG2g==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=arm.com dmarc=pass fromdomain=arm.com); spf=pass (google.com: domain of linux-kernel+bounces-85087-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-85087-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [2604:1380:45e3:2400::1]) by mx.google.com with ESMTPS id d18-20020a17090abf9200b0029aa48f9284si1327702pjs.134.2024.02.28.05.24.52 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 28 Feb 2024 05:24:52 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-85087-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) client-ip=2604:1380:45e3:2400::1; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=arm.com dmarc=pass fromdomain=arm.com); spf=pass (google.com: domain of linux-kernel+bounces-85087-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-85087-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 6C91F289BA5 for ; Wed, 28 Feb 2024 13:24:52 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id E55DB14CAB3; Wed, 28 Feb 2024 13:24:44 +0000 (UTC) Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by smtp.subspace.kernel.org (Postfix) with ESMTP id A6F77145351; Wed, 28 Feb 2024 13:24:41 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=217.140.110.172 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709126684; cv=none; b=dE06TRSule9g1O6AGg3YtKbMpXzSIWwZ1/OjbyyK9RLIPHY+YbNhJrt2+t67USfXIu41WNP0MoOR6gveUNrb2tV99XvcadVdv3BReq93TEb1/1M1otVB85PGFjNzwAzMWrt3+bm+gKgYcYEwiZloHsUrInJt6UdMhRFeKBr7AV0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709126684; c=relaxed/simple; bh=XDFj5ej2ly05jyaCAesq3QNALGY6izh4ir1ndq5BHhg=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=a2ycsSuJEg9/yTfd2brF9yv8gTI0kJqt1kaFLePourRfa/Fk8kvuc6swFgQ1ts6XT1HpxCgKUdlczD3YqCAxZildh4wtZEMBsG7aiUMuymDdOHSyILkeT+k4smg5Xl4ltaC9yQzHB0pQKKvbTBERyjlCsaVG0toMMXzacGvsEH0= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; arc=none smtp.client-ip=217.140.110.172 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com 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 78C53C15; Wed, 28 Feb 2024 05:25:19 -0800 (PST) Received: from [10.57.11.244] (unknown [10.57.11.244]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 187A53F762; Wed, 28 Feb 2024 05:24:36 -0800 (PST) Message-ID: Date: Wed, 28 Feb 2024 13:24:53 +0000 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH V3 2/2] cpufreq: scmi: Register for limit change notifications Content-Language: en-US To: Sibi Sankar Cc: linux-arm-kernel@lists.infradead.org, pierre.gondois@arm.com, dietmar.eggemann@arm.com, morten.rasmussen@arm.com, viresh.kumar@linaro.org, rafael@kernel.org, cristian.marussi@arm.com, sudeep.holla@arm.com, linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, quic_mdtipton@quicinc.com, linux-arm-msm@vger.kernel.org References: <20240227181632.659133-1-quic_sibis@quicinc.com> <20240227181632.659133-3-quic_sibis@quicinc.com> From: Lukasz Luba In-Reply-To: <20240227181632.659133-3-quic_sibis@quicinc.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit On 2/27/24 18:16, Sibi Sankar wrote: > Register for limit change notifications if supported and use the throttled > frequency from the notification to apply HW pressure. > > Signed-off-by: Sibi Sankar > --- > > v3: > * Sanitize range_max received from the notifier. [Pierre] > * Update commit message. > > drivers/cpufreq/scmi-cpufreq.c | 29 ++++++++++++++++++++++++++++- > 1 file changed, 28 insertions(+), 1 deletion(-) > > diff --git a/drivers/cpufreq/scmi-cpufreq.c b/drivers/cpufreq/scmi-cpufreq.c > index 76a0ddbd9d24..78b87b72962d 100644 > --- a/drivers/cpufreq/scmi-cpufreq.c > +++ b/drivers/cpufreq/scmi-cpufreq.c > @@ -25,9 +25,13 @@ struct scmi_data { > int domain_id; > int nr_opp; > struct device *cpu_dev; > + struct cpufreq_policy *policy; > cpumask_var_t opp_shared_cpus; > + struct notifier_block limit_notify_nb; > }; > > +const struct scmi_handle *handle; > +static struct scmi_device *scmi_dev; > static struct scmi_protocol_handle *ph; > static const struct scmi_perf_proto_ops *perf_ops; > static struct cpufreq_driver scmi_cpufreq_driver; > @@ -151,6 +155,20 @@ static struct freq_attr *scmi_cpufreq_hw_attr[] = { > NULL, > }; > > +static int scmi_limit_notify_cb(struct notifier_block *nb, unsigned long event, void *data) > +{ > + struct scmi_data *priv = container_of(nb, struct scmi_data, limit_notify_nb); > + struct scmi_perf_limits_report *limit_notify = data; > + struct cpufreq_policy *policy = priv->policy; > + > + policy->max = clamp(limit_notify->range_max_freq/HZ_PER_KHZ, policy->cpuinfo.min_freq, > + policy->cpuinfo.max_freq); Please take the division operation out of this clamp() call, somewhere above. Currently it 'blurs' these stuff, while it's important convertion to khz. You can call it e.g.: limit_freq_khz = limit_notify->range_max_freq / HZ_PER_KHZ; then use in clamp(limit_freq_khz, ...) > + > + cpufreq_update_pressure(policy); > + > + return NOTIFY_OK; > +} > + > static int scmi_cpufreq_init(struct cpufreq_policy *policy) > { > int ret, nr_opp, domain; > @@ -269,6 +287,15 @@ static int scmi_cpufreq_init(struct cpufreq_policy *policy) > } > } > > + priv->limit_notify_nb.notifier_call = scmi_limit_notify_cb; > + ret = handle->notify_ops->devm_event_notifier_register(scmi_dev, SCMI_PROTOCOL_PERF, > + SCMI_EVENT_PERFORMANCE_LIMITS_CHANGED, > + &domain, > + &priv->limit_notify_nb); > + if (ret) > + dev_warn(cpu_dev, > + "failed to register for limits change notifier for domain %d\n", domain); > + > priv->policy = policy; > > return 0; > @@ -342,8 +369,8 @@ static int scmi_cpufreq_probe(struct scmi_device *sdev) > { > int ret; > struct device *dev = &sdev->dev; > - const struct scmi_handle *handle; It should be a compilation error... > > + scmi_dev = sdev; > handle = sdev->handle; due to usage here, wasn't it? > > if (!handle)