diff mbox series

[V2,5/7] thermal/drivers/cpu_cooling: Add idle cooling device documentation

Message ID 1519226968-19821-6-git-send-email-daniel.lezcano@linaro.org
State Superseded
Headers show
Series CPU cooling device new strategies | expand

Commit Message

Daniel Lezcano Feb. 21, 2018, 3:29 p.m. UTC
Provide some documentation for the idle injection cooling effect in
order to let people to understand the rational of the approach for the
idle injection CPU cooling device.

Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>

---
 Documentation/thermal/cpu-idle-cooling.txt | 165 +++++++++++++++++++++++++++++
 1 file changed, 165 insertions(+)
 create mode 100644 Documentation/thermal/cpu-idle-cooling.txt

-- 
2.7.4

Comments

Pavel Machek March 6, 2018, 11:19 p.m. UTC | #1
Hi!

> --- /dev/null

> +++ b/Documentation/thermal/cpu-idle-cooling.txt

> @@ -0,0 +1,165 @@

> +

> +Situation:

> +----------

> +


Can we have some real header here? Also if this is .rst, maybe it
should be marked so?

> +Under certain circumstances, the SoC reaches a temperature exceeding

> +the allocated power budget or the maximum temperature limit. The


I don't understand. Power budget is in W, temperature is in
kelvin. Temperature can't exceed power budget AFAICT.

> +former must be mitigated to stabilize the SoC temperature around the

> +temperature control using the defined cooling devices, the latter


later?

> +catastrophic situation where a radical decision must be taken to

> +reduce the temperature under the critical threshold, that can impact

> +the performances.


performance.

> +Another situation is when the silicon reaches a certain temperature

> +which continues to increase even if the dynamic leakage is reduced to

> +its minimum by clock gating the component. The runaway phenomena will

> +continue with the static leakage and only powering down the component,

> +thus dropping the dynamic and static leakage will allow the component

> +to cool down. This situation is critical.


Critical here, critical there. I have trouble following
it. Theoretically hardware should protect itself, because you don't
want kernel bug to damage your CPU?

> +Last but not least, the system can ask for a specific power budget but

> +because of the OPP density, we can only choose an OPP with a power

> +budget lower than the requested one and underuse the CPU, thus losing

> +performances. In other words, one OPP under uses the CPU with a


performance.

> +lesser than the power budget and the next OPP exceed the power budget,

> +an intermediate OPP could have been used if it were present.


was.

> +Solutions:

> +----------

> +

> +If we can remove the static and the dynamic leakage for a specific

> +duration in a controlled period, the SoC temperature will

> +decrease. Acting at the idle state duration or the idle cycle


"should" decrease? If you are in bad environment..

> +The Operating Performance Point (OPP) density has a great influence on

> +the control precision of cpufreq, however different vendors have a

> +plethora of OPP density, and some have large power gap between OPPs,

> +that will result in loss of performance during thermal control and

> +loss of power in other scenes.


scene seems to be wrong word here.

> +At a specific OPP, we can assume injecting idle cycle on all CPUs,


Extra comma?

> +Idle Injection:

> +---------------

> +

> +The base concept of the idle injection is to force the CPU to go to an

> +idle state for a specified time each control cycle, it provides

> +another way to control CPU power and heat in addition to

> +cpufreq. Ideally, if all CPUs of a cluster inject idle synchronously,

> +this cluster can get into the deepest idle state and achieve minimum

> +power consumption, but that will also increase system response latency

> +if we inject less than cpuidle latency.


I don't understand last sentence.

> +The mitigation begins with a maximum period value which decrease


decreases?
  
> +more cooling effect is requested. When the period duration is equal

> to

> +the idle duration, then we are in a situation the platform can’t

> +dissipate the heat enough and the mitigation fails. In this case


fast enough?

> +situation is considered critical and there is nothing to do. The idle


Nothing to do? Maybe power the system down?

> +The idle injection duration value must comply with the constraints:

> +

> +- It is lesser or equal to the latency we tolerate when the mitigation


less ... than the latency

> +Minimum period

> +--------------

> +

> +The idle injection duration being fixed, it is obvious the minimum

> +period can’t be lesser than that, otherwise we will be scheduling the


less.

> +Practically, if the running power is lesses than the targeted power,


less.

> +However, in this demonstration we ignore three aspects:

> +

