[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20240321102100.2401340-1-ye.zhang@rock-chips.com>
Date: Thu, 21 Mar 2024 18:21:00 +0800
From: Ye Zhang <ye.zhang@...k-chips.com>
To: ye.zhang@...k-chips.com,
finley.xiao@...k-chips.com,
heiko@...ech.de,
daniel.lezcano@...aro.org,
rui.zhang@...el.com,
lukasz.luba@....com,
rafael@...nel.org
Cc: tao.huang@...k-chips.com,
linux-rockchip@...ts.infradead.org,
linux-pm@...r.kernel.org,
linux-kernel@...r.kernel.org,
stable@...r.kernel.org
Subject: [PATCH v2] thermal: devfreq_cooling: Fix perf state when calculate dfc res_util
The issue occurs when the devfreq cooling device uses the EM power model
and the get_real_power() callback is provided by the driver.
The EM power table is sorted ascending,can't index the table by cooling
device state,so convert cooling state to performance state by
dfc->max_state - dfc->capped_state.
Fixes: 615510fe13bd ("thermal: devfreq_cooling: remove old power model and use EM")
Cc: 5.11+ <stable@...r.kernel.org> # 5.11+
Signed-off-by: Ye Zhang <ye.zhang@...k-chips.com>
---
v1 -> v2:
- Update the commit message.
drivers/thermal/devfreq_cooling.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/thermal/devfreq_cooling.c b/drivers/thermal/devfreq_cooling.c
index 50dec24e967a..8fd7cf1932cd 100644
--- a/drivers/thermal/devfreq_cooling.c
+++ b/drivers/thermal/devfreq_cooling.c
@@ -214,7 +214,7 @@ static int devfreq_cooling_get_requested_power(struct thermal_cooling_device *cd
res = dfc->power_ops->get_real_power(df, power, freq, voltage);
if (!res) {
- state = dfc->capped_state;
+ state = dfc->max_state - dfc->capped_state;
/* Convert EM power into milli-Watts first */
rcu_read_lock();
--
2.34.1
Powered by blists - more mailing lists