

# Rock and a Hard Place

## How Hard It Is To Be a CPU Idle Time Governor

Rafael J. Wysocki

Intel Linux Systems Engineering

May 20, 2019



# Terminology: CPUs = Logical CPUs



# CPUs: Busy Vs Idle



# Idleness Is an Opportunity to Save Energy



Intel  
**OpenSource**  
TECHNOLOGY CENTER

# The Idle Loop in Linux\* (4.17 and Later)



# Idle Governor and Idle Driver Need To Communicate



**Intel**  
**OpenSource**  
TECHNOLOGY CENTER

# CPU Idle State Parameters



# Worst-case Numbers Are Difficult To Come By

## Worst case measurement Catch 22

In order to measure the worst case you must experience it, but you cannot know whether or not you have experienced it unless you know beforehand what it is.



# Governor Perspective



 **OpenSource**  
TECHNOLOGY CENTER

# The Rock and The Hard Place

## The Rock

Selecting idle states that are too shallow hurts energy-efficiency.

## The Hard Place

Selecting idle states that are too deep hurts energy-efficiency and performance (through excessive latency).



# Two Categories of Wakeup Events



Intel  
**OpenSource**  
TECHNOLOGY CENTER

# Measurement Issues



**Intel**  
**OpenSource**  
TECHNOLOGY CENTER

# Idle Duration Is Difficult To Measure Precisely



# Interrupt Timing Measurements May Be Affected Too



## Example: Core and Package C-states



# What Target Residency To Use for a “Combo” State?



Intel  
**OpenSource**  
TECHNOLOGY CENTER

# Target Residencies May Be Missed Due to Interactions (1)



# Target Residencies May Be Missed Due to Interactions (2)



# Overlapping Hints and Missed Opportunities



# Fall-through Idle States Idea

Assume target residency (TR) of the next idle state

Selected for latency reasons only.

Results (12 runs on Dell XPS13 9360, TEO governor)

| Metric            | Baseline        | C6 – C10: TR of C6 | Δ     | %    |
|-------------------|-----------------|--------------------|-------|------|
| BaseMark          | $301.0 \pm 6.5$ | $305.9 \pm 5.6$    | 4.9   | 1.7  |
| JetStream2 (1)    | $54.5 \pm 1.7$  | $55.1 \pm 1.6$     | 0.6   | 1.1  |
| speedometer       | $44.9 \pm 0.4$  | $45.2 \pm 0.3$     | 0.3   | 0.7  |
| JetStream2 (2)    | $53.5 \pm 1.4$  | $54.4 \pm 1.6$     | 0.9   | 1.6  |
| Active Watt (pkg) | $13.1 \pm 0.1$  | $13.1 \pm 0.2$     | 0.0   | 0.0  |
| Idle Watt (pkg)   | $0.93 \pm 0.08$ | $0.88 \pm 0.07$    | -0.05 | -5.8 |

# Questions?



 **OpenSource**  
TECHNOLOGY CENTER

# References

-  Marta Rybczyńska, *Improving idle behavior in tickless systems* (<https://lwn.net/Articles/775618/>).
-  Tom Yates, *What's a CPU to do when it has nothing to do?* (<https://lwn.net/Articles/767630/>).
-  Rafael J. Wysocki, *CPU Idle Loop Rework* (<https://kernel-recipes.org/en/2018/talks/cpu-idle-loop-rework/>).
-  T. Ilsche, M. Hähnel, R. Schöhne, M. Bielert, D. Hackenberg,  
*Powernightmares: The Challenge of Efficiently Using Sleep States on Multi-Core Systems*  
(<https://tu-dresden.de/zih/forschung/ressourcen/dateien/projekte/haec/powernightmares.pdf?lang=en>).
-  Rafael J. Wysocki, *Power Management Challenges in Linux* ([https://www.linuxplumbersconf.org/2017/ocw//system/presentations/4652/original/linux\\_pm\\_challenges.pdf](https://www.linuxplumbersconf.org/2017/ocw//system/presentations/4652/original/linux_pm_challenges.pdf)).
-  Rafael J. Wysocki, *PM Infrastructure in the Linux Kernel – Current Status and Future*  
([https://events.linuxfoundation.org/sites/events/files/slides/kernel\\_PM\\_infra\\_0.pdf](https://events.linuxfoundation.org/sites/events/files/slides/kernel_PM_infra_0.pdf)).
-  Jonathan Corbet, *The cpuidle subsystem* ([http://lwn.net/Articles/384146/](https://lwn.net/Articles/384146/)).

## Disclaimer

Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. No computer system can be absolutely secure. Check with your system manufacturer or retailer or learn more at [www.intel.com](http://www.intel.com).

Intel and the Intel logo are trademarks of Intel Corporation in the U.S. and/or other countries. \*Other names and brands may be claimed as the property of others.

© Intel Corporation