> + * The static leakage is not defined here, we can introduce it in the

> +   equation but assuming it will be zero most of the time as it is


, but?

Best regards,
								Pavel
-- 
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
Daniel Lezcano March 7, 2018, 11:42 a.m. UTC | #2
On 07/03/2018 00:19, Pavel Machek wrote:
> Hi!


Hi Pavel,

thanks for taking the time to review the documentation.

>> --- /dev/null

>> +++ b/Documentation/thermal/cpu-idle-cooling.txt

>> @@ -0,0 +1,165 @@

>> +

>> +Situation:

>> +----------

>> +

> 

> Can we have some real header here? Also if this is .rst, maybe it

> should be marked so?


Ok, I will fix it.

>> +Under certain circumstances, the SoC reaches a temperature exceeding

>> +the allocated power budget or the maximum temperature limit. The

> 

> I don't understand. Power budget is in W, temperature is in

> kelvin. Temperature can't exceed power budget AFAICT.


Yes, it is badly worded. Is the following better ?

"
Under certain circumstances a SoC can reach the maximum temperature
limit or is unable to stabilize the temperature around a temperature
control.

When the SoC has to stabilize the temperature, the kernel can act on a
cooling device to mitigate the dissipated power.

When the maximum temperature is reached and to prevent a catastrophic
situation a radical decision must be taken to reduce the temperature
under the critical threshold, that impacts the performance.

"

>> +former must be mitigated to stabilize the SoC temperature around the

>> +temperature control using the defined cooling devices, the latter

> 

> later?

> 

>> +catastrophic situation where a radical decision must be taken to

>> +reduce the temperature under the critical threshold, that can impact

>> +the performances.

> 

> performance.

> 

>> +Another situation is when the silicon reaches a certain temperature

>> +which continues to increase even if the dynamic leakage is reduced to

>> +its minimum by clock gating the component. The runaway phenomena will

>> +continue with the static leakage and only powering down the component,

>> +thus dropping the dynamic and static leakage will allow the component

>> +to cool down. This situation is critical.

> 

> Critical here, critical there. I have trouble following

> it. Theoretically hardware should protect itself, because you don't

> want kernel bug to damage your CPU?


There are several levels of protection. The first level is mitigating
the temperature from the kernel, then in the temperature sensor a reset
line will trigger the reboot of the CPUs. Usually it is a register where
you write the maximum temperature, from the driver itself. I never tried
to write 1000°C in this register and see if I can burn the board.

I know some boards have another level of thermal protection in the
hardware itself and some other don't.

In any case, from a kernel point of view, it is a critical situation as
we are about to hard reboot the system and in this case it is preferable
to drop drastically the performance but give the opportunity to the
system to run in a degraded mode.

>> +Last but not least, the system can ask for a specific power budget but

>> +because of the OPP density, we can only choose an OPP with a power

>> +budget lower than the requested one and underuse the CPU, thus losing

>> +performances. In other words, one OPP under uses the CPU with a

> 

> performance.

> 

>> +lesser than the power budget and the next OPP exceed the power budget,

>> +an intermediate OPP could have been used if it were present.

> 

> was.

> 

>> +Solutions:

>> +----------

>> +

>> +If we can remove the static and the dynamic leakage for a specific

>> +duration in a controlled period, the SoC temperature will

>> +decrease. Acting at the idle state duration or the idle cycle

> 

> "should" decrease? If you are in bad environment..


No, it will decrease in any case because of the static leakage drop. The
bad environment will impact the speed of this decrease.

>> +The Operating Performance Point (OPP) density has a great influence on

>> +the control precision of cpufreq, however different vendors have a

>> +plethora of OPP density, and some have large power gap between OPPs,

>> +that will result in loss of performance during thermal control and

>> +loss of power in other scenes.

> 

> scene seems to be wrong word here.


yes, 'scenario' will be better :)

>> +At a specific OPP, we can assume injecting idle cycle on all CPUs,

> 

> Extra comma?

> 

>> +Idle Injection:

>> +---------------

>> +

>> +The base concept of the idle injection is to force the CPU to go to an

>> +idle state for a specified time each control cycle, it provides

>> +another way to control CPU power and heat in addition to

>> +cpufreq. Ideally, if all CPUs of a cluster inject idle synchronously,

>> +this cluster can get into the deepest idle state and achieve minimum

