Skip to content

Commit 49835c1

Browse files
committed
Merge tag 'pm-5.7-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm
Pull power management updates from Rafael Wysocki: "These clean up and rework the PM QoS API, address a suspend-to-idle wakeup regression on some ACPI-based platforms, clean up and extend a few cpuidle drivers, update multiple cpufreq drivers and cpufreq documentation, and fix a number of issues in devfreq and several other things all over. Specifics: - Clean up and rework the PM QoS API to simplify the code and reduce the size of it (Rafael Wysocki). - Fix a suspend-to-idle wakeup regression on Dell XPS13 9370 and similar platforms where the USB plug/unplug events are handled by the EC (Rafael Wysocki). - CLean up the intel_idle and PSCI cpuidle drivers (Rafael Wysocki, Ulf Hansson). - Extend the haltpoll cpuidle driver so that it can be forced to run on some systems where it refused to load (Maciej Szmigiero). - Convert several cpufreq documents to the .rst format and move the legacy driver documentation into one common file (Mauro Carvalho Chehab, Rafael Wysocki). - Update several cpufreq drivers: * Extend and fix the imx-cpufreq-dt driver (Anson Huang). * Improve the -EPROBE_DEFER handling and fix unwanted CPU overclocking on i.MX6ULL in imx6q-cpufreq (Anson Huang, Christoph Niedermaier). * Add support for Krait based SoCs to the qcom driver (Ansuel Smith). * Add support for OPP_PLUS to ti-cpufreq (Lokesh Vutla). * Add platform specific intermediate callbacks support to cpufreq-dt and update the imx6q driver (Peng Fan). * Simplify and consolidate some pieces of the intel_pstate driver and update its documentation (Rafael Wysocki, Alex Hung). - Fix several devfreq issues: * Remove unneeded extern keyword from a devfreq header file and use the DEVFREQ_GOV_UPDATE_INTERNAL event name instead of DEVFREQ_GOV_INTERNAL (Chanwoo Choi). * Fix the handling of dev_pm_qos_remove_request() result (Leonard Crestez). * Use constant name for userspace governor (Pierre Kuo). * Get rid of doc warnings and fix a typo (Christophe JAILLET). - Use built-in RCU list checking in some places in the PM core to avoid false-positive RCU usage warnings (Madhuparna Bhowmik). - Add explicit READ_ONCE()/WRITE_ONCE() annotations to low-level PM QoS routines (Qian Cai). - Fix removal of wakeup sources to avoid NULL pointer dereferences in a corner case (Neeraj Upadhyay). - Clean up the handling of hibernate compat ioctls and fix the related documentation (Eric Biggers). - Update the idle_inject power capping driver to use variable-length arrays instead of zero-length arrays (Gustavo Silva). - Fix list format in a PM QoS document (Randy Dunlap). - Make the cpufreq stats module use scnprintf() to avoid potential buffer overflows (Takashi Iwai). - Add pm_runtime_get_if_active() to PM-runtime API (Sakari Ailus). - Allow no domain-idle-states DT property in generic PM domains (Ulf Hansson). - Fix a broken y-axis scale in the intel_pstate_tracer utility (Doug Smythies)" * tag 'pm-5.7-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (78 commits) cpufreq: intel_pstate: Simplify intel_pstate_cpu_init() tools/power/x86/intel_pstate_tracer: fix a broken y-axis scale ACPI: PM: s2idle: Refine active GPEs check ACPICA: Allow acpi_any_gpe_status_set() to skip one GPE PM: sleep: wakeup: Skip wakeup_source_sysfs_remove() if device is not there PM / devfreq: Get rid of some doc warnings PM / devfreq: Fix handling dev_pm_qos_remove_request result PM / devfreq: Fix a typo in a comment PM / devfreq: Change to DEVFREQ_GOV_UPDATE_INTERVAL event name PM / devfreq: Remove unneeded extern keyword PM / devfreq: Use constant name of userspace governor ACPI: PM: s2idle: Fix comment in acpi_s2idle_prepare_late() cpufreq: qcom: Add support for krait based socs cpufreq: imx6q-cpufreq: Improve the logic of -EPROBE_DEFER handling cpufreq: Use scnprintf() for avoiding potential buffer overflow cpuidle: psci: Split psci_dt_cpu_init_idle() PM / Domains: Allow no domain-idle-states DT property in genpd when parsing PM / hibernate: Remove unnecessary compat ioctl overrides PM: hibernate: fix docs for ioctls that return loff_t via pointer Documentation: intel_pstate: update links for references ...
2 parents a231bed + 2409000 commit 49835c1

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

