Энергосбережение
Недавно пробовал ноут на AMD Ryzen 7 5800U, на нем и производительность и автономность из коробки (с amd_pstate=active) была превосходная.
А на моем дефолтном ноуте Dell Latitude 7490 на i7-8650U с этим проблемы - надо найти подходящий баланс между автономностью и быстродействием.
Тулзы
TLP
Я сейчас живу с таким конфигом:
CPU_DRIVER_OPMODE_ON_AC=active
CPU_SCALING_GOVERNOR_ON_AC=powersave
CPU_MIN_PERF_ON_AC=0
CPU_MAX_PERF_ON_AC=100
CPU_ENERGY_PERF_POLICY_ON_AC=balance_performance
CPU_ENERGY_PERF_POLICY_ON_BAT=balance_power
CPU_MIN_PERF_ON_BAT=0
CPU_MAX_PERF_ON_BAT=100
CPU_DRIVER_OPMODE_ON_BAT=passive
CPU_SCALING_GOVERNOR_ON_BAT=conservative
#CPU_SCALING_GOVERNOR_ON_BAT=schedutil
CPU_SCALING_MIN_FREQ_ON_BAT=400000
CPU_SCALING_MAX_FREQ_ON_BAT=2500000
CPU_BOOST_ON_AC=1
CPU_BOOST_ON_BAT=1
CPU_HWP_DYN_BOOST_ON_AC=1
CPU_HWP_DYN_BOOST_ON_BAT=1
NMI_WATCHDOG=0
# Можно поиграться, но я не пробовал
#INTEL_GPU_MIN_FREQ_ON_AC=0
#INTEL_GPU_MIN_FREQ_ON_BAT=0
#INTEL_GPU_MAX_FREQ_ON_AC=0
#INTEL_GPU_MAX_FREQ_ON_BAT=0
#INTEL_GPU_BOOST_FREQ_ON_AC=0
#INTEL_GPU_BOOST_FREQ_ON_BAT=0
PCIE_ASPM_ON_AC=default
PCIE_ASPM_ON_BAT=powersupersave
RUNTIME_PM_ON_AC=on
RUNTIME_PM_ON_BAT=auto
# костыль чтобы звук по bluetooth не рвался при активном трафике по wifi, но это не помогает и кажется надо менять модуль
USB_DENYLIST="1d6b:0002"
USB_EXCLUDE_BTUSB=1
WIFI_PWR_ON_AC=off
WIFI_PWR_ON_BAT=off
Поясняю в чем фишка: intel_pstate немного неадекватно рулит частотой, и ограничить частоту просто так нельзя, можно только в абстрактных процентах. И турбобуст при этом тоже нужен, т.к. чатоты 1.9 ГГц нехватает.
Passive режим pstate в связке с conservative говернором позволяет балансировать между низким энергопотреблением (ибо conservative) и достаточным для жизни турбобустом в 2.5 ГГц (для чего в ноутбук засунули турбобуст до 4.2 ГГц мне искренне непонятно). Еще можно смело снизить порог снижения чатоты - conservative говернор будет еще шустрее снижать частоту при снижении нагрузки на систему.
# агрессивнее снижать частоты
echo 5 | sudo tee /sys/devices/system/cpu/cpufreq/conservative/down_threshold
# не так часто запускать говернор, мне это помогло убрать подскоки частоты с 800 до 1200 в ютубе
echo 10000 | sudo tee /sys/devices/system/cpu/cpufreq/conservative/sampling_rate
# В итоге промежуточно как-то так
echo 30 | sudo tee /sys/devices/system/cpu/cpufreq/conservative/down_threshold
echo 1 | sudo tee /sys/devices/system/cpu/cpufreq/conservative/freq_step
echo 2 | sudo tee /sys/devices/system/cpu/cpufreq/conservative/sampling_down_factor
echo 80 | sudo tee /sys/devices/system/cpu/cpufreq/conservative/up_threshold
echo 25000 | sudo tee /sys/devices/system/cpu/cpufreq/conservative/sampling_rate
При этом повышается частота достаточно быстро, в околобраузерном использовании не заметно просадок производительности.
TuneD - аналог tlp от redhat
Немного упрощенный аналог TLP от RedHat.
Там нет некоторых новых параметров, которые есть в TLP, например управление порогами зарядки батареи, управление профилем платформы, управление частотой видеоядра, но зато есть, например, настройка C-state'ов, можно гибко задать пороги нагрузки и задержки
Но главный плюс по сравнению с TLP - профили. Если у TLP есть 2 режима - на батарее и на зарядке, то у TuneD можно рисовать режимы на любой удобный случай. Поэтому для TuneD есть пакет tuned-ppd, который позволяет управлять через dbus профилями (то чем занимается из коробки powerprofilesdaemon). И еще tuned умеет запускать кастомные скрипты в зависимости от профиля.
Есть gui для создания/редактирования/переключения профилей.
Power Profiles Daemon
Демон, который идет из коробки с популярными дистрами (федора, сузя, всякие debian-based) для управления энергопотреблением через DE (KDE, Gnome).
Абсолютно бесполезный демон, т.к. он не кастомизируется и какие конкретно параметры он изменяет - непонятно. Никогда его не использовал.
FAQ
Аппаратный декод видео
Могу лишь посоветовать почитать статью https://wiki.archlinux.org/title/Hardware_video_acceleration и смотреть наличие декода через nvtop или intel_gpu_top.
Жоский тюнинг проца
Вот тут можно настроить длительный буст и короткий буст
/sys/class/powercap/intel-rapl:0
in /sys/class/powercap/intel-rapl:0 λ cat constraint_0_name
long_term
in /sys/class/powercap/intel-rapl:0 λ cat constraint_1_name
short_term
# По дефолту для ноутбука тут какие-то сильно завышенные лимиты (i7-8650u)
in /sys/class/powercap/intel-rapl:0 λ cat constraint_0_power_limit_uw
22000000
in /sys/class/powercap/intel-rapl:0 λ cat constraint_1_power_limit_uw
44000000
# Говорят так будет хорошо на батарее
in /sys/class/powercap/intel-rapl:0 λ echo 10000000 | sudo tee constraint_0_power_limit_uw
10000000
in /sys/class/powercap/intel-rapl:0 λ echo 12000000 | sudo tee constraint_1_power_limit_uw
12000000
Также смотри на intel-undervolt, там можно урезать TDP, вольтаж и детально играться с потреблением проца.
Мониторить потребление можно так
sudo turbostat --Summary --interval 5 --show Avg_MHz,Busy%,Bzy_MHz,IRQ,PkgTmp,PkgWatt,GFXWatt
Проц
Если у тебя интел:
Есть 3 способа рулить частотой: intel_pstate (active), intel_pstate (passive), acpi-cpufreq
Ядра
На арче Я пробовал 3 разных ядра: linux, linux-zen, linux-clear. Они все показали разные результаты по автономности и неожиданно в пользу ванильного ядра. linux - не шибко быстрое, но автономное, linux-zen - бегает шустрее, но жрет больше батареи, linux-clear - ваще быстрое, но жрет столько же сколько linux-zen. Разница не сильно критична, но на аккумуляторе в 42 ватта это превращается из 2-3 часов автономности в 3-4.
Можно еще взять параметры ядра у linux-clear (наверное решает все таки mitigations=off)
Утилиты
[AUR] energygraph
https://github.com/stolk/energygraph
Консольная утилита которая строит график потребления системы.
[Repo] turbostat
Утилита которая графики не строит, но выводит много полезной информации, в т.ч. потребление каждого компонента системы.
Пример:
sudo turbostat \
--header_iterations 50 \
--Summary \
--interval 2 \
--show Avg_MHz,Busy%,Bzy_MHz,IRQ,PkgTmp,PkgWatt,CorWatt,GFXWatt,RAMWatt,SysWatt,UncMHz,POLL%,C0%,C1%,C1E%,C3%,C6%,C7s%,C8%,C9%,C10%
[AUR] powerstat - еще один аналог turbostat
Утилита собирает из RAPL инфу о потреблении энергии системой. Показывает красивую статистику
Просто команды:
cat /sys/devices/system/cpu/cpufreq/policy*/energy_performance_preference
power
power
power
power
power
power
power
power
cat /sys/devices/system/cpu/cpu*/power/energy_perf_bias # 0 - производительный режим, 15 - максимальное энергосбережение
15
15
15
15
15
15
15
15
No Comments