>> +power consumption, but that will also increase system response latency

>> +if we inject less than cpuidle latency.

> 

> I don't understand last sentence.


Is it better ?

"Ideally, if all CPUs, belonging to the same cluster, inject their idle
cycle synchronously, the cluster can reach its power down state with a
minimum power consumption and static leakage drop. However, these idle
cycles injection will add extra latencies as the CPUs will have to
wakeup from a deep sleep state."


>> +The mitigation begins with a maximum period value which decrease

> 

> decreases?

>   

>> +more cooling effect is requested. When the period duration is equal

>> to

>> +the idle duration, then we are in a situation the platform can’t

>> +dissipate the heat enough and the mitigation fails. In this case

> 

> fast enough?

> 

>> +situation is considered critical and there is nothing to do. The idle

> 

> Nothing to do? Maybe power the system down?


Nothing to do == the mitigation can't handle the situation, it reached
its limit. We can't do better.

Solution: add an emergency thermal shutdown (which is an orthogonal
feature to be added to the thermal framework).

Sidenote: it is a very unlikely case, as we are idle most of the time
when the heat is hard to dissipate. I tested this with a proto-SoC with
an interesting thermal behavior (temperature jumps insanely high),
running at full blast and bad heat dissipation, the mitigation never
reached the limit.

>> +The idle injection duration value must comply with the constraints:

>> +

>> +- It is lesser or equal to the latency we tolerate when the mitigation

> 

> less ... than the latency

> 

>> +Minimum period

>> +--------------

>> +

>> +The idle injection duration being fixed, it is obvious the minimum

>> +period can’t be lesser than that, otherwise we will be scheduling the

> 

> less.

> 

>> +Practically, if the running power is lesses than the targeted power,

> 

> less.

> 

>> +However, in this demonstration we ignore three aspects:

>> +

>> + * The static leakage is not defined here, we can introduce it in the

>> +   equation but assuming it will be zero most of the time as it is

> 

> , but?

> 

> Best regards,


Thanks!


-- 
 <http://www.linaro.org/> Linaro.org │ Open source software for ARM SoCs

Follow Linaro:  <http://www.facebook.com/pages/Linaro> Facebook |
<http://twitter.com/#!/linaroorg> Twitter |
<http://www.linaro.org/linaro-blog/> Blog
Daniel Thompson March 8, 2018, 11:54 a.m. UTC | #3
On Thu, Mar 08, 2018 at 09:59:49AM +0100, Pavel Machek wrote:
> Hi!

> 

> > >> +Under certain circumstances, the SoC reaches a temperature exceeding

> > >> +the allocated power budget or the maximum temperature limit. The

> > > 

> > > I don't understand. Power budget is in W, temperature is in

> > > kelvin. Temperature can't exceed power budget AFAICT.

> > 

> > Yes, it is badly worded. Is the following better ?

> > 

> > "

> > Under certain circumstances a SoC can reach the maximum temperature

> > limit or is unable to stabilize the temperature around a temperature

> > control.

> > 

> > When the SoC has to stabilize the temperature, the kernel can act on a

> > cooling device to mitigate the dissipated power.

> > 

> > When the maximum temperature is reached and to prevent a catastrophic

> > situation a radical decision must be taken to reduce the temperature

> > under the critical threshold, that impacts the performance.

> > 

> > "

> 

> Actually... if hardware is expected to protect itself, I'd tone it

> down. No need to be all catastrophic and critical... But yes, better.


Makes sense. For a thermally overcommitted but passively cooled device 
work close to max operating temperature it is not a critical situation 
requiring a radical reaction, it is normal operation.

Put another way, it would severely bogus to attach KERN_CRITICAL 
messages to reaching the cooling threshold.


Daniel.


> > > Critical here, critical there. I have trouble following

> > > it. Theoretically hardware should protect itself, because you don't

> > > want kernel bug to damage your CPU?

> > 

> > There are several levels of protection. The first level is mitigating

> > the temperature from the kernel, then in the temperature sensor a reset

> > line will trigger the reboot of the CPUs. Usually it is a register where

> > you write the maximum temperature, from the driver itself. I never tried

> > to write 1000°C in this register and see if I can burn the board.

> > 

> > I know some boards have another level of thermal protection in the

> > hardware itself and some other don't.

> > 