79 files changed

+1564
-1573
lines changed
Lines changed: 274 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,274 @@
1+
.. SPDX-License-Identifier: GPL-2.0
2+
3+
=======================================================
4+
Legacy Documentation of CPU Performance Scaling Drivers
5+
=======================================================
6+
7+
Included below are historic documents describing assorted
8+
:doc:`CPU performance scaling <cpufreq>` drivers. They are reproduced verbatim,
9+
with the original white space formatting and indentation preserved, except for
10+
the added leading space character in every line of text.
11+
12+
13+
AMD PowerNow! Drivers
14+
=====================
15+
16+
::
17+
18+
PowerNow! and Cool'n'Quiet are AMD names for frequency
19+
management capabilities in AMD processors. As the hardware
20+
implementation changes in new generations of the processors,
21+
there is a different cpu-freq driver for each generation.
22+
23+
Note that the driver's will not load on the "wrong" hardware,
24+
so it is safe to try each driver in turn when in doubt as to
25+
which is the correct driver.
26+
27+
Note that the functionality to change frequency (and voltage)
28+
is not available in all processors. The drivers will refuse
29+
to load on processors without this capability. The capability
30+
is detected with the cpuid instruction.
31+
32+
The drivers use BIOS supplied tables to obtain frequency and
33+
voltage information appropriate for a particular platform.
34+
Frequency transitions will be unavailable if the BIOS does
35+
not supply these tables.
36+
37+
6th Generation: powernow-k6
38+
39+
7th Generation: powernow-k7: Athlon, Duron, Geode.
40+
41+
8th Generation: powernow-k8: Athlon, Athlon 64, Opteron, Sempron.
42+
Documentation on this functionality in 8th generation processors
43+
is available in the "BIOS and Kernel Developer's Guide", publication
44+
26094, in chapter 9, available for download from www.amd.com.
45+
46+
BIOS supplied data, for powernow-k7 and for powernow-k8, may be
47+
from either the PSB table or from ACPI objects. The ACPI support
48+
is only available if the kernel config sets CONFIG_ACPI_PROCESSOR.
49+
The powernow-k8 driver will attempt to use ACPI if so configured,
50+
and fall back to PST if that fails.
51+
The powernow-k7 driver will try to use the PSB support first, and
52+
fall back to ACPI if the PSB support fails. A module parameter,
53+
acpi_force, is provided to force ACPI support to be used instead
54+
of PSB support.
55+
56+
57+
``cpufreq-nforce2``
58+
===================
59+
60+
::
61+
62+
The cpufreq-nforce2 driver changes the FSB on nVidia nForce2 platforms.
63+
64+
This works better than on other platforms, because the FSB of the CPU
65+
can be controlled independently from the PCI/AGP clock.
66+
67+
The module has two options:
68+
69+
fid: multiplier * 10 (for example 8.5 = 85)
70+
min_fsb: minimum FSB
71+
72+
If not set, fid is calculated from the current CPU speed and the FSB.
73+
min_fsb defaults to FSB at boot time - 50 MHz.
74+
75+
IMPORTANT: The available range is limited downwards!
76+
Also the minimum available FSB can differ, for systems
77+
booting with 200 MHz, 150 should always work.
78+
79+
80+
``pcc-cpufreq``
81+
===============
82+
83+
::
84+
85+
/*
86+
* pcc-cpufreq.txt - PCC interface documentation
87+
*
88+
* Copyright (C) 2009 Red Hat, Matthew Garrett <[email protected]>
89+
* Copyright (C) 2009 Hewlett-Packard Development Company, L.P.
90+
* Nagananda Chumbalkar <[email protected]>
91+
*/
92+
93+
94+
Processor Clocking Control Driver
95+
---------------------------------
96+
97+
Contents:
98+
---------
99+
1. Introduction
100+
1.1 PCC interface
101+
1.1.1 Get Average Frequency
102+
1.1.2 Set Desired Frequency
103+
1.2 Platforms affected
104+
2. Driver and /sys details
105+
2.1 scaling_available_frequencies
106+
2.2 cpuinfo_transition_latency
107+
2.3 cpuinfo_cur_freq
108+
2.4 related_cpus
109+
3. Caveats
110+
111+
1. Introduction:
112+
----------------
113+
Processor Clocking Control (PCC) is an interface between the platform
114+
firmware and OSPM. It is a mechanism for coordinating processor
115+
performance (ie: frequency) between the platform firmware and the OS.
116+
117+
The PCC driver (pcc-cpufreq) allows OSPM to take advantage of the PCC
118+
interface.
119+
120+
OS utilizes the PCC interface to inform platform firmware what frequency the
121+
OS wants for a logical processor. The platform firmware attempts to achieve
122+
the requested frequency. If the request for the target frequency could not be
123+
satisfied by platform firmware, then it usually means that power budget
124+
conditions are in place, and "power capping" is taking place.
125+
126+
1.1 PCC interface:
127+
------------------
128+
The complete PCC specification is available here:
129+
https://acpica.org/sites/acpica/files/Processor-Clocking-Control-v1p0.pdf
130+
131+
PCC relies on a shared memory region that provides a channel for communication
132+
between the OS and platform firmware. PCC also implements a "doorbell" that
133+
is used by the OS to inform the platform firmware that a command has been
134+
sent.
135+
136+
The ACPI PCCH() method is used to discover the location of the PCC shared
137+
memory region. The shared memory region header contains the "command" and
138+
"status" interface. PCCH() also contains details on how to access the platform
139+
doorbell.
140+
141+
The following commands are supported by the PCC interface:
142+
* Get Average Frequency
143+
* Set Desired Frequency
144+
145+
The ACPI PCCP() method is implemented for each logical processor and is
146+
used to discover the offsets for the input and output buffers in the shared
147+
memory region.
148+
149+
When PCC mode is enabled, the platform will not expose processor performance
150+
or throttle states (_PSS, _TSS and related ACPI objects) to OSPM. Therefore,
151+
the native P-state driver (such as acpi-cpufreq for Intel, powernow-k8 for
152+
AMD) will not load.
153+
154+
However, OSPM remains in control of policy. The governor (eg: "ondemand")
155+
computes the required performance for each processor based on server workload.
156+
The PCC driver fills in the command interface, and the input buffer and
157+
communicates the request to the platform firmware. The platform firmware is
158+
responsible for delivering the requested performance.
159+
160+
Each PCC command is "global" in scope and can affect all the logical CPUs in
161+
the system. Therefore, PCC is capable of performing "group" updates. With PCC
162+
the OS is capable of getting/setting the frequency of all the logical CPUs in
163+
the system with a single call to the BIOS.
164+
165+
1.1.1 Get Average Frequency:
166+
----------------------------
167+
This command is used by the OSPM to query the running frequency of the
168+
processor since the last time this command was completed. The output buffer
169+
indicates the average unhalted frequency of the logical processor expressed as
170+
a percentage of the nominal (ie: maximum) CPU frequency. The output buffer
171+
also signifies if the CPU frequency is limited by a power budget condition.
172+
173+
1.1.2 Set Desired Frequency:
174+
----------------------------
175+
This command is used by the OSPM to communicate to the platform firmware the
176+
desired frequency for a logical processor. The output buffer is currently
177+
ignored by OSPM. The next invocation of "Get Average Frequency" will inform
178+
OSPM if the desired frequency was achieved or not.
179+
180+
1.2 Platforms affected:
181+
-----------------------
182+
The PCC driver will load on any system where the platform firmware:
183+
* supports the PCC interface, and the associated PCCH() and PCCP() methods
184+
* assumes responsibility for managing the hardware clocking controls in order
185+
to deliver the requested processor performance
186+
187+
Currently, certain HP ProLiant platforms implement the PCC interface. On those
188+
platforms PCC is the "default" choice.
189+
190+
However, it is possible to disable this interface via a BIOS setting. In
191+
such an instance, as is also the case on platforms where the PCC interface
192+
is not implemented, the PCC driver will fail to load silently.
193+
194+
2. Driver and /sys details:
195+
---------------------------
196+
When the driver loads, it merely prints the lowest and the highest CPU
197+
frequencies supported by the platform firmware.
198+
199+
The PCC driver loads with a message such as:
200+
pcc-cpufreq: (v1.00.00) driver loaded with frequency limits: 1600 MHz, 2933
201+
MHz
202+
203+
This means that the OPSM can request the CPU to run at any frequency in
204+
between the limits (1600 MHz, and 2933 MHz) specified in the message.
205+
206+
Internally, there is no need for the driver to convert the "target" frequency
207+
to a corresponding P-state.
208+
209+
The VERSION number for the driver will be of the format v.xy.ab.
210+
eg: 1.00.02
211+
----- --
212+
| |
213+
| -- this will increase with bug fixes/enhancements to the driver
214+
|-- this is the version of the PCC specification the driver adheres to
215+
216+
217+
The following is a brief discussion on some of the fields exported via the
218+
/sys filesystem and how their values are affected by the PCC driver:
219+
220+
2.1 scaling_available_frequencies:
221+
----------------------------------
222+
scaling_available_frequencies is not created in /sys. No intermediate
223+
frequencies need to be listed because the BIOS will try to achieve any
224+
frequency, within limits, requested by the governor. A frequency does not have
225+
to be strictly associated with a P-state.
226+
227+
2.2 cpuinfo_transition_latency:
228+
-------------------------------
229+
The cpuinfo_transition_latency field is 0. The PCC specification does
230+
not include a field to expose this value currently.
231+
232+
2.3 cpuinfo_cur_freq:
233+
---------------------
234+
A) Often cpuinfo_cur_freq will show a value different than what is declared
235+
in the scaling_available_frequencies or scaling_cur_freq, or scaling_max_freq.
236+
This is due to "turbo boost" available on recent Intel processors. If certain
237+
conditions are met the BIOS can achieve a slightly higher speed than requested
238+
by OSPM. An example:
239+
240+
scaling_cur_freq : 2933000
241+
cpuinfo_cur_freq : 3196000
242+
243+
B) There is a round-off error associated with the cpuinfo_cur_freq value.
244+
Since the driver obtains the current frequency as a "percentage" (%) of the
245+
nominal frequency from the BIOS, sometimes, the values displayed by
246+
scaling_cur_freq and cpuinfo_cur_freq may not match. An example:
247+
248+
scaling_cur_freq : 1600000
249+
cpuinfo_cur_freq : 1583000
250+
251+
In this example, the nominal frequency is 2933 MHz. The driver obtains the
252+
current frequency, cpuinfo_cur_freq, as 54% of the nominal frequency:
253+
254+
54% of 2933 MHz = 1583 MHz
255+
256+
Nominal frequency is the maximum frequency of the processor, and it usually
257+
corresponds to the frequency of the P0 P-state.
258+
259+
2.4 related_cpus:
260+
-----------------
261+
The related_cpus field is identical to affected_cpus.
262+
263+
affected_cpus : 4
264+
related_cpus : 4
265+
266+
Currently, the PCC driver does not evaluate _PSD. The platforms that support
267+
PCC do not implement SW_ALL. So OSPM doesn't need to perform any coordination
268+
to ensure that the same frequency is requested of all dependent CPUs.
269+
270+
3. Caveats:
271+
-----------
272+
The "cpufreq_stats" module in its present form cannot be loaded and
273+
expected to work with the PCC driver. Since the "cpufreq_stats" module
274+
provides information wrt each P-state, it is not applicable to the PCC driver.

