3759ec678e
The DTPM framework is available but without a way to configure it. This change provides a way to create a hierarchy of DTPM node where the power consumption reflects the sum of the children's power consumption. It is up to the platform to specify an array of dtpm nodes where each element has a pointer to its parent, except the top most one. The type of the node gives the indication of which initialization callback to call. At this time, we can create a virtual node, where its purpose is to be a parent in the hierarchy, and a DT node where the name describes its path. In order to ensure a nice self-encapsulation, the DTPM subsys array contains a couple of initialization functions, one to setup the DTPM backend and one to initialize it up. With this approach, the DTPM framework has a very few material to export. Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> Reviewed-by: Ulf Hansson <ulf.hansson@linaro.org> Link: https://lore.kernel.org/r/20220128163537.212248-3-daniel.lezcano@linaro.org
61 lines
1.9 KiB
Plaintext
61 lines
1.9 KiB
Plaintext
# SPDX-License-Identifier: GPL-2.0-only
|
|
#
|
|
# Generic power capping sysfs interface configuration
|
|
#
|
|
|
|
menuconfig POWERCAP
|
|
bool "Generic powercap sysfs driver"
|
|
help
|
|
The power capping sysfs interface allows kernel subsystems to expose power
|
|
capping settings to user space in a consistent way. Usually, it consists
|
|
of multiple control types that determine which settings may be exposed and
|
|
power zones representing parts of the system that can be subject to power
|
|
capping.
|
|
|
|
If you want this code to be compiled in, say Y here.
|
|
|
|
if POWERCAP
|
|
# Client driver configurations go here.
|
|
config INTEL_RAPL_CORE
|
|
tristate
|
|
|
|
config INTEL_RAPL
|
|
tristate "Intel RAPL Support via MSR Interface"
|
|
depends on X86 && IOSF_MBI
|
|
select INTEL_RAPL_CORE
|
|
help
|
|
This enables support for the Intel Running Average Power Limit (RAPL)
|
|
technology via MSR interface, which allows power limits to be enforced
|
|
and monitored on modern Intel processors (Sandy Bridge and later).
|
|
|
|
In RAPL, the platform level settings are divided into domains for
|
|
fine grained control. These domains include processor package, DRAM
|
|
controller, CPU core (Power Plane 0), graphics uncore (Power Plane
|
|
1), etc.
|
|
|
|
config IDLE_INJECT
|
|
bool "Idle injection framework"
|
|
depends on CPU_IDLE
|
|
default n
|
|
help
|
|
This enables support for the idle injection framework. It
|
|
provides a way to force idle periods on a set of specified
|
|
CPUs for power capping. Idle period can be injected
|
|
synchronously on a set of specified CPUs or alternatively
|
|
on a per CPU basis.
|
|
|
|
config DTPM
|
|
bool "Power capping for Dynamic Thermal Power Management (EXPERIMENTAL)"
|
|
depends on OF
|
|
help
|
|
This enables support for the power capping for the dynamic
|
|
thermal power management userspace engine.
|
|
|
|
config DTPM_CPU
|
|
bool "Add CPU power capping based on the energy model"
|
|
depends on DTPM && ENERGY_MODEL
|
|
help
|
|
This enables support for CPU power limitation based on
|
|
energy model.
|
|
endif
|