auto-cpufreq/README.md

130 lines
5.5 KiB
Markdown
Raw Normal View History

2020-01-02 19:12:34 +01:00
# auto-cpufreq
2020-01-03 19:05:33 +01:00
Automatic CPU speed & power optimizer for Linux based on active monitoring of laptop's battery state, CPU usage and system load. Ultimately allowing you to improve battery life without making any compromises.
2020-01-02 19:12:34 +01:00
For tl;dr folks there's a: [Youtube: auto-cpufreq - tool demo](https://www.youtube.com/watch?v=QkYRpVEEIlg)
2020-01-03 23:23:04 +01:00
[![](http://img.youtube.com/vi/QkYRpVEEIlg/0.jpg)](http://www.youtube.com/watch?v=QkYRpVEEIlg"")
## Why do I need auto-cpufreq?
2020-01-02 19:12:34 +01:00
One of the problems with Linux today on laptops is that CPU will run in unoptimized manner which will negatively reflect on battery life. For example, CPU will run using "performance" governor with turbo boost enabled regardless if it's plugged in to power or not.
Issue can be mitigated by using tools like [indicator-cpufreq](https://itsfoss.com/cpufreq-ubuntu/) or [cpufreq](https://github.com/konkor/cpufreq), but these still require maual action from your side which can be daunting and cumbersome.
Using tools like [TLP](https://github.com/linrunner/TLP) will help in this situation with extending battery life (which is something I did for numerous years now), but it also might come with its own set of problems, like losing turbo boost.
2020-01-02 19:12:34 +01:00
2020-01-05 11:33:35 +01:00
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.
2020-01-02 19:12:34 +01:00
2020-01-05 00:02:24 +01:00
Please note: this tool doesn't conflict and [works great in tandem with TLP](https://www.reddit.com/r/linux/comments/ejxx9f/github_autocpufreq_automatic_cpu_speed_power/fd4y36k/).
2020-01-03 16:48:03 +01:00
## Features
2020-01-02 19:12:34 +01:00
* Monitoring
* Basic system information
* CPU frequency
* CPU temperatures
* Battery state
* System load
* CPU frequency scaling, governor and [turbo boost](https://en.wikipedia.org/wiki/Intel_Turbo_Boost) management based on
* battery state
* CPU usage
* System load
* Automatic CPU & power optimization (temporary and persistent)
2020-01-03 16:48:03 +01:00
## How to run auto-cpufreq?
2020-01-02 19:12:34 +01:00
2020-01-07 17:29:20 +01:00
#### Arch Linux
[AUR package is available](https://aur.archlinux.org/packages/auto-cpufreq-git/) for install. After which `auto-cpufreq` will be available as a binary and you can skip to [auto-cpufreq: modes and options](https://github.com/AdnanHodzic/auto-cpufreq#auto-cpufreq-modes-and-options) for further reference.
2020-01-03 16:48:03 +01:00
#### Get auto-cpufreq source code
2020-01-02 19:12:34 +01:00
`git clone https://github.com/AdnanHodzic/auto-cpufreq.git`
#### Install requirements
##### Requirements installation for Debian/Ubuntu and their derivatives
All requirements can be installed by running:
2020-01-11 16:36:59 +01:00
`sudo apt install python3-dev python3-pip python3-distro python3-psutil python3-click -y`
2020-01-02 19:12:34 +01:00
2020-01-07 08:56:47 +01:00
Since APT packages may contain older version of necessary Python packages, please make sure to have latest version by running:
`sudo pip3 install --upgrade psutil click distro`
2020-01-11 16:36:59 +01:00
##### Requirements installation for Redhat/Fedora and its derivatives
Necessary pre-requisites can be installed by running:
`sudo yum install python-devel`
After which you need to[ need to install rest of the requirements](https://github.com/AdnanHodzic/auto-cpufreq#requirements-installation-for-all-other-linux-distributions) as stated below.
2020-01-02 19:12:34 +01:00
##### Requirements installation for all other Linux distributions
If you have python3 and pip3 installed simply run:
`sudo pip3 install psutil click distro`
Note: libraries must be installed using root user as tool will be run as root.
2020-01-07 08:56:47 +01:00
##### Running auto-cpufreq on AMD CPU and/or desktop/servers's
Please note when this tool was made it was solely targeting Intel CPU's running on laptops. Support for both AMD CPU is [currently being worked on](https://github.com/AdnanHodzic/auto-cpufreq/issues/17).
While there are plans to [extend support for desktop/servers](https://www.reddit.com/r/linux/comments/ejxx9f/github_autocpufreq_automatic_cpu_speed_power/fd5nodm/) in near future.
2020-01-02 19:12:34 +01:00
#### Run auto-cpufreq
auto-cpufreq can be run by simply running the `auto-cpufreq.py` and following on screen instructions, i.e:
`sudo python3 auto-cpufreq.py`
2020-01-03 16:48:03 +01:00
## auto-cpufreq modes and options
2020-01-02 19:12:34 +01:00
#### Monitor
`sudo python3 auto-cpufreq.py --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 python3 auto-cpufreq.py --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.
2020-01-02 19:12:34 +01:00
2020-01-03 16:48:03 +01:00
#### Install - auto-cpufreq daemon
Necessary changes are made to the system for auto-cpufreq CPU optimizaton to persist across reboots. Daemon is deployed and then started as a systemd service. Changes are made automatically and live log is made for monitoring purposes.
2020-01-02 19:12:34 +01:00
2020-01-03 16:39:35 +01:00
`sudo python3 auto-cpufreq.py --install`
2020-01-02 19:12:34 +01:00
After daemon is installed, `auto-cpufreq` is available as a binary and is running in the background. Its logs can be viewed by running: `auto-cpufreq --log`
Since daemon is running as a systemd service, its status can be seen by running:
`systemctl status auto-cpufreq`
2020-01-03 16:48:03 +01:00
#### Remove - auto-cpufreq daemon
2020-01-02 19:12:34 +01:00
2020-01-03 16:48:03 +01:00
auto-cpufreq daemon and its systemd service, along with all its persistent changes can be removed by running:
2020-01-02 19:12:34 +01:00
2020-01-05 17:30:19 +01:00
`sudo auto-cpufreq --remove`
2020-01-02 19:12:34 +01:00
or
`sudo python3 auto-cpufreq.py --remove`
#### Log
If daemon has been instaled, live log of CPU/system load monitoring and optimizaiton can be seen by running:
2020-01-02 19:12:34 +01:00
`auto-cpufreq --log`
2020-01-03 16:39:35 +01:00
or `sudo python3 auto-cpufreq.py --log`
2020-01-03 16:48:03 +01:00
## Discussion:
2020-01-03 16:39:35 +01:00
* Blogpost: [auto-cpufreq - Automatic CPU speed & power optimizer for Linux](http://foolcontrol.org/?p=3124)