Documentation/admin-guide/pm/cpuidle.rst

Lines changed: 36 additions & 37 deletions
Original file line numberDiff line numberDiff line change
@@ -583,20 +583,17 @@ Power Management Quality of Service for CPUs
583583
The power management quality of service (PM QoS) framework in the Linux kernel
584584
allows kernel code and user space processes to set constraints on various
585585
energy-efficiency features of the kernel to prevent performance from dropping
586-
below a required level. The PM QoS constraints can be set globally, in
587-
predefined categories referred to as PM QoS classes, or against individual
588-
devices.
586+
below a required level.
589587

590588
CPU idle time management can be affected by PM QoS in two ways, through the
591-
global constraint in the ``PM_QOS_CPU_DMA_LATENCY`` class and through the
592-
resume latency constraints for individual CPUs. Kernel code (e.g. device
593-
drivers) can set both of them with the help of special internal interfaces
594-
provided by the PM QoS framework. User space can modify the former by opening
595-
the :file:`cpu_dma_latency` special device file under :file:`/dev/` and writing
596-
a binary value (interpreted as a signed 32-bit integer) to it. In turn, the
597-
resume latency constraint for a CPU can be modified by user space by writing a
598-
string (representing a signed 32-bit integer) to the
599-
:file:`power/pm_qos_resume_latency_us` file under
589+
global CPU latency limit and through the resume latency constraints for
590+
individual CPUs. Kernel code (e.g. device drivers) can set both of them with
591+
the help of special internal interfaces provided by the PM QoS framework. User
592+
space can modify the former by opening the :file:`cpu_dma_latency` special
593+
device file under :file:`/dev/` and writing a binary value (interpreted as a
594+
signed 32-bit integer) to it. In turn, the resume latency constraint for a CPU
595+
can be modified from user space by writing a string (representing a signed
596+
32-bit integer) to the :file:`power/pm_qos_resume_latency_us` file under
600597
:file:`/sys/devices/system/cpu/cpu<N>/` in ``sysfs``, where the CPU number
601598
``<N>`` is allocated at the system initialization time. Negative values
602599
will be rejected in both cases and, also in both cases, the written integer
@@ -605,32 +602,34 @@ number will be interpreted as a requested PM QoS constraint in microseconds.
605602
The requested value is not automatically applied as a new constraint, however,
606603
as it may be less restrictive (greater in this particular case) than another
607604
constraint previously requested by someone else. For this reason, the PM QoS
608-
framework maintains a list of requests that have been made so far in each
609-
global class and for each device, aggregates them and applies the effective
610-
(minimum in this particular case) value as the new constraint.
605+
framework maintains a list of requests that have been made so far for the
606+
global CPU latency limit and for each individual CPU, aggregates them and
607+
applies the effective (minimum in this particular case) value as the new
608+
constraint.
611609

