bclm_loop is a background looping utility that maintains the battery level of Apple Silicon based Mac computers. This project was inspired by several battery management solutions, including Apple's own battery health management.
The purpose of limiting the battery's max charge is to prolong battery health and to prevent damage to the battery. Various sources show that the optimal charge range for operation of lithium-ion batteries is between 40% and 80%, commonly referred to as the 40-80 rule [1][2][3]. This project is especially helpful to people who leave their Macs on the charger all day, every day.
To use it, Apple Optimized Battery Charging must be turned off. It will first try to use firmware based battery level limits on supported firmware.
If the current battery level is higher than the target battery level, please manually discharge it to the target battery level or lower, otherwise it may only stay at the current battery level. This tool does not implement forced discharge because it may make the system unable to recognize the power adapter status.
It only supports Apple Silicon based Mac computers.
This project was forked from upstream (https://github.com/zackelia/bclm).
$ brew tap lslqtz/formulae
$ brew install bclm_loop
$ make build
$ sudo make install
$ unzip bclm_loop.zip
$ sudo mkdir -p /usr/local/bin
$ sudo cp bclm_loop /usr/local/bin/bclm_loop
$ sudo chmod +x /usr/local/bin/bclm_loop
$ bclm_loop
OVERVIEW: Battery Charge Level Max (BCLM) Utility.
USAGE: bclm_loop <subcommand>
OPTIONS:
--version Show the version.
-h, --help Show help information.
SUBCOMMANDS:
loop Loop bclm on target battery level (Default: 80%).
persist Persists bclm loop service.
unpersist Unpersists bclm loop service.
See 'bclm_loop help <subcommand>' for detailed help.
The program must be run as root.
If you are migrating from upstream bclm or older version (ver < 1.0) of bclm_loop.
$ sudo bclm unpersist
$ sudo rm -f /Library/LaunchDaemon/com.zackelia.bclm_loop.plist
It can run in the background to maintain battery levels. Just create a new plist in /Library/LaunchDaemons
and load it via launchctl
.
$ sudo bclm_loop persist
Likewise, it can be unpersisted which will unload the service and remove the plist.
$ sudo bclm_loop unpersist