Set battery charging threshold / charging limit / charging mode Battery Health Charging: An extension to maximize the battery life of laptops by setting their charging threshold or modes. Compatibility (no dependencies required): - Asus - LG - Samsung - Sony/Vaio - Huawei - Toshiba/Dynabook - System76 - Lenovo (Ideapad, Legion) - Thinkpad - Panasonic - Fujitsu - Dell (recent kernel) - Chromebook (recent kernel) Compatibility with dependencies - Acer (kernel module) - MSI (older kernel requires kernel module) - Tuxedo (kernel module) - Slimbook (kernel module) - Tuxedo IntelQC71 (kernel module) - XMG IntelQC71 (kernel module) - Eluktronics IntelQC71 (kernel module) - Purism Librem (kernel module) - Gigabyte Aero/Aorus (kernel module) - Dell (older kernel requires libsmbios/Dell Command Configure) - Apple Macbook Intel-series chip (kernel module) - Apple Macbook M-series chip (custom kernel) - Razer (package razer-cli) - Framework (kernel module / package: framework_tool) - Chromebook (older kernel requires package ectool) Not all models are comaptible. Please read about the compatibility and dependencies of your device on github link below. https://maniacx.github.io/Battery-Health-Charging/
Note: Binary files aren't shown on the web site. To see all files, please download the extension zipfile.
Version | Status |
---|---|
70 | Active |
69 | Active |
68 | Inactive |
67 | Rejected |
66 | Rejected |
65 | Inactive |
64 | Inactive |
63 | Inactive |
62 | Inactive |
61 | Inactive |
60 | Inactive |
59 | Inactive |
58 | Inactive |
57 | Inactive |
56 | Inactive |
55 | Inactive |
54 | Rejected |
53 | Inactive |
52 | Inactive |
51 | Inactive |
50 | Inactive |
49 | Inactive |
48 | Inactive |
47 | Inactive |
46 | Rejected |
45 | Rejected |
44 | Inactive |
43 | Inactive |
42 | Inactive |
41 | Inactive |
40 | Inactive |
39 | Inactive |
38 | Rejected |
37 | Inactive |
36 | Inactive |
35 | Inactive |
34 | Inactive |
33 | Rejected |
32 | Inactive |
31 | Inactive |
30 | Inactive |
29 | Inactive |
28 | Inactive |
27 | Rejected |
26 | Inactive |
25 | Inactive |
24 | Inactive |
23 | Inactive |
22 | Inactive |
21 | Inactive |
20 | Inactive |
19 | Inactive |
18 | Inactive |
17 | Inactive |
16 | Inactive |
15 | Inactive |
14 | Inactive |
13 | Inactive |
12 | Inactive |
11 | Inactive |
10 | Inactive |
9 | Inactive |
8 | Inactive |
7 | Inactive |
6 | Inactive |
5 | Inactive |
4 | Rejected |
3 | Inactive |
2 | Inactive |
1 | Inactive |
I have corrected the Highlighted issue with GLib.timeout's Each Glib.timeout has a different id and the are removed as soon as they exit and also removed them on disable extension. As far as script and spawn commands goes. there are a lot of spawn commands visible but maximum 4 are used A brief explaiation, I made this extension to control the charging-threshold of the laptop. Laptop currently supported are thinkpad, asus, samsung, sony, huwaei, lg, lenovo, acer, toshiba, appleIntelSMC, Some laptops require root permissions and some don't When the extension is enabled. 1. checkDeviceType() detects the type of laptop by checking sysfsfile for controlling threshold is present or not. schema@'device-type' If found device type is stored. 2. isDeviceAuthRequired() checks if this sysfs file need root to write on it or not and saved in schema@'root-mode' Once the type and mode is detected. If this extension is installed on thinkpad with dual battery, one mode change will echo 4 commands to change the threshold values battery 1 '/sys/class/power_supply/BAT0/charge_control_end_threshold'; battery 1 '/sys/class/power_supply/BAT0/charge_control_start_threshold'; battery 2 '/sys/class/power_supply/BAT1/charge_control_end_threshold'; battery 2 '/sys/class/power_supply/BAT1/charge_control_start_threshold'; maximum 4 commandline are used and it is only for this laptop with 2 battery which is also done in this extension https://extensions.gnome.org/extension/4798/thinkpad-battery-threshold/ Likewise if this extension is installed on thinkpad single battery, one mode change will echo 2 commands to change the threshold values '/sys/class/power_supply/BAT0/charge_control_end_threshold'; '/sys/class/power_supply/BAT0/charge_control_start_threshold'; maximum 2 commandline are used and it is only for this laptop Likewise if this extension is installed on asus, one mode change will echo 1 commands to change the threshold values '/sys/class/power_supply/BAT0/charge_control_end_threshold'; Similiar samsung, sony, huwaei, lg, lenovo, acer, toshiba, appleIntelSMC use only 1 commang to change the threshold values As you can see not all spawn commands are used. It is only uses selected command based on laptop type it is installed in. As for script, if root is need to change the threshold, user needs to install it. and remove it when removing the extension. installer.sh is used for this purpose and only used once. during first use of extension (if root is need) and when user decides to remove it. batteryhealthchargingctl is used to control the threshold in root-mode Honestly i used and sligthly modified both script from these two extension. https://extensions.gnome.org/extension/4372/shutdowntimer/ https://extensions.gnome.org/extension/945/cpu-power-manager/ I do not want to make an seperate app. It breaks usabilty. If there are other concerns please let me know. Oh. There is also another function that runs command through GLib subprocess cleanOutdatedFiles() My VERSION3 used systemd service to change permission of sysfsfile for controlling threshold so that the extension can modfy it. Now since I am using Polkit and not using systemd service, user who get automatically upgraded may not have a chances to uninstall the unused systemd service file. So i have embeded a fucntion to check if systemd service file exist. If exist it will notify to remove these unused systemd files. And if user clicks on remove file, it will use cleanOutdatedFiles() to remove them If this is too much, then I could delete cleanOutdatedFiles() function from this extension, and just send notification asking user to read github on how to remove these unused systemd service files. And i can mentioned steps on Github.
Approved. Thanks for the clarification. In case you want to separate it to an app: You can ask users to install the dependency in case the app wasn't installed. That's why we have rules for binaries and scripts installing from other sources: https://gjs.guide/extensions/review-guidelines/review-guidelines.html#scripts-and-binaries