612610
In fact, opening the :file:`cpu_dma_latency` special device file causes a new
613-
PM QoS request to be created and added to the priority list of requests in the
614-
``PM_QOS_CPU_DMA_LATENCY`` class and the file descriptor coming from the
615-
"open" operation represents that request. If that file descriptor is then
616-
used for writing, the number written to it will be associated with the PM QoS
617-
request represented by it as a new requested constraint value. Next, the
618-
priority list mechanism will be used to determine the new effective value of
619-
the entire list of requests and that effective value will be set as a new
620-
constraint. Thus setting a new requested constraint value will only change the
621-
real constraint if the effective "list" value is affected by it. In particular,
622-
for the ``PM_QOS_CPU_DMA_LATENCY`` class it only affects the real constraint if
623-
it is the minimum of the requested constraints in the list. The process holding
624-
a file descriptor obtained by opening the :file:`cpu_dma_latency` special device
625-
file controls the PM QoS request associated with that file descriptor, but it
626-
controls this particular PM QoS request only.
611+
PM QoS request to be created and added to a global priority list of CPU latency
612+
limit requests and the file descriptor coming from the "open" operation
613+
represents that request. If that file descriptor is then used for writing, the
614+
number written to it will be associated with the PM QoS request represented by
615+
it as a new requested limit value. Next, the priority list mechanism will be
616+
used to determine the new effective value of the entire list of requests and
617+
that effective value will be set as a new CPU latency limit. Thus requesting a
618+
new limit value will only change the real limit if the effective "list" value is
619+
affected by it, which is the case if it is the minimum of the requested values
620+
in the list.
621+
622+
The process holding a file descriptor obtained by opening the
623+
:file:`cpu_dma_latency` special device file controls the PM QoS request
624+
associated with that file descriptor, but it controls this particular PM QoS
625+
request only.
627626