> > In any case, from a kernel point of view, it is a critical situation as

> > we are about to hard reboot the system and in this case it is preferable

> > to drop drastically the performance but give the opportunity to the

> > system to run in a degraded mode.

> 

> Agreed you want to keep going. In ACPI world, we shutdown when

> critical trip point is reached, so this is somehow confusing.

> 

> > >> +Solutions:

> > >> +----------

> > >> +

> > >> +If we can remove the static and the dynamic leakage for a specific

> > >> +duration in a controlled period, the SoC temperature will

> > >> +decrease. Acting at the idle state duration or the idle cycle

> > > 

> > > "should" decrease? If you are in bad environment..

> > 

> > No, it will decrease in any case because of the static leakage drop. The

> > bad environment will impact the speed of this decrease.

> 

> I meant... if ambient temperature is 105C, there's not much you can do

> to cool system down :-).

> 

> > >> +Idle Injection:

> > >> +---------------

> > >> +

> > >> +The base concept of the idle injection is to force the CPU to go to an

> > >> +idle state for a specified time each control cycle, it provides

> > >> +another way to control CPU power and heat in addition to

> > >> +cpufreq. Ideally, if all CPUs of a cluster inject idle synchronously,

> > >> +this cluster can get into the deepest idle state and achieve minimum

> > >> +power consumption, but that will also increase system response latency

> > >> +if we inject less than cpuidle latency.

> > > 

> > > I don't understand last sentence.

> > 

> > Is it better ?

> > 

> > "Ideally, if all CPUs, belonging to the same cluster, inject their idle

> > cycle synchronously, the cluster can reach its power down state with a

> > minimum power consumption and static leakage drop. However, these idle

> > cycles injection will add extra latencies as the CPUs will have to

> > wakeup from a deep sleep state."

> 

> Extra comma "CPUs , belonging". But yes, better.

> 

> > Thanks!

> 

> You are welcome. Best regards,

> 									Pavel

> -- 

> (english) http://www.livejournal.com/~pavelmachek

