5484e31bbb
Because the cost of calling tick_nohz_get_sleep_length() may increase in the future, reorder the code in menu_select() so it first uses the statistics to determine the expected idle duration. If that value is higher than RESIDENCY_THRESHOLD_NS, tick_nohz_get_sleep_length() will be called to obtain the time till the closest timer and refine the idle duration prediction if necessary. This causes the governor to always take the full overhead of get_typical_interval() with the assumption that the cost will be amortized by skipping the tick_nohz_get_sleep_length() call in the cases when the predicted idle duration is relatively very small. Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Tested-by: Doug Smythies <dsmythies@telus.net>
15 lines
376 B
C
15 lines
376 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
/* Common definitions for cpuidle governors. */
|
|
|
|
#ifndef __CPUIDLE_GOVERNOR_H
|
|
#define __CPUIDLE_GOVERNOR_H
|
|
|
|
/*
|
|
* Idle state target residency threshold used for deciding whether or not to
|
|
* check the time till the closest expected timer event.
|
|
*/
|
|
#define RESIDENCY_THRESHOLD_NS (15 * NSEC_PER_USEC)
|
|
|
|
#endif /* __CPUIDLE_GOVERNOR_H */
|