Hi Ye,
On 3/20/24 07:57, Ye Zhang wrote:
> 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.
>
> Signed-off-by: Ye Zhang <[email protected]>
> ---
> 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();
Thank you for the patch. Good catch! It's under the device driver
callback optional thing: get_real_power().
Please send the v2 with extended explanation about the section
of the code, which is triggered by the get_real_power() presence.
Also, please add the tags, so it can be collected by stable kernel.
Fixes: 615510fe13bd2434610 ("thermal: devfreq_cooling: remove old power
model and use EM")
Cc: 5.11+ <[email protected]> # 5.11+
BTW, how did you trigger that issue? Do you have such a driver
which provides this get_real_power() callback?
Regards,
Lukasz