> (cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
diff mbox series

Patch

diff --git a/Documentation/thermal/cpu-idle-cooling.txt b/Documentation/thermal/cpu-idle-cooling.txt
new file mode 100644
index 0000000..29fc651
--- /dev/null
+++ b/Documentation/thermal/cpu-idle-cooling.txt
@@ -0,0 +1,165 @@ 
+
+Situation:
+----------
+
+Under certain circumstances, the SoC reaches a temperature exceeding
+the allocated power budget or the maximum temperature limit. The
+former must be mitigated to stabilize the SoC temperature around the
+temperature control using the defined cooling devices, the latter is a
+catastrophic situation where a radical decision must be taken to
+reduce the temperature under the critical threshold, that can impact
+the performances.
+
+Another situation is when the silicon reaches a certain temperature
+which continues to increase even if the dynamic leakage is reduced to
+its minimum by clock gating the component. The runaway phenomena will
+continue with the static leakage and only powering down the component,
+thus dropping the dynamic and static leakage will allow the component
+to cool down. This situation is critical.
+
+Last but not least, the system can ask for a specific power budget but
+because of the OPP density, we can only choose an OPP with a power
+budget lower than the requested one and underuse the CPU, thus losing
+performances. In other words, one OPP under uses the CPU with a power
+lesser than the power budget and the next OPP exceed the power budget,
+an intermediate OPP could have been used if it were present.
+
+Solutions:
+----------
+
+If we can remove the static and the dynamic leakage for a specific
+duration in a controlled period, the SoC temperature will
+decrease. Acting at the idle state duration or the idle cycle
+injection period, we can mitigate the temperature by modulating the
+power budget.
+
+The Operating Performance Point (OPP) density has a great influence on
+the control precision of cpufreq, however different vendors have a
+plethora of OPP density, and some have large power gap between OPPs,
+that will result in loss of performance during thermal control and
+loss of power in other scenes.
+
+At a specific OPP, we can assume injecting idle cycle on all CPUs,
+belonging to the same cluster, with a duration greater than the
+cluster idle state target residency, we drop the static and the
+dynamic leakage for this period (modulo the energy needed to enter
+this state). So the sustainable power with idle cycles has a linear
+relation with the OPP’s sustainable power and can be computed with a
+coefficient similar to:
+
+	    Power(IdleCycle) = Coef x Power(OPP)
+
+Idle Injection:
+---------------
+
+The base concept of the idle injection is to force the CPU to go to an
+idle state for a specified time each control cycle, it provides
+another way to control CPU power and heat in addition to
+cpufreq. Ideally, if all CPUs of a cluster inject idle synchronously,
+this cluster can get into the deepest idle state and achieve minimum
+power consumption, but that will also increase system response latency
+if we inject less than cpuidle latency.
+
+     ^
+     |
+     |
+     |-------       -------       -------
+     |_______|_____|_______|_____|_______|___________
+
+      <----->
+       idle  <---->
+              running
+
+With the fixed idle injection duration, we can give a value which is
+an acceptable performance drop off or latency when we reach a specific
+temperature and we begin to mitigate by varying the Idle injection
+period.
+
+The mitigation begins with a maximum period value which decrease when
+more cooling effect is requested. When the period duration is equal to
+the idle duration, then we are in a situation the platform can’t
+dissipate the heat enough and the mitigation fails. In this case the
+situation is considered critical and there is nothing to do. The idle
+injection duration must be changed by configuration and until we reach
+the cooling effect, otherwise an additionnal cooling device must be
+used or ultimately decrease the SoC performance by dropping the
+highest OPP point of the SoC.
+
+The idle injection duration value must comply with the constraints:
+
+- It is lesser or equal to the latency we tolerate when the mitigation
+  begins. It is platform dependent and will depend on the user
+  experience, reactivity vs performance trade off we want. This value
+  should be specified.
+
+- It is greater than the idle state’s target residency we want to go
+  for thermal mitigation, otherwise we end up consuming more energy.
+
+Minimum period
+--------------
+
+The idle injection duration being fixed, it is obvious the minimum
+period can’t be lesser than that, otherwise we will be scheduling the
+idle injection task right before the idle injection duration is
+complete, so waking up the CPU to put it asleep again.
+
+Maximum period
+--------------
+
+The maximum period is the initial period when the mitigation
+begins. Theoretically when we reach the thermal trip point, we have to
+sustain a specified power for specific temperature but at this time we
+consume:
+
+ Power = Capacitance x Voltage^2 x Frequency x Utilisation
+
+... which is more than the sustainable power (or there is something
+wrong on the system setup). The ‘Capacitance’ and ‘Utilisation’ are a
+fixed value, ‘Voltage’ and the ‘Frequency’ are fixed artificially
+because we don’t want to change the OPP. We can group the
+‘Capacitance’ and the ‘Utilisation’ into a single term which is the
+‘Dynamic Power Coefficient (Cdyn)’ Simplifying the above, we have:
+
+ Pdyn = Cdyn x Voltage^2 x Frequency
+
+The IPA will ask us somehow to reduce our power in order to target the
+sustainable power defined in the device tree. So with the idle
+injection mechanism, we want an average power (Ptarget) resulting on
+an amount of time running at full power on a specific OPP and idle
+another amount of time. That could be put in a equation:
+
+ P(opp)target = ((trunning x (P(opp)running) + (tidle P(opp)idle)) /
+			(trunning + tidle)
+  ...
+
+ tidle = trunning x ((P(opp)running / P(opp)target) - 1)
+
+At this point if we know the running period for the CPU, that gives us
+the idle injection, we need. Alternatively if we have the idle
+injection duration, we can compute the running duration with:
+
+ trunning = tidle / ((P(opp)running / P(opp)target) - 1)
+
+Practically, if the running power is lesses than the targeted power,
+we end up with a negative time value, so obviously the equation usage
+is bound to a power reduction, hence a higher OPP is needed to have
+the running power greater than the targeted power.
+
+However, in this demonstration we ignore three aspects:
+
+ * The static leakage is not defined here, we can introduce it in the
+   equation but assuming it will be zero most of the time as it is
+   difficult to get the values from the SoC vendors
+
+ * The idle state wake up latency (or entry + exit latency) is not
+   taken into account, it must be added in the equation in order to
+   rigorously compute the idle injection
+
+ * The injected idle duration must be greater than the idle state
+   target residency, otherwise we end up consuming more energy and
+   potentially invert the mitigation effect
+
+So the final equation is:
+
+ trunning = (tidle - twakeup ) x
+		(((P(opp)dyn + P(opp)static ) - P(opp)target) / P(opp)target )