628627
Closing the :file:`cpu_dma_latency` special device file or, more precisely, the
629628
file descriptor obtained while opening it, causes the PM QoS request associated
630-
with that file descriptor to be removed from the ``PM_QOS_CPU_DMA_LATENCY``
631-
class priority list and destroyed. If that happens, the priority list mechanism
632-
will be used, again, to determine the new effective value for the whole list
633-
and that value will become the new real constraint.
629+
with that file descriptor to be removed from the global priority list of CPU
630+
latency limit requests and destroyed. If that happens, the priority list
631+
mechanism will be used again, to determine the new effective value for the whole
632+
list and that value will become the new limit.
634633

635634
In turn, for each CPU there is one resume latency PM QoS request associated with
636635
the :file:`power/pm_qos_resume_latency_us` file under
@@ -647,10 +646,10 @@ CPU in question every time the list of requests is updated this way or another
647646
(there may be other requests coming from kernel code in that list).
648647

649648
CPU idle time governors are expected to regard the minimum of the global
650-
effective ``PM_QOS_CPU_DMA_LATENCY`` class constraint and the effective
651-
resume latency constraint for the given CPU as the upper limit for the exit
652-
latency of the idle states they can select for that CPU. They should never
653-
select any idle states with exit latency beyond that limit.
649+
(effective) CPU latency limit and the effective resume latency constraint for
650+
the given CPU as the upper limit for the exit latency of the idle states that
651+
they are allowed to select for that CPU. They should never select any idle
652+
states with exit latency beyond that limit.
654653

