diff options
author | Que Quotion | 2022-02-22 00:38:07 +0900 |
---|---|---|
committer | Que Quotion | 2022-02-22 00:38:07 +0900 |
commit | c4efbe4a205cb3e647c7d6c3f18168f821bab69c (patch) | |
tree | 0057013b2a374c9cb8ac3e373f77a110dc5d1a62 | |
parent | 67134d91a8eb959b1f234b744c6721aaf13d1401 (diff) | |
download | aur-c4efbe4a205cb3e647c7d6c3f18168f821bab69c.tar.gz |
Partial rewrite of throttlectl script: smarter scripting (use tee; actually check things exist before setting them, etc); order as in front end (sys,turbo,hyperthreads,gov,gpu,backlight); have backlight be a powersave/performance toggle like everything else (it will set only the lowest or highest brightness)
-rw-r--r-- | .SRCINFO | 4 | ||||
-rw-r--r-- | PKGBUILD | 4 | ||||
-rwxr-xr-x | throttlectl | 236 |
3 files changed, 109 insertions, 135 deletions
@@ -1,6 +1,6 @@ pkgbase = throttlectl pkgdesc = Command-line user discretion power managment utility - pkgver = 8 + pkgver = 9 pkgrel = 1 url = https://bbs.archlinux.org/viewtopic.php?id=180762 arch = any @@ -21,7 +21,7 @@ pkgbase = throttlectl source = performance source = systemstate source = powermizer - sha512sums = 9fd9bce15fbbce4d5f42860302fbaf96263f312e1eb21a27a2e79ce1ffd26bfe603ef97af9dd9b1420449dbe546645b51c1adb99b8502e39ed5a14150ad61460 + sha512sums = 36a3ad795a2c0b0ce98492a903499b19982c4a75ca536955111c6613fea8242abc19ff5dcaa558bd1f38a32be9d768879b458e5dd651deaa2eea84580a43d70d sha512sums = 6254e73446a91ea7945b9e4db1a1047eb2055d93aee315006857711ab21cba140da3badcf5834d2628e4799494a069647d11aa378a9bac67691df8d8b3adc12f sha512sums = 926f7c787aea8c1027f331fe2e9417ba8e4f15a79f51610baafeed5d0de86d8f41da92f4460c29a5ce251e7cc110e26c2c344931af91949dc529595cc18c0f0e sha512sums = 0d90ae4c0b9600f50ffd3e2c1a03b49d2fbdb9a2d14c8211e86463787549ada156498f68989d851952fe34660daaacc11242f5ee9e9e318f3d2a3eba0971eb53 @@ -1,7 +1,7 @@ # Maintainer: Que Quotion <quequotion@mailinator.com> pkgname=throttlectl -pkgver=8 +pkgver=9 pkgrel=1 pkgdesc="Command-line user discretion power managment utility" arch=('any') @@ -16,7 +16,7 @@ source=('throttlectl' 'performance' 'systemstate' 'powermizer') -sha512sums=('9fd9bce15fbbce4d5f42860302fbaf96263f312e1eb21a27a2e79ce1ffd26bfe603ef97af9dd9b1420449dbe546645b51c1adb99b8502e39ed5a14150ad61460' +sha512sums=('36a3ad795a2c0b0ce98492a903499b19982c4a75ca536955111c6613fea8242abc19ff5dcaa558bd1f38a32be9d768879b458e5dd651deaa2eea84580a43d70d' '6254e73446a91ea7945b9e4db1a1047eb2055d93aee315006857711ab21cba140da3badcf5834d2628e4799494a069647d11aa378a9bac67691df8d8b3adc12f' '926f7c787aea8c1027f331fe2e9417ba8e4f15a79f51610baafeed5d0de86d8f41da92f4460c29a5ce251e7cc110e26c2c344931af91949dc529595cc18c0f0e' '0d90ae4c0b9600f50ffd3e2c1a03b49d2fbdb9a2d14c8211e86463787549ada156498f68989d851952fe34660daaacc11242f5ee9e9e318f3d2a3eba0971eb53' diff --git a/throttlectl b/throttlectl index 202ed0dea277..714c12acdf49 100755 --- a/throttlectl +++ b/throttlectl @@ -15,7 +15,7 @@ throttle_help() { "${0} ht {on,off} - Hyperthreads\n"\ "${0} gov {cut,full} - CPU Governor\n"\ "${0} gpu {cut,full} - GPU runtime powersaving (only Nvidia ATM)\n"\ - "${0} backlight {0,1,2} - Backlight brightness (laptops only?)\n" \ + "${0} backlight {cut,full} - Backlight brightness (laptops only?)\n" \ "\nAll options are stackable and take {{cut,powersave,start},{full,performace,stop},{check,status}}\n" exit } @@ -29,66 +29,6 @@ config_help() { exit } -throttle_ht() { - [[ -f /sys/devices/system/cpu/smt/control ]] && \ - printf "${HYPERTHREADS}" > /sys/devices/system/cpu/smt/control & -} - -check_ht() { - [[ -f /sys/devices/system/cpu/smt/control ]] && \ - echo -e "\nHyperthreads\n/sys/devices/system/cpu/smt/\n"\ - "control\t$(cat /sys/devices/system/cpu/smt/control)" -} - -throttle_gov() { - for i in /sys/bus/cpu/drivers/processor/cpu*/cpufreq/scaling_governor; do \ - [[ "$(printf ${i} | tr -cd [:digit:])" -ge "${CORES}" && \ - "$(cat /sys/devices/system/cpu/cpu$(printf ${i} | tr -cd [:digit:])/online)" == 0 ]] && \ - continue ; printf "${GOVERNOR}" > "${i}" & done & -} - -check_gov() { - printf "\nCPU Governor\n/sys/bus/cpu/drivers/processor/cpu*/cpufreq/scaling_governor\n" - for i in /sys/bus/cpu/drivers/processor/cpu*/cpufreq/scaling_governor; do \ - printf " ${i}\n$(cat ${i})\n"; done | sed 's|/sys/bus/cpu/drivers/processor/||g; s|/.*||g; N;s|\n|\t|' -} - -throttle_turbo() { - [[ -f /sys/devices/system/cpu/intel_pstate/no_turbo ]] && \ - printf "${XPSTURBO}" > /sys/devices/system/cpu/intel_pstate/no_turbo & -} - -check_turbo() { - [[ -f /sys/devices/system/cpu/intel_pstate/no_turbo ]] && \ - echo -e "\nDisable Intel P-State Turbo\n/sys/devices/system/cpu/intel_pstate/\n"\ - "no_turbo\t$(cat /sys/devices/system/cpu/intel_pstate/no_turbo)" -} - -throttle_backlight() { - [[ -f /sys/class/backlight/acpi_video0 ]] && \ - for i in /sys/class/backlight/acpi_video*/brightness; do \ - printf "${BACKLIGHT}" > "${i}" & done & -} - -check_backlight() { - [[ -f /sys/class/backlight/acpi_video0 ]] && \ - printf "\nBacklight\n/sys/class/backlight/\n" && \ - for i in /sys/class/backlight/acpi_video*/brightness; do \ - printf " ${i}\n$(cat ${i})\n"; done | sed 's|/sys/class/backlight/||g; s|/.*||g; N;s|\n|\t|' -} - -throttle_nvpm() { - [[ -z "$(command -v nvidia-settings)" ]] && \ - printf "nvidia-settings not found; only nvidia currently supported" || \ - DISPLAY=":0.0" nvidia-settings -a [gpu:0]/GPUPowerMizerMode="${NVPM}" > /dev/null & -} - -check_nvpm() { - [[ -n "$(command -v nvidia-settings)" ]] && \ - printf "\nNvidia PowerMizer\n " && \ - DISPLAY=":0.0" nvidia-settings -q [gpu:0]/GPUPowerMizerMode | grep "Attribute" | sed 's|.*\[||g;s|\]):||g;s| |\t|g;s|\.$||g' -} - throttle_system() { # ENERGY_PERF_BIAS [[ -n "$(command -v x86_energy_perf_policy)" ]] && \ @@ -107,53 +47,53 @@ throttle_system() { printf "${NMIDOG}" > /proc/sys/kernel/watchdog & # SATA link power management - for i in /sys/class/scsi_host/host*/link_power_management_policy; do [[ -f "${i}" ]] && \ - printf "${POLICY}" > "${i}" & done & + [[ -n "$(ls /sys/class/scsi_host/host*/link_power_management_policy 2> /dev/null)" ]] && \ + printf "${POLICY}" | tee /sys/class/scsi_host/host*/link_power_management_policy > /dev/null 2>&1 & # Hard drives [[ -n "$(command -v hdparm)" ]] && \ - hdparm -qB "${APM}" -qM "${AAM}" /dev/[hs]d[a-z] 2> /dev/null & + hdparm -qB "${APM}" -qM "${AAM}" /dev/[hs]d[a-z] > /dev/null 2>&1 & # Block device autosuspend - for i in /sys/block/*/device/power/autosuspend_delay_ms; do \ - printf -- "${DISKAUTOSUSPEND}" > "${i}" & done & + [[ -n "$(ls /sys/block/*/device/power/autosuspend_delay_ms 2> /dev/null)" ]] && \ + printf -- "${DISKAUTOSUSPEND}" | tee /sys/block/*/device/power/autosuspend_delay_ms > /dev/null 2>&1 & # Runtime power management for devices (with exceptions for devices by VID:PID) for i in /sys/{class/*,bus/*/devices}/*/power/control; do \ [[ "${CONTROL}" == "auto" ]] && \ - [[ -n "$(printf ${i} | grep msr[${CORES}-$((${CORES} * 2 - 1))])" || \ - -n "$(printf ${i} | grep machinecheck[${CORES}-$((${CORES} * 2 - 1))])" || \ - -n "$(ls $(printf ${i} | sed 's|power.*||g')/*/ | grep 046D\:C52B)" ]] && \ - continue ; printf "${CONTROL}" > "${i}" & done & + [[ -n "$(ls $(printf ${i} | sed 's|power.*||g')/*/ | grep 046D\:C52B)" ]] && \ + continue ; CONTROLS+="${i} "; done + [[ -n "${CONTROLS}" ]] && printf "${CONTROL}" | tee "${CONTROLS}" > /dev/null 2>&1 & # USB Autosuspend (with exceptions for devices by VID:PID) for i in /sys/bus/usb/devices/*/power/autosuspend{,_delay_ms}; do \ [[ "${AUTOSUSPEND}" == "1" ]] && \ [[ -n "$(ls $(printf ${i} | sed 's|power.*||g')/*/ | grep 046D\:C52B)" ]] && \ - continue ; printf -- "${AUTOSUSPEND}" > "${i}" & done & + continue ; AUTOSUSPENDS+="${i} "; done + [[ -n "${AUTOSUSPENDS}" ]] && printf -- "${AUTOSUSPEND}" | tee "${AUTOSUSPENDS}" > /dev/null 2>&1 & # Powersaving for modules - for i in /sys/module/*/parameters/power_save; do \ - printf "${POWERSAVE}" > "${i}" & done & - for i in /sys/module/*/parameters/power_save_controller; do \ - printf "${CONTROLLER}" > "${i}" & done & + [[ -n "$(ls /sys/module/*/parameters/power_save 2> /dev/null)" ]] && \ + printf "${POWERSAVE}" | tee /sys/module/*/parameters/power_save > /dev/null 2>&1 & + [[ -n "$(ls /sys/module/*/parameters/power_save_controller 2> /dev/null)" ]] && \ + printf "${CONTROLLER}" | tee /sys/module/*/parameters/power_save_controller > /dev/null 2>&1 & # Network powersaving for i in /sys/class/net/wl*; do \ [[ -n "$(command -v iw)" ]] && \ - iw dev "$(printf ${i} | sed 's/^.*wl/wl/')" set power_save "${WLPOWERSAVE}" 2> /dev/null & done & + iw dev "$(printf ${i} | sed 's/^.*wl/wl/')" set power_save "${WLPOWERSAVE}" > /dev/null 2>&1 & done & for i in /sys/class/net/e*; do \ [[ -n "$(command -v ethtool)" ]] && \ - ethtool -s "$(printf ${i} | sed 's/^.*e/e/')" wol "${WOLA}" 2> /dev/null & done & - for i in /sys/class/net/*/device/power/wakeup; do \ - printf "${WOLB}" > "${i}" & done & + ethtool -s "$(printf ${i} | sed 's/^.*e/e/')" wol "${WOLA}" > /dev/null 2>&1 & done & + [[ -n "$(ls /sys/class/net/*/device/power/wakeup 2> /dev/null)" ]] && \ + printf "${WOLB}" | tee /sys/class/net/*/device/power/wakeup > /dev/null 2>&1 & # LEDs - for i in /sys/class/leds/*/brightness; do \ - printf "${LEDBRIGHT}" > "${i}" & done & + [[ -n "$(ls /sys/class/leds/*/brightness 2> /dev/null)" ]] && \ + printf "${LEDBRIGHT}" | tee /sys/class/leds/*/brightness > /dev/null 2>&1 & # Save state for frontend - printf "$SYSTEM" > /etc/throttle.d/systemstate & + printf "${SYSTEM}" > /etc/throttle.d/systemstate & } check_system() { @@ -211,22 +151,77 @@ check_system() { printf " ${i}\n$(cat ${i})\n"; done | sed 's|/sys/class/leds/||g; s|/brightness||g; s|/.*||g; N;s|\n|\t|' } +throttle_ht() { + [[ -f /sys/devices/system/cpu/smt/control ]] && \ + printf "${HYPERTHREADS}" > /sys/devices/system/cpu/smt/control & +} + +check_ht() { + [[ -f /sys/devices/system/cpu/smt/control ]] && \ + echo -e "\nHyperthreads\n/sys/devices/system/cpu/smt/\n"\ + "control\t$(cat /sys/devices/system/cpu/smt/control)" +} + +throttle_turbo() { + [[ -f /sys/devices/system/cpu/intel_pstate/no_turbo ]] && \ + printf "${XPSTURBO}" > /sys/devices/system/cpu/intel_pstate/no_turbo & +} + +check_turbo() { + [[ -f /sys/devices/system/cpu/intel_pstate/no_turbo ]] && \ + echo -e "\nDisable Intel P-State Turbo\n/sys/devices/system/cpu/intel_pstate/\n"\ + "no_turbo\t$(cat /sys/devices/system/cpu/intel_pstate/no_turbo)" +} + +throttle_gov() { + [[ -n "$(ls /sys/bus/cpu/drivers/processor/cpu*/cpufreq/scaling_governor 2> /dev/null)" ]] && \ + printf "${GOVERNOR}" | tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor > /dev/null 2>&1 & +} + +check_gov() { + [[ -n "$(ls /sys/bus/cpu/drivers/processor/cpu*/cpufreq/scaling_governor 2> /dev/null)" ]] && \ + printf "\nCPU Governor\n/sys/bus/cpu/drivers/processor/cpu*/cpufreq/scaling_governor\n" + for i in /sys/bus/cpu/drivers/processor/cpu*/cpufreq/scaling_governor; do \ + printf " ${i}\n$(cat ${i})\n"; done | sed 's|/sys/bus/cpu/drivers/processor/||g; s|/.*||g; N;s|\n|\t|' +} + +throttle_nvpm() { + [[ -z "$(command -v nvidia-settings)" ]] && \ + printf "nvidia-settings not found; only nvidia currently supported" || \ + DISPLAY=":0.0" nvidia-settings -a [gpu:0]/GPUPowerMizerMode="${NVPM}" > /dev/null 2>&1 && \ + check_nvpm | tail -c 2 | tr -d '\n' > /etc/throttle.d/powermizer & +} + +check_nvpm() { + [[ -n "$(command -v nvidia-settings)" ]] && \ + printf "\nNvidia PowerMizer\n " && \ + DISPLAY=":0.0" nvidia-settings -q [gpu:0]/GPUPowerMizerMode 2>/dev/null | grep "Attribute" | sed 's|.*\[||g;s|\]):||g;s| |\t|g;s|\.$||g' +} + +throttle_backlight() { + [[ -n "$(ls /sys/class/backlight/*/brightness 2> /dev/null)" ]] && \ + [[ "$BACKLIGHT" == "0" ]] && printf "${BACKLIGHT}" | tee /sys/class/backlight/*/brightness > /dev/null 2>&1 || \ + for i in /sys/class/backlight/*/brightness; do \ + cat "${i/%brightness/max_brightness}" > "${i}" & done & +} + +check_backlight() { + [[ -n "$(ls -d /sys/class/backlight/* 2> /dev/null)" ]] && \ + printf "\nBacklight\n/sys/class/backlight/\n" && \ + for i in /sys/class/backlight/*/brightness; do \ + printf " ${i}\n$(cat ${i})\n"; done | sed 's|/sys/class/backlight/||g; s|/.*||g; N;s|\n|\t|' +} + while (( "$#" )); do case "$1" in sys) - case "${2}" in - cut|off|powersave|start) - [[ -f /etc/throttle.d/powersave ]] && . /etc/throttle.d/powersave || config_help; SYSTEM="0" - ;; - full|on|performance|stop) - [[ -f /etc/throttle.d/performance ]] && . /etc/throttle.d/performance || config_help; SYSTEM="1" - ;; - check|status) - check_system - ;; - esac - [[ -n "$SYSTEM" ]] && throttle_system - shift "2" + case "${2}" in \ + cut|off|powersave|start) \ + [[ -f /etc/throttle.d/powersave ]] && . /etc/throttle.d/powersave || config_help; SYSTEM="0" ;; \ + full|on|performance|stop) \ + [[ -f /etc/throttle.d/performance ]] && . /etc/throttle.d/performance || config_help; SYSTEM="1" ;; \ + check|status) check_system ;; esac + [[ -n "$SYSTEM" ]] && throttle_system; shift "2" unset ENERGYPERF LAPTOP DIRTYWBC NMIDOG POLICY APM AAM CONTROL AUTOSUSPEND POWERSAVE CONTROLLER \ WLPOWERSAVE WOLA WOLB LEDBRIGHT SYSTEM ;; @@ -236,8 +231,7 @@ while (( "$#" )); do cut|off|powersave|start) XPSTURBO="1" ;; \ full|on|performance|stop) XPSTURBO="0" ;; \ check|status) check_turbo ;; esac - [[ -n "${XPSTURBO}" ]] && throttle_turbo - shift "2" + [[ -n "${XPSTURBO}" ]] && throttle_turbo; shift "2" unset XPSTURBO ;; ht) @@ -246,8 +240,7 @@ while (( "$#" )); do cut|off|powersave|start) HYPERTHREADS="off" ;; \ full|on|performance|stop) HYPERTHREADS="on" ;; \ check|status) check_ht ;; esac - [[ -n "${HYPERTHREADS}" ]] && throttle_ht - shift "2" + [[ -n "${HYPERTHREADS}" ]] && throttle_ht; shift "2" unset HYPERTHREADS ;; gov|cpu) @@ -256,8 +249,7 @@ while (( "$#" )); do cut|off|powersave|start) GOVERNOR="powersave" ;; \ full|on|performance|stop) GOVERNOR="performance" ;; \ check|status) check_gov ;; esac - [[ -n "${GOVERNOR}" ]] && throttle_gov - shift "2" + [[ -n "${GOVERNOR}" ]] && throttle_gov; shift "2" unset GOVERNOR ;; gpu) @@ -266,49 +258,31 @@ while (( "$#" )); do cut|off|powersave|start) NVPM="0" ;; \ full|on|performance|stop) NVPM="1" ;; \ check|status) check_nvpm ;; esac - [[ -n "${NVPM}" ]] && throttle_nvpm - shift "2" + [[ -n "${NVPM}" ]] && throttle_nvpm; shift "2" unset NVPM ;; backlight) [[ -z "${BACKLIGHT}" ]] && \ case "${2}" in \ - cut|off|0|powersave|start) BACKLIGHT="0" ;; \ - full|on|1|performance|stop) BACKLIGHT="1" ;; \ - 2) BACKLIGHT="2" ;; \ + cut|off|powersave|start) BACKLIGHT="0" ;; \ + full|on|performance|stop) BACKLIGHT="1" ;; \ check|status) check_backlight ;; esac - [[ -n "${BACKLIGHT}" ]] && throttle_backlight - shift "2" + [[ -n "${BACKLIGHT}" ]] && throttle_backlight; shift "2" unset BACKLIGHT ;; full|on|performance|start|cut|off|powersave|stop) - case "${1}" in - cut|off|powersave|start) - [[ -f /etc/throttle.d/powersave ]] && . /etc/throttle.d/powersave || config_help; SYSTEM="1" - ;; - full|on|performance|stop) - [[ -f /etc/throttle.d/performance ]] && . /etc/throttle.d/performance || config_help; SYSTEM="0" - ;; - esac - throttle_ht - throttle_gov - throttle_turbo - throttle_backlight - throttle_nvpm - throttle_system - shift + case "${1}" in \ + cut|off|powersave|start) \ + [[ -f /etc/throttle.d/powersave ]] && . /etc/throttle.d/powersave || config_help; SYSTEM="1" ;; \ + full|on|performance|stop) \ + [[ -f /etc/throttle.d/performance ]] && . /etc/throttle.d/performance || config_help; SYSTEM="0" ;; esac + throttle_system; throttle_turbo; throttle_ht; throttle_gov; throttle_nvpm; throttle_backlight; shift unset GOVERNOR XPSTURBO HYPERTHREADS ENERGYPERF BACKLIGHT LAPTOP DIRTYWBC NMIDOG \ - POLICY APM AAM CONTROL AUTOSUSPEND POWERSAVE CONTROLLER \ + POLICY APM AAM CONTROL{,S} AUTOSUSPEND{,S} POWERSAVE CONTROLLER \ WLPOWERSAVE WOLA WOLB LEDBRIGHT NVPM SYSTEM ;; check|status) - check_ht - check_gov - check_turbo - check_backlight - check_nvpm - check_system - shift + check_system; check_turbo; check_ht; check_gov; check_nvpm; check_backlight; shift ;; help|*) throttle_help |