1
0
Fork 0
mirror of https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git synced 2025-01-22 07:53:11 -05:00

cpuidle: teo: Update documentation after previous changes

After previous changes, the description of the teo governor in the
documentation comment does not match the code any more, so update it
as appropriate.

Fixes: 4499143980 ("cpuidle: teo: Remove recent intercepts metric")
Fixes: 2662342079 ("cpuidle: teo: Gather statistics regarding whether or not to stop the tick")
Fixes: 6da8f9ba5a ("cpuidle: teo: Skip tick_nohz_get_sleep_length() call in some cases")
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Reviewed-by: Christian Loehle <christian.loehle@arm.com>
Link: https://patch.msgid.link/6120335.lOV4Wx5bFT@rjwysocki.net
[ rjw: Corrected 3 typos found by Christian ]
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
Rafael J. Wysocki 2025-01-10 13:48:10 +01:00
parent 56098a4505
commit 5a597a19a2

View file

@ -10,25 +10,27 @@
* DOC: teo-description * DOC: teo-description
* *
* The idea of this governor is based on the observation that on many systems * The idea of this governor is based on the observation that on many systems
* timer events are two or more orders of magnitude more frequent than any * timer interrupts are two or more orders of magnitude more frequent than any
* other interrupts, so they are likely to be the most significant cause of CPU * other interrupt types, so they are likely to dominate CPU wakeup patterns.
* wakeups from idle states. Moreover, information about what happened in the * Moreover, in principle, the time when the next timer event is going to occur
* (relatively recent) past can be used to estimate whether or not the deepest * can be determined at the idle state selection time, although doing that may
* idle state with target residency within the (known) time till the closest * be costly, so it can be regarded as the most reliable source of information
* timer event, referred to as the sleep length, is likely to be suitable for * for idle state selection.
* the upcoming CPU idle period and, if not, then which of the shallower idle
* states to choose instead of it.
* *
* Of course, non-timer wakeup sources are more important in some use cases * Of course, non-timer wakeup sources are more important in some use cases,
* which can be covered by taking a few most recent idle time intervals of the * but even then it is generally unnecessary to consider idle duration values
* CPU into account. However, even in that context it is not necessary to * greater than the time time till the next timer event, referred as the sleep
* consider idle duration values greater than the sleep length, because the * length in what follows, because the closest timer will ultimately wake up the
* closest timer will ultimately wake up the CPU anyway unless it is woken up * CPU anyway unless it is woken up earlier.
* earlier.
* *
* Thus this governor estimates whether or not the prospective idle duration of * However, since obtaining the sleep length may be costly, the governor first
* a CPU is likely to be significantly shorter than the sleep length and selects * checks if it can select a shallow idle state using wakeup pattern information
* an idle state for it accordingly. * from recent times, in which case it can do without knowing the sleep length
* at all. For this purpose, it counts CPU wakeup events and looks for an idle
* state whose target residency has not exceeded the idle duration (measured
* after wakeup) in the majority of relevant recent cases. If the target
* residency of that state is small enough, it may be used right away and the
* sleep length need not be determined.
* *
* The computations carried out by this governor are based on using bins whose * The computations carried out by this governor are based on using bins whose
* boundaries are aligned with the target residency parameter values of the CPU * boundaries are aligned with the target residency parameter values of the CPU
@ -39,7 +41,11 @@
* idle state 2, the third bin spans from the target residency of idle state 2 * idle state 2, the third bin spans from the target residency of idle state 2
* up to, but not including, the target residency of idle state 3 and so on. * up to, but not including, the target residency of idle state 3 and so on.
* The last bin spans from the target residency of the deepest idle state * The last bin spans from the target residency of the deepest idle state
* supplied by the driver to infinity. * supplied by the driver to the scheduler tick period length or to infinity if
* the tick period length is less than the target residency of that state. In
* the latter case, the governor also counts events with the measured idle
* duration between the tick period length and the target residency of the
* deepest idle state.
* *
* Two metrics called "hits" and "intercepts" are associated with each bin. * Two metrics called "hits" and "intercepts" are associated with each bin.
* They are updated every time before selecting an idle state for the given CPU * They are updated every time before selecting an idle state for the given CPU
@ -49,47 +55,46 @@
* sleep length and the idle duration measured after CPU wakeup fall into the * sleep length and the idle duration measured after CPU wakeup fall into the
* same bin (that is, the CPU appears to wake up "on time" relative to the sleep * same bin (that is, the CPU appears to wake up "on time" relative to the sleep
* length). In turn, the "intercepts" metric reflects the relative frequency of * length). In turn, the "intercepts" metric reflects the relative frequency of
* situations in which the measured idle duration is so much shorter than the * non-timer wakeup events for which the measured idle duration falls into a bin
* sleep length that the bin it falls into corresponds to an idle state * that corresponds to an idle state shallower than the one whose bin is fallen
* shallower than the one whose bin is fallen into by the sleep length (these * into by the sleep length (these events are also referred to as "intercepts"
* situations are referred to as "intercepts" below). * below).
* *
* In order to select an idle state for a CPU, the governor takes the following * In order to select an idle state for a CPU, the governor takes the following
* steps (modulo the possible latency constraint that must be taken into account * steps (modulo the possible latency constraint that must be taken into account
* too): * too):
* *
* 1. Find the deepest CPU idle state whose target residency does not exceed * 1. Find the deepest enabled CPU idle state (the candidate idle state) and
* the current sleep length (the candidate idle state) and compute 2 sums as * compute 2 sums as follows:
* follows:
* *
* - The sum of the "hits" and "intercepts" metrics for the candidate state * - The sum of the "hits" metric for all of the idle states shallower than
* and all of the deeper idle states (it represents the cases in which the * the candidate one (it represents the cases in which the CPU was likely
* CPU was idle long enough to avoid being intercepted if the sleep length * woken up by a timer).
* had been equal to the current one).
* *
* - The sum of the "intercepts" metrics for all of the idle states shallower * - The sum of the "intercepts" metric for all of the idle states shallower
* than the candidate one (it represents the cases in which the CPU was not * than the candidate one (it represents the cases in which the CPU was
* idle long enough to avoid being intercepted if the sleep length had been * likely woken up by a non-timer wakeup source).
* equal to the current one).
* *
* 2. If the second sum is greater than the first one the CPU is likely to wake * 2. If the second sum computed in step 1 is greater than a half of the sum of
* up early, so look for an alternative idle state to select. * both metrics for the candidate state bin and all subsequent bins(if any),
* a shallower idle state is likely to be more suitable, so look for it.
* *
* - Traverse the idle states shallower than the candidate one in the * - Traverse the enabled idle states shallower than the candidate one in the
* descending order. * descending order.
* *
* - For each of them compute the sum of the "intercepts" metrics over all * - For each of them compute the sum of the "intercepts" metrics over all
* of the idle states between it and the candidate one (including the * of the idle states between it and the candidate one (including the
* former and excluding the latter). * former and excluding the latter).
* *
* - If each of these sums that needs to be taken into account (because the * - If this sum is greater than a half of the second sum computed in step 1,
* check related to it has indicated that the CPU is likely to wake up * use the given idle state as the new candidate one.
* early) is greater than a half of the corresponding sum computed in step
* 1 (which means that the target residency of the state in question had
* not exceeded the idle duration in over a half of the relevant cases),
* select the given idle state instead of the candidate one.
* *
* 3. By default, select the candidate state. * 3. If the current candidate state is state 0 or its target residency is short
* enough, return it and prevent the scheduler tick from being stopped.
*
* 4. Obtain the sleep length value and check if it is below the target
* residency of the current candidate state, in which case a new shallower
* candidate state needs to be found, so look for it.
*/ */
#include <linux/cpuidle.h> #include <linux/cpuidle.h>