xref: /openbmc/linux/drivers/cpuidle/governors/teo.c (revision f7af616c632ee2ac3af0876fe33bf9e0232e665a)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Timer events oriented CPU idle governor
4  *
5  * Copyright (C) 2018 Intel Corporation
6  * Author: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
7  *
8  * The idea of this governor is based on the observation that on many systems
9  * timer events are two or more orders of magnitude more frequent than any
10  * other interrupts, so they are likely to be the most significant source of CPU
11  * wakeups from idle states.  Moreover, information about what happened in the
12  * (relatively recent) past can be used to estimate whether or not the deepest
13  * idle state with target residency within the time to the closest timer is
14  * likely to be suitable for the upcoming idle time of the CPU and, if not, then
15  * which of the shallower idle states to choose.
16  *
17  * Of course, non-timer wakeup sources are more important in some use cases and
18  * they can be covered by taking a few most recent idle time intervals of the
19  * CPU into account.  However, even in that case it is not necessary to consider
20  * idle duration values greater than the time till the closest timer, as the
21  * patterns that they may belong to produce average values close enough to
22  * the time till the closest timer (sleep length) anyway.
23  *
24  * Thus this governor estimates whether or not the upcoming idle time of the CPU
25  * is likely to be significantly shorter than the sleep length and selects an
26  * idle state for it in accordance with that, as follows:
27  *
28  * - Find an idle state on the basis of the sleep length and state statistics
29  *   collected over time:
30  *
31  *   o Find the deepest idle state whose target residency is less than or equal
32  *     to the sleep length.
33  *
34  *   o Select it if it matched both the sleep length and the observed idle
35  *     duration in the past more often than it matched the sleep length alone
36  *     (i.e. the observed idle duration was significantly shorter than the sleep
37  *     length matched by it).
38  *
39  *   o Otherwise, select the shallower state with the greatest matched "early"
40  *     wakeups metric.
41  *
42  * - If the majority of the most recent idle duration values are below the
43  *   target residency of the idle state selected so far, use those values to
44  *   compute the new expected idle duration and find an idle state matching it
45  *   (which has to be shallower than the one selected so far).
46  */
47 
48 #include <linux/cpuidle.h>
49 #include <linux/jiffies.h>
50 #include <linux/kernel.h>
51 #include <linux/sched/clock.h>
52 #include <linux/tick.h>
53 
54 /*
55  * The PULSE value is added to metrics when they grow and the DECAY_SHIFT value
56  * is used for decreasing metrics on a regular basis.
57  */
58 #define PULSE		1024
59 #define DECAY_SHIFT	3
60 
61 /*
62  * Number of the most recent idle duration values to take into consideration for
63  * the detection of wakeup patterns.
64  */
65 #define INTERVALS	8
66 
67 /**
68  * struct teo_idle_state - Idle state data used by the TEO cpuidle governor.
69  * @early_hits: "Early" CPU wakeups "matching" this state.
70  * @hits: "On time" CPU wakeups "matching" this state.
71  * @misses: CPU wakeups "missing" this state.
72  *
73  * A CPU wakeup is "matched" by a given idle state if the idle duration measured
74  * after the wakeup is between the target residency of that state and the target
75  * residency of the next one (or if this is the deepest available idle state, it
76  * "matches" a CPU wakeup when the measured idle duration is at least equal to
77  * its target residency).
78  *
79  * Also, from the TEO governor perspective, a CPU wakeup from idle is "early" if
80  * it occurs significantly earlier than the closest expected timer event (that
81  * is, early enough to match an idle state shallower than the one matching the
82  * time till the closest timer event).  Otherwise, the wakeup is "on time", or
83  * it is a "hit".
84  *
85  * A "miss" occurs when the given state doesn't match the wakeup, but it matches
86  * the time till the closest timer event used for idle state selection.
87  */
88 struct teo_idle_state {
89 	unsigned int early_hits;
90 	unsigned int hits;
91 	unsigned int misses;
92 };
93 
94 /**
95  * struct teo_cpu - CPU data used by the TEO cpuidle governor.
96  * @time_span_ns: Time between idle state selection and post-wakeup update.
97  * @sleep_length_ns: Time till the closest timer event (at the selection time).
98  * @states: Idle states data corresponding to this CPU.
99  * @interval_idx: Index of the most recent saved idle interval.
100  * @intervals: Saved idle duration values.
101  */
102 struct teo_cpu {
103 	s64 time_span_ns;
104 	s64 sleep_length_ns;
105 	struct teo_idle_state states[CPUIDLE_STATE_MAX];
106 	int interval_idx;
107 	u64 intervals[INTERVALS];
108 };
109 
110 static DEFINE_PER_CPU(struct teo_cpu, teo_cpus);
111 
112 /**
113  * teo_update - Update CPU data after wakeup.
114  * @drv: cpuidle driver containing state data.
115  * @dev: Target CPU.
116  */
117 static void teo_update(struct cpuidle_driver *drv, struct cpuidle_device *dev)
118 {
119 	struct teo_cpu *cpu_data = per_cpu_ptr(&teo_cpus, dev->cpu);
120 	int i, idx_hit = 0, idx_timer = 0;
121 	unsigned int hits, misses;
122 	u64 measured_ns;
123 
124 	if (cpu_data->time_span_ns >= cpu_data->sleep_length_ns) {
125 		/*
126 		 * One of the safety nets has triggered or the wakeup was close
127 		 * enough to the closest timer event expected at the idle state
128 		 * selection time to be discarded.
129 		 */
130 		measured_ns = U64_MAX;
131 	} else {
132 		u64 lat_ns = drv->states[dev->last_state_idx].exit_latency_ns;
133 
134 		/*
135 		 * The computations below are to determine whether or not the
136 		 * (saved) time till the next timer event and the measured idle
137 		 * duration fall into the same "bin", so use last_residency_ns
138 		 * for that instead of time_span_ns which includes the cpuidle
139 		 * overhead.
140 		 */
141 		measured_ns = dev->last_residency_ns;
142 		/*
143 		 * The delay between the wakeup and the first instruction
144 		 * executed by the CPU is not likely to be worst-case every
145 		 * time, so take 1/2 of the exit latency as a very rough
146 		 * approximation of the average of it.
147 		 */
148 		if (measured_ns >= lat_ns)
149 			measured_ns -= lat_ns / 2;
150 		else
151 			measured_ns /= 2;
152 	}
153 
154 	/*
155 	 * Decay the "early hits" metric for all of the states and find the
156 	 * states matching the sleep length and the measured idle duration.
157 	 */
158 	for (i = 0; i < drv->state_count; i++) {
159 		unsigned int early_hits = cpu_data->states[i].early_hits;
160 
161 		cpu_data->states[i].early_hits -= early_hits >> DECAY_SHIFT;
162 
163 		if (drv->states[i].target_residency_ns <= cpu_data->sleep_length_ns) {
164 			idx_timer = i;
165 			if (drv->states[i].target_residency_ns <= measured_ns)
166 				idx_hit = i;
167 		}
168 	}
169 
170 	/*
171 	 * Update the "hits" and "misses" data for the state matching the sleep
172 	 * length.  If it matches the measured idle duration too, this is a hit,
173 	 * so increase the "hits" metric for it then.  Otherwise, this is a
174 	 * miss, so increase the "misses" metric for it.  In the latter case
175 	 * also increase the "early hits" metric for the state that actually
176 	 * matches the measured idle duration.
177 	 */
178 	hits = cpu_data->states[idx_timer].hits;
179 	hits -= hits >> DECAY_SHIFT;
180 
181 	misses = cpu_data->states[idx_timer].misses;
182 	misses -= misses >> DECAY_SHIFT;
183 
184 	if (idx_timer == idx_hit) {
185 		hits += PULSE;
186 	} else {
187 		misses += PULSE;
188 		cpu_data->states[idx_hit].early_hits += PULSE;
189 	}
190 
191 	cpu_data->states[idx_timer].misses = misses;
192 	cpu_data->states[idx_timer].hits = hits;
193 
194 	/*
195 	 * Save idle duration values corresponding to non-timer wakeups for
196 	 * pattern detection.
197 	 */
198 	cpu_data->intervals[cpu_data->interval_idx++] = measured_ns;
199 	if (cpu_data->interval_idx >= INTERVALS)
200 		cpu_data->interval_idx = 0;
201 }
202 
203 static bool teo_time_ok(u64 interval_ns)
204 {
205 	return !tick_nohz_tick_stopped() || interval_ns >= TICK_NSEC;
206 }
207 
208 /**
209  * teo_find_shallower_state - Find shallower idle state matching given duration.
210  * @drv: cpuidle driver containing state data.
211  * @dev: Target CPU.
212  * @state_idx: Index of the capping idle state.
213  * @duration_ns: Idle duration value to match.
214  */
215 static int teo_find_shallower_state(struct cpuidle_driver *drv,
216 				    struct cpuidle_device *dev, int state_idx,
217 				    s64 duration_ns)
218 {
219 	int i;
220 
221 	for (i = state_idx - 1; i >= 0; i--) {
222 		if (dev->states_usage[i].disable)
223 			continue;
224 
225 		state_idx = i;
226 		if (drv->states[i].target_residency_ns <= duration_ns)
227 			break;
228 	}
229 	return state_idx;
230 }
231 
232 /**
233  * teo_select - Selects the next idle state to enter.
234  * @drv: cpuidle driver containing state data.
235  * @dev: Target CPU.
236  * @stop_tick: Indication on whether or not to stop the scheduler tick.
237  */
238 static int teo_select(struct cpuidle_driver *drv, struct cpuidle_device *dev,
239 		      bool *stop_tick)
240 {
241 	struct teo_cpu *cpu_data = per_cpu_ptr(&teo_cpus, dev->cpu);
242 	s64 latency_req = cpuidle_governor_latency_req(dev->cpu);
243 	int max_early_idx, prev_max_early_idx, constraint_idx, idx0, idx, i;
244 	unsigned int hits, misses, early_hits;
245 	ktime_t delta_tick;
246 	s64 duration_ns;
247 
248 	if (dev->last_state_idx >= 0) {
249 		teo_update(drv, dev);
250 		dev->last_state_idx = -1;
251 	}
252 
253 	cpu_data->time_span_ns = local_clock();
254 
255 	duration_ns = tick_nohz_get_sleep_length(&delta_tick);
256 	cpu_data->sleep_length_ns = duration_ns;
257 
258 	hits = 0;
259 	misses = 0;
260 	early_hits = 0;
261 	max_early_idx = -1;
262 	prev_max_early_idx = -1;
263 	constraint_idx = drv->state_count;
264 	idx = -1;
265 	idx0 = idx;
266 
267 	for (i = 0; i < drv->state_count; i++) {
268 		struct cpuidle_state *s = &drv->states[i];
269 
270 		if (dev->states_usage[i].disable) {
271 			/*
272 			 * Ignore disabled states with target residencies beyond
273 			 * the anticipated idle duration.
274 			 */
275 			if (s->target_residency_ns > duration_ns)
276 				continue;
277 
278 			/*
279 			 * This state is disabled, so the range of idle duration
280 			 * values corresponding to it is covered by the current
281 			 * candidate state, but still the "hits" and "misses"
282 			 * metrics of the disabled state need to be used to
283 			 * decide whether or not the state covering the range in
284 			 * question is good enough.
285 			 */
286 			hits = cpu_data->states[i].hits;
287 			misses = cpu_data->states[i].misses;
288 
289 			if (early_hits >= cpu_data->states[i].early_hits ||
290 			    idx < 0)
291 				continue;
292 
293 			/*
294 			 * If the current candidate state has been the one with
295 			 * the maximum "early hits" metric so far, the "early
296 			 * hits" metric of the disabled state replaces the
297 			 * current "early hits" count to avoid selecting a
298 			 * deeper state with lower "early hits" metric.
299 			 */
300 			if (max_early_idx == idx) {
301 				early_hits = cpu_data->states[i].early_hits;
302 				continue;
303 			}
304 
305 			/*
306 			 * The current candidate state is closer to the disabled
307 			 * one than the current maximum "early hits" state, so
308 			 * replace the latter with it, but in case the maximum
309 			 * "early hits" state index has not been set so far,
310 			 * check if the current candidate state is not too
311 			 * shallow for that role.
312 			 */
313 			if (teo_time_ok(drv->states[idx].target_residency_ns)) {
314 				prev_max_early_idx = max_early_idx;
315 				early_hits = cpu_data->states[i].early_hits;
316 				max_early_idx = idx;
317 			}
318 
319 			continue;
320 		}
321 
322 		if (idx < 0) {
323 			idx = i; /* first enabled state */
324 			hits = cpu_data->states[i].hits;
325 			misses = cpu_data->states[i].misses;
326 			idx0 = i;
327 		}
328 
329 		if (s->target_residency_ns > duration_ns)
330 			break;
331 
332 		if (s->exit_latency_ns > latency_req && constraint_idx > i)
333 			constraint_idx = i;
334 
335 		idx = i;
336 		hits = cpu_data->states[i].hits;
337 		misses = cpu_data->states[i].misses;
338 
339 		if (early_hits < cpu_data->states[i].early_hits &&
340 		    teo_time_ok(drv->states[i].target_residency_ns)) {
341 			prev_max_early_idx = max_early_idx;
342 			early_hits = cpu_data->states[i].early_hits;
343 			max_early_idx = i;
344 		}
345 	}
346 
347 	/*
348 	 * If the "hits" metric of the idle state matching the sleep length is
349 	 * greater than its "misses" metric, that is the one to use.  Otherwise,
350 	 * it is more likely that one of the shallower states will match the
351 	 * idle duration observed after wakeup, so take the one with the maximum
352 	 * "early hits" metric, but if that cannot be determined, just use the
353 	 * state selected so far.
354 	 */
355 	if (hits <= misses) {
356 		/*
357 		 * The current candidate state is not suitable, so take the one
358 		 * whose "early hits" metric is the maximum for the range of
359 		 * shallower states.
360 		 */
361 		if (idx == max_early_idx)
362 			max_early_idx = prev_max_early_idx;
363 
364 		if (max_early_idx >= 0) {
365 			idx = max_early_idx;
366 			duration_ns = drv->states[idx].target_residency_ns;
367 		}
368 	}
369 
370 	/*
371 	 * If there is a latency constraint, it may be necessary to use a
372 	 * shallower idle state than the one selected so far.
373 	 */
374 	if (constraint_idx < idx)
375 		idx = constraint_idx;
376 
377 	if (idx < 0) {
378 		idx = 0; /* No states enabled. Must use 0. */
379 	} else if (idx > idx0) {
380 		unsigned int count = 0;
381 		u64 sum = 0;
382 
383 		/*
384 		 * The target residencies of at least two different enabled idle
385 		 * states are less than or equal to the current expected idle
386 		 * duration.  Try to refine the selection using the most recent
387 		 * measured idle duration values.
388 		 *
389 		 * Count and sum the most recent idle duration values less than
390 		 * the current expected idle duration value.
391 		 */
392 		for (i = 0; i < INTERVALS; i++) {
393 			u64 val = cpu_data->intervals[i];
394 
395 			if (val >= duration_ns)
396 				continue;
397 
398 			count++;
399 			sum += val;
400 		}
401 
402 		/*
403 		 * Give up unless the majority of the most recent idle duration
404 		 * values are in the interesting range.
405 		 */
406 		if (count > INTERVALS / 2) {
407 			u64 avg_ns = div64_u64(sum, count);
408 
409 			/*
410 			 * Avoid spending too much time in an idle state that
411 			 * would be too shallow.
412 			 */
413 			if (teo_time_ok(avg_ns)) {
414 				duration_ns = avg_ns;
415 				if (drv->states[idx].target_residency_ns > avg_ns)
416 					idx = teo_find_shallower_state(drv, dev,
417 								       idx, avg_ns);
418 			}
419 		}
420 	}
421 
422 	/*
423 	 * Don't stop the tick if the selected state is a polling one or if the
424 	 * expected idle duration is shorter than the tick period length.
425 	 */
426 	if (((drv->states[idx].flags & CPUIDLE_FLAG_POLLING) ||
427 	    duration_ns < TICK_NSEC) && !tick_nohz_tick_stopped()) {
428 		*stop_tick = false;
429 
430 		/*
431 		 * The tick is not going to be stopped, so if the target
432 		 * residency of the state to be returned is not within the time
433 		 * till the closest timer including the tick, try to correct
434 		 * that.
435 		 */
436 		if (idx > idx0 &&
437 		    drv->states[idx].target_residency_ns > delta_tick)
438 			idx = teo_find_shallower_state(drv, dev, idx, delta_tick);
439 	}
440 
441 	return idx;
442 }
443 
444 /**
445  * teo_reflect - Note that governor data for the CPU need to be updated.
446  * @dev: Target CPU.
447  * @state: Entered state.
448  */
449 static void teo_reflect(struct cpuidle_device *dev, int state)
450 {
451 	struct teo_cpu *cpu_data = per_cpu_ptr(&teo_cpus, dev->cpu);
452 
453 	dev->last_state_idx = state;
454 	/*
455 	 * If the wakeup was not "natural", but triggered by one of the safety
456 	 * nets, assume that the CPU might have been idle for the entire sleep
457 	 * length time.
458 	 */
459 	if (dev->poll_time_limit ||
460 	    (tick_nohz_idle_got_tick() && cpu_data->sleep_length_ns > TICK_NSEC)) {
461 		dev->poll_time_limit = false;
462 		cpu_data->time_span_ns = cpu_data->sleep_length_ns;
463 	} else {
464 		cpu_data->time_span_ns = local_clock() - cpu_data->time_span_ns;
465 	}
466 }
467 
468 /**
469  * teo_enable_device - Initialize the governor's data for the target CPU.
470  * @drv: cpuidle driver (not used).
471  * @dev: Target CPU.
472  */
473 static int teo_enable_device(struct cpuidle_driver *drv,
474 			     struct cpuidle_device *dev)
475 {
476 	struct teo_cpu *cpu_data = per_cpu_ptr(&teo_cpus, dev->cpu);
477 	int i;
478 
479 	memset(cpu_data, 0, sizeof(*cpu_data));
480 
481 	for (i = 0; i < INTERVALS; i++)
482 		cpu_data->intervals[i] = U64_MAX;
483 
484 	return 0;
485 }
486 
487 static struct cpuidle_governor teo_governor = {
488 	.name =		"teo",
489 	.rating =	19,
490 	.enable =	teo_enable_device,
491 	.select =	teo_select,
492 	.reflect =	teo_reflect,
493 };
494 
495 static int __init teo_governor_init(void)
496 {
497 	return cpuidle_register_governor(&teo_governor);
498 }
499 
500 postcore_initcall(teo_governor_init);
501