Automatic CPU speed & power optimizer for Linux
Go to file
abvee 9a1c0ad44a
Improve auto-cpufreq installer (#459)
* Fixed seperator so that it prints to the lenght of the terminal and uses box lines instead of hyphens

* Replaced multiple echo calls with either a single echo call or a here
doc.
Here docs are more efficient as they only call once, and formatting
doesn't need to be done with escape characters, thus making code more
readable

* Moved header to the center

* Fixed _EOF_ error

* Fixed Indentation problem.
Moved $COLOUMN into seperator function, so if the terminal is resized
while the script is running, a new seperator should be resized as well.

* Added a header function as the "auto-cpufreq installer" heading comes up
multiple times.

Made local variables to allow for neat drawing when resizing the
terminal.

* Fixed spacing issue

* Replaced "=" with seperators and added blank lines

* Added a check for wrapper script. This allows uninstallation without the daemon needing to be installed
2022-12-05 06:32:51 +01:00
.github Fix typo in issue template 2022-10-03 20:40:54 +02:00
auto_cpufreq Use usr/local/bin instead of usr/bin for Silverblue and other immutable OSs (#460) 2022-11-24 17:44:57 +01:00
bin Add --install_performance option to help menu 2022-08-02 09:27:57 +02:00
scripts add s6 script for auto-cpufreq install (#421) 2022-08-15 12:40:39 +02:00
snap Update to core22 & v1.9.5 bump 2022-06-17 07:04:17 +02:00
.gitignore Improve domain language around logging and stats (#160) 2021-02-02 21:40:55 +01:00
LICENSE Initial commit 2019-12-29 21:39:57 +01:00
README.md Documentation update/revamp (#458) 2022-11-27 16:56:55 +01:00
auto-cpufreq-installer Improve auto-cpufreq installer (#459) 2022-12-05 06:32:51 +01:00
auto-cpufreq.conf-example Add min/max allowed frequencies option (#309) (#324) 2021-12-26 11:01:32 +01:00
requirements.txt removed unused power lib 2020-08-14 11:28:29 +02:00
setup.py 1.9.6 version bump (release) 2022-09-11 15:03:00 +02:00

README.md

auto-cpufreq

Automatic CPU speed & power optimizer for, Linux based on active monitoring of a laptop's battery state, CPU usage, CPU temperature and system load. Ultimately allowing you to improve battery life without making any compromises.

For tl;dr folks there's a: Youtube: auto-cpufreq - tool demo

Looking for developers and co-maintainers

auto-cpufreq is looking for co-maintainers & open source developers to help shape future of the project!

Index

Why do I need auto-cpufreq?

One of the problems with Linux today on laptops is that the CPU will run in an unoptimized manner which will negatively reflect on battery life. For example, the CPU will run using "performance" governor with turbo boost enabled regardless if it's plugged in to power or not.

These issues can be mitigated by using tools like indicator-cpufreq or cpufreq, but these still require manual action from your side which can be daunting and cumbersome.

Using tools like TLP can help in this situation with extending battery life (which is something I used to do for numerous years), but it also might come with its own set of problems, like losing turbo boost.

With that said, I needed a simple tool which would automatically make "cpufreq" related changes, save battery like TLP, but let Linux kernel do most of the heavy lifting. That's how auto-cpufreq was born.

Please note: auto-cpufreq aims to replace TLP in terms of functionality and after you install auto-cpufreq it's recommended to remove TLP. If both are used for same functionality, i.e: to set CPU frequencies it'll lead to unwanted results like overheating. Hence, only use both tools in tandem if you know what you're doing.

The Tool/daemon that does not conflict with auto-cpufreq in any way, and is even recommended to have running alongside, is thermald.

Supported architectures and devices

Supported devices must have an Intel, AMD or ARM CPUs. This tool was developed to improve performance and battery life on laptops, but running it on desktop/servers (to lower power consumption) should also be possible.

Features

  • Monitoring
    • Basic system information
    • CPU frequency (system total & per core)
    • CPU usage (system total & per core)
    • CPU temperature (total average & per core)
    • Battery state
    • System load
  • CPU frequency scaling, governor and turbo boost management based on
    • Battery state
    • CPU usage (total & per core)
    • CPU temperature in combination with CPU utilization/load (prevent overheating)
    • System load
  • Automatic CPU & power optimization (temporary and persistent)

Installing auto-cpufreq

Snap store

auto-cpufreq is available on the snap store, or can be installed using CLI:

sudo snap install auto-cpufreq

Please note:

auto-cpufreq-installer

Get source code, run installer and follow on screen instructions:

git clone https://github.com/AdnanHodzic/auto-cpufreq.git
cd auto-cpufreq && sudo ./auto-cpufreq-installer

In case you encounter any problems with auto-cpufreq-installer, please submit a bug report.

AUR package (Arch/Manjaro Linux)

  • Binary Package (For the latest binary release on github)
  • Git Package (For the latest commits/changes)
    Please note that this git package is currently unmaintained & has issues. Until someone starts maintaining it, use the manual script installer if you intend to have the latest changes.

Post Installation

After installation auto-cpufreq will be available as a binary and you can refer to auto-cpufreq modes and options for more information on how to run and configure auto-cpufreq.

Configuring auto-cpufreq

auto-cpufreq makes all decisions automatically based on various factors like cpu usage, temperature or system load. However, it's possible to perform additional configurations in 2 ways:

1: power_helper.py script

If detected as running, auto-cpufreq will disable GNOME Power profiles service, which would otherwise cause conflicts and cause problems.

By default auto-cpufreq uses balanced mode which works the best on various systems. However, if you're not reaching maximum frequencies your CPU is capable of with auto-cpufreq (#361), you can switch to performance mode. Which will result in higher frequencies by default, but also results in higher energy use (battery consumption).

If you installed auto-cpufreq using auto-cpufreq-installer, you can switch to performance mode by running:

sudo auto-cpufreq --install_performance

Or if you installed auto-cpufreq using Snap package you can switch to performance mode by running:

sudo python3 power_helper.py --gnome_power_disable performance

Please Note:
The power_helper.py script is located at auto_cpufreq/power_helper.py. In order to have access to it, you need to first clone the repository:

git clone https://github.com/AdnanHodzic/auto-cpufreq

After this step, all necessary changes will still be made automatically. However, if you wish to perform additional "manual" settings this can be done by following instructions explained in next step.

2: auto-cpufreq config file

You can configure seperate profiles for the battery and power supply. These profiles will let you pick which governor to use, and how and when turbo boost is enabled. The possible values for turbo boost behavior are always, auto and never. The default behavior is auto, which only kicks in during high load.

By default, auto-cpufreq does not use the config file! If you wish to use it, the location where config needs to be placed for it to be read automatically is: /etc/auto-cpufreq.conf

Example config file contents

# settings for when connected to a power source
[charger]
# see available governors by running: cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_available_governors
# preferred governor.
governor = performance

# minimum cpu frequency (in kHz)
# example: for 800 MHz = 800000 kHz --> scaling_min_freq = 800000
# see conversion info: https://www.rapidtables.com/convert/frequency/mhz-to-hz.html
# to use this feature, uncomment the following line and set the value accordingly
# scaling_min_freq = 800000

# maximum cpu frequency (in kHz)
# example: for 1GHz = 1000 MHz = 1000000 kHz -> scaling_max_freq = 1000000
# see conversion info: https://www.rapidtables.com/convert/frequency/mhz-to-hz.html
# to use this feature, uncomment the following line and set the value accordingly
# scaling_max_freq = 1000000

# turbo boost setting. possible values: always, auto, never
turbo = auto

# settings for when using battery power
[battery]
# see available governors by running: cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_available_governors
# preferred governor
governor = powersave

# minimum cpu frequency (in kHz)
# example: for 800 MHz = 800000 kHz --> scaling_min_freq = 800000
# see conversion info: https://www.rapidtables.com/convert/frequency/mhz-to-hz.html
# to use this feature, uncomment the following line and set the value accordingly
# scaling_min_freq = 800000

# maximum cpu frequency (in kHz)
# see conversion info: https://www.rapidtables.com/convert/frequency/mhz-to-hz.html
# example: for 1GHz = 1000 MHz = 1000000 kHz -> scaling_max_freq = 1000000
# to use this feature, uncomment the following line and set the value accordingly
# scaling_max_freq = 1000000

# turbo boost setting. possible values: always, auto, never
turbo = auto

How to run auto-cpufreq

auto-cpufreq should be run with with one of the following options:

  • monitor

    • Monitor and see suggestions for CPU optimizations
  • live

    • Monitor and make (temp.) suggested CPU optimizations
  • install / remove

    • Install/remove daemon for (permanent) automatic CPU optimizations
  • install_performance

    • Install daemon in "performance" mode.
  • stats

    • View live stats of CPU optimizations made by daemon
  • config TEXT

    • Use config file at defined path
  • debug

    • Show debug info (include when submitting bugs)
  • version

    • Show currently installed version
  • donate

    • To support the project
  • help

    • Shows all of the above options

Running auto-cpufreq --help will print the same list of options as above. Read auto-cpufreq modes and options for more details.

auto-cpufreq modes and options

Monitor

sudo auto-cpufreq --monitor

No changes are made to the system, and is solely made for demonstration purposes what auto-cpufreq could do differently for your system.

Live

sudo auto-cpufreq --live

Necessary changes are temporarily made to the system which are lost with system reboot. This mode is made to evaluate what the system would behave with auto-cpufreq permanently running on the system.

Install - auto-cpufreq daemon

Necessary changes are made to the system for auto-cpufreq CPU optimization to persist across reboots. The daemon is deployed and then started as a systemd service. Changes are made automatically and live stats are generated for monitoring purposes.

Install the daemon using this command (after installing auto-cpufreq):

sudo auto-cpufreq --install

This will enable the auto-cpufreq service (equivalent to systemctl enable auto-cpufreq) to start on boot, and start it (equivalent to systemctl start auto-cpufreq).

After the daemon is installed, auto-cpufreq is available as a binary and is running in the background. Its stats can be viewed by running: auto-cpufreq --stats

Since daemon is running as a systemd service, its status can be seen by running:

systemctl status auto-cpufreq

If the install has been performed as part of snap package, daemon status can be verified by running:

systemctl status snap.auto-cpufreq.service.service

Remove - auto-cpufreq daemon

auto-cpufreq daemon and its systemd service, along with all its persistent changes can be removed by running:

sudo auto-cpufreq --remove

This does the equivalent of systemctl stop auto-cpufreq && systemctl disable auto-cpufreq.

Note that the given command should be used instead of using just systemctl.

Stats

If daemon has been installed, live stats of CPU/system load monitoring and optimization can be seen by running:

auto-cpufreq --stats

Troubleshooting

Q: If after installing auto-cpufreq you're (still) experiencing:

  • high CPU temperatures
  • CPU is not scaling to minimum/maximum frequencies
  • suboptimal CPU performance

A: If you're using intel_pstate CPU management driver consider changing it to: acpi-cpufreq.

This can be done by editing /etc/default/grub file and appending intel_pstate=disable to GRUB_CMDLINE_LINUX_DEFAULT line, followed by sudo update-grub

Example line change:

GRUB_CMDLINE_LINUX_DEFAULT="quiet splash intel_pstate=disable"

Discussion:

Donate

Showing your support and appreciation for auto-cpufreq project can be done in two ways:

  • Financial donation
  • Code contribution

Financial donation

If auto-cpufreq helped you out and you find it useful, show your appreciation by donating (any amount) to the project!

PayPal

paypal

BitCoin

bc1qlncmgdjyqy8pe4gad4k2s6xtyr8f2r3ehrnl87

bitcoin

Code contribution

Other ways of supporting the project consists of making a code or documentation contribution. If you have an idea for a new features or want to implement some of the existing feature requests or fix some of the bugs & issues please make your changes and submit a pull request which I'll be glad to review. If your changes are accepted you'll be credited as part of releases page.

Please note: auto-cpufreq is looking for co-maintainers & open source developers to help shape future of the project!