655654

656655
Idle States Control Via Kernel Command Line

Documentation/admin-guide/pm/intel_pstate.rst

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -734,10 +734,10 @@ References
734734
==========
735735

736736
.. [1] Kristen Accardi, *Balancing Power and Performance in the Linux Kernel*,
737-
http://events.linuxfoundation.org/sites/events/files/slides/LinuxConEurope_2015.pdf
737+
https://events.static.linuxfound.org/sites/events/files/slides/LinuxConEurope_2015.pdf
738738
739739
.. [2] *Intel® 64 and IA-32 Architectures Software Developer’s Manual Volume 3: System Programming Guide*,
740-
http://www.intel.com/content/www/us/en/architecture-and-technology/64-ia-32-architectures-software-developer-system-programming-manual-325384.html
740+
https://www.intel.com/content/www/us/en/architecture-and-technology/64-ia-32-architectures-software-developer-system-programming-manual-325384.html
741741
742742
.. [3] *Advanced Configuration and Power Interface Specification*,
743743
https://uefi.org/sites/default/files/resources/ACPI_6_3_final_Jan30.pdf

Documentation/admin-guide/pm/working-state.rst

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,4 +11,5 @@ Working-State Power Management
1111
intel_idle
1212
cpufreq
1313
intel_pstate
14+
cpufreq_drivers
1415
intel_epb

0 commit comments

Comments
 (0)