[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <57a5dc82-f2c9-5190-e3fa-702b2eb2de5e@arm.com>
Date: Mon, 3 Jul 2023 16:06:46 +0100
From: Lukasz Luba <lukasz.luba@....com>
To: Dietmar Eggemann <dietmar.eggemann@....com>
Cc: rui.zhang@...el.com, amit.kucheria@...durent.com,
amit.kachhap@...il.com, daniel.lezcano@...aro.org,
viresh.kumar@...aro.org, len.brown@...el.com, pavel@....cz,
Pierre.Gondois@....com, ionela.voinescu@....com,
rostedt@...dmis.org, mhiramat@...nel.org,
linux-kernel@...r.kernel.org, linux-pm@...r.kernel.org,
rafael@...nel.org
Subject: Re: [PATCH v2 06/17] PM: EM: Add update_power() callback for runtime
modifications
Hi Dietmar,
On 5/30/23 10:31, Dietmar Eggemann wrote:
> On 12/05/2023 11:57, Lukasz Luba wrote:
>> The Energy Model (EM) is going to support runtime modifications. This
>> new callback would be used in the upcoming EM changes. The drivers
>> or frameworks which want to modify the EM have to implement the
>> update_power() callback and provide it via EM API
>> em_dev_update_perf_domain(). The callback is then used by the EM
>> framework to get new power values for each frequency in existing EM.
>
> Do we have any numbers or feedback that the chosen design (i.e. update
> per performance state through update_power()) is performant enough for
> the anticipated use case on real devices?
>
Yes, we have. I have a testing kernel module which updates the EM
with queue_delayed_work() every 100ms. That update is for Little's EM
where we have 11 OPPs. We call the new callback for each OPP
in the em_dev_update_perf_domain(). I have measured that total function
time.
When we fix all CPUs freq to max freq on pixel6 and disable deep idle
states and leave only WFI, then we can run some tracing and capture the
results:
(The 4 CPUs from top are the little (1.8MHz), than 2 Mid (2.2GHz) and
then 2 big (2.8GHz))
------------------------------------
Function Hit Time Avg
s^2
-------- --- ---- ---
---
em_dev_update_perf_domain 3104 51236.39 us 16.506
us 75.344 us
Function Hit Time Avg
s^2
-------- --- ---- ---
---
em_dev_update_perf_domain 1264 20768.15 us 16.430
us 62.257 us
Function Hit Time Avg
s^2
-------- --- ---- ---
---
em_dev_update_perf_domain 1166 18632.95 us 15.980
us 70.707 us
Function Hit Time Avg
s^2
-------- --- ---- ---
---
em_dev_update_perf_domain 770 12334.43 us 16.018
us 66.337 us
Function Hit Time Avg
s^2
-------- --- ---- ---
---
em_dev_update_perf_domain 101 920.613 us 9.114
us 21.380 us
Function Hit Time Avg
s^2
-------- --- ---- ---
---
em_dev_update_perf_domain 20 211.830 us 10.591
us 23.998 us
Function Hit Time Avg
s^2
-------- --- ---- ---
---
Function Hit Time Avg
s^2
-------- --- ---- ---
---
em_dev_update_perf_domain 15 78.085 us 5.205
us 7.444 us
------------------------------------
As you can see in avg on Little CPUs it takes ~16us, on Mid ~10us and on
Big ~5us.
If such updating kernel module is implemented correctly, it would be
most often scheduled on the Littles as you can see based on 'Hit'
column.
Therefore, IMO this cost can be OK for the upstream. This EM runtime
change won't be triggered very often. If it would be e.g. every
100ms than the cost ~1.5us per 1 OPP is negligible.
Regards,
Lukasz
Powered by blists - more mailing lists