mbox series

[v2,0/4] Update Energy Model after chip binning adjusted voltages

Message ID 20240322103221.47594-1-lukasz.luba@arm.com (mailing list archive)
Headers show
Series Update Energy Model after chip binning adjusted voltages | expand

Message

Lukasz Luba March 22, 2024, 10:32 a.m. UTC
Hi all,

This is a follow-up patch aiming to add EM modification due to chip binning.
The first RFC and the discussion can be found here [1].

It uses Exynos chip driver code as a 1st user. The EM framework has been
extended to handle this use case easily, when the voltage has been changed
after setup. On my Odroid-xu4 in some OPPs I can observe ~20% power difference.
According to that data in driver tables it could be up to ~29%.

This chip binning is applicable to a lot of SoCs, so the EM framework should
make it easy to update. It uses the existing OPP and DT information to
re-calculate the new power values.


Changes:
v2:
- removed 'ret' from error message which wasn't initialized (Christian)
v1:
- exported the OPP calculation function from the OPP/OF so it can be
  used from EM fwk (Viresh)
- refactored EM updating function to re-use common code
- added new EM function which can be used by chip device drivers which
  modify the voltage in OPPs
RFC is at [1]

Regards,
Lukasz Luba

[1] https://lore.kernel.org/lkml/20231220110339.1065505-1-lukasz.luba@arm.com/

Lukasz Luba (4):
  OPP: OF: Export dev_opp_pm_calc_power() for usage from EM
  PM: EM: Change the em_adjust_new_capacity() to re-use code
  PM: EM: Add em_dev_update_chip_binning()
  soc: samsung: exynos-asv: Update Energy Model after adjusting voltage

 drivers/opp/of.c                 |  17 +++--
 drivers/soc/samsung/exynos-asv.c |  11 +++-
 include/linux/energy_model.h     |   5 ++
 include/linux/pm_opp.h           |   8 +++
 kernel/power/energy_model.c      | 109 +++++++++++++++++++++++++------
 5 files changed, 125 insertions(+), 25 deletions(-)

Comments

Lukasz Luba March 22, 2024, 11:06 a.m. UTC | #1
On 3/22/24 10:32, Lukasz Luba wrote:
> Hi all,
> 
> This is a follow-up patch aiming to add EM modification due to chip binning.
> The first RFC and the discussion can be found here [1].
> 
> It uses Exynos chip driver code as a 1st user. The EM framework has been
> extended to handle this use case easily, when the voltage has been changed
> after setup. On my Odroid-xu4 in some OPPs I can observe ~20% power difference.
> According to that data in driver tables it could be up to ~29%.
> 
> This chip binning is applicable to a lot of SoCs, so the EM framework should
> make it easy to update. It uses the existing OPP and DT information to
> re-calculate the new power values.
> 
> 
> Changes:
> v2:
> - removed 'ret' from error message which wasn't initialized (Christian)
> v1:
> - exported the OPP calculation function from the OPP/OF so it can be
>    used from EM fwk (Viresh)
> - refactored EM updating function to re-use common code
> - added new EM function which can be used by chip device drivers which
>    modify the voltage in OPPs
> RFC is at [1]
> 
> Regards,
> Lukasz Luba
> 
> [1] https://lore.kernel.org/lkml/20231220110339.1065505-1-lukasz.luba@arm.com/
> 
> Lukasz Luba (4):
>    OPP: OF: Export dev_opp_pm_calc_power() for usage from EM
>    PM: EM: Change the em_adjust_new_capacity() to re-use code
>    PM: EM: Add em_dev_update_chip_binning()
>    soc: samsung: exynos-asv: Update Energy Model after adjusting voltage
> 
>   drivers/opp/of.c                 |  17 +++--
>   drivers/soc/samsung/exynos-asv.c |  11 +++-
>   include/linux/energy_model.h     |   5 ++
>   include/linux/pm_opp.h           |   8 +++
>   kernel/power/energy_model.c      | 109 +++++++++++++++++++++++++------
>   5 files changed, 125 insertions(+), 25 deletions(-)
> 

Please ignore this version. It still has that 'ret'. I've fixed in
different repo, but sent patches from different terminal.

I'll resend it in a second...

Regards,
Lukasz