Skip to content

Commit 8160467

Browse files
committed
**2020.3.14-dev (202003140)**
- `acc -s v`: fixed "voltage unit not shown" - `cooldownCurrent=(file raw_current charge_seconds pause_seconds)`, cooldown_current (ccr): dedicated and independent cooldown settings for quick charging - General optimizations - Updated documentation
1 parent 0c0960f commit 8160467

10 files changed

+117
-80
lines changed

README.md

+31-10
Original file line numberDiff line numberDiff line change
@@ -48,14 +48,13 @@ By choosing to use/misuse ACC, you agree to do so at your own risk!
4848
ACC is an Android software mainly intended for [extending battery service life](https://batteryuniversity.com/learn/article/how_to_prolong_lithium_based_batteries).
4949
In a nutshell, this is achieved through limiting charging current, temperature and voltage.
5050
Any root solution is supported. A recent stable Magisk version is recommended.
51-
If you're reading this from Magisk Manager > Downloads, tap here to open the documentation.
52-
Once there, if you're lazy, jump to the quick start section.
5351

5452

5553

5654
---
5755
## PREREQUISITES
5856

57+
- [Must Read: How to Prolong Lithium Ion Batteries Lifespan](https://batteryuniversity.com/index.php/learn/article/how_to_prolong_lithium_based_batteries/)
5958
- Android or Android based OS
6059
- Any root solution (e.g., [Magisk](https://github.com/topjohnwu/Magisk/))
6160
- [Busybox*](https://github.com/search?o=desc&q=busybox+android&s=updated&type=Repositories/) (only if not rooted with Magisk)
@@ -67,39 +66,44 @@ Once there, if you're lazy, jump to the quick start section.
6766
That's a fallback path. ACC sets permissions (rwx------) as needed.
6867
Precedence: Magisk busybox > system busybox > /data/adb/busybox
6968

70-
\*\* The Magisk module [ccbins](https://github.com/Magisk-Modules-Repo/ccbins/) by [Zackptg5](https://github.com/Zackptg5/) installs `curl`.
69+
\*\* The Magisk module [Cross Compiled Binaries](https://github.com/Magisk-Modules-Repo/ccbins/) installs `curl`.
7170

7271

7372

7473
---
7574
## QUICK START GUIDE
7675

76+
0. All commands/actions require root.
77+
Don't use `su -c`, `sudo`, `tsudo` or similar. On Android, these are not as reliable as the plain old `su`.
7778

7879
1. Unless Magisk is not installed, always install/upgrade from Magisk Manager or ACC front-end (e.g. AccA).
7980
Apps such as EX/Franco Kernel Managers are also good options.
8081
There are yet two more ways of upgrading: `acc -u` (online) and `acc -F` (zip flasher).
8182
Rebooting after installation/removal is unnecessary.
8283

83-
2. [Optional] run `su -c acc pause_capacity resume_capacity` (default `75 70`) or use a front-end app to change settings.
84+
2. [Optional] run `acc` (wizard). That's the only command you need to remember.
8485

85-
3. If you come across an issue, refer to the `TROUBLESHOOTING`, `TIPS` and `FAQ` sections below.
86-
Read as much as you can, before asking the developer or opening an issue on GitHub.
86+
3. [Optional] run `acc pause_capacity resume_capacity` (default `75 70`) to set the battery levels at which charging should pause and resume, respectively.
87+
88+
4. If you come across an issue, refer to the `TROUBLESHOOTING`, `TIPS` and `FAQ` sections below.
89+
Read as much as you can before asking the developer or opening issues on GitHub.
8790
Oftentimes, solutions will be right before your eyes.
8891

8992

9093
### Notes
9194

9295
- ACC cannot be installed/upgraded from recovery (e.g., TWRP).
9396

94-
- Step `2` is optional, because there are default settings.
97+
- Steps `2` and `3` are optional because there are default settings.
9598
For details, refer to the `DEFAULT CONFIGURATION` section below.
99+
Users are encouraged to try step `2` - to familiarize themselves with the menu.
96100

97101
- Settings can be overwhelming. Start with what you understand.
98102
The default configuration has you covered.
99103
Don't ever feel like you have to configure everything. You probably shouldn't anyway - unless you really know what you're doing.
100104

101105
- Uninstall: depending on the installed variant (e.g., app back-end or Magisk module), you can use Magisk Manager (app), [Magisk Manager for Recovery Mode (utility)](https://github.com/VR-25/mm/), or clear the front-end app's data.
102-
Two universal methods are: `su -c acc --uninstall` and `/sdcard/acc-uninstaller.zip` (flashable uninstaller).
106+
Two universal methods are: `acc --uninstall` and `/sdcard/acc-uninstaller.zip` (flashable uninstaller).
103107

104108

105109

@@ -176,7 +180,7 @@ Apps such as EX/Franco Kernel Managers are also good options.
176180
There are yet two more ways of upgrading: `acc -u` (online) and `acc -F` (zip flasher).
177181

178182
Uninstall: depending on the installed variant (e.g., app back-end or Magisk module), you can use Magisk Manager (app), [Magisk Manager for Recovery Mode (utility)](https://github.com/VR-25/mm/), or clear the front-end app's data.
179-
Two universal methods are: `su -c acc --uninstall` and `/sdcard/acc-uninstaller.zip` (flashable uninstaller).
183+
Two universal methods are: `acc --uninstall` and `/sdcard/acc-uninstaller.zip` (flashable uninstaller).
180184

181185

182186
### Notes
@@ -197,9 +201,10 @@ Additionally, `$installDir/acc/acc-init.sh` must be executed on boot to initiali
197201
```
198202
#DC#
199203
200-
configVerCode=202003110
204+
configVerCode=202003140
201205
capacity=(-1 60 70 75 +0 false)
202206
temperature=(70 80 90)
207+
cooldownCurrent=()
203208
cooldownRatio=()
204209
resetBattStats=(false false)
205210
loopDelay=(10 15)
@@ -224,6 +229,8 @@ dynPowerSaving=0
224229
225230
# temperature=(cooldown_temp max_temp max_temp_pause)
226231
232+
# cooldownCurrent=(file raw_current charge_seconds pause_seconds)
233+
227234
# cooldownRatio=(cooldown_charge cooldown_pause)
228235
229236
# resetBattStats=(reset_batt_stats_on_pause reset_batt_stats_on_unplug)
@@ -270,6 +277,8 @@ dynPowerSaving=0
270277
# mt max_temp
271278
# mtp max_temp_pause
272279
280+
# ccr cooldown_current
281+
273282
# cch cooldown_charge
274283
# cp cooldown_pause
275284
@@ -318,6 +327,9 @@ dynPowerSaving=0
318327
# acc /data/acc-night-config.txt -s c 500
319328
# accd /data/acc-night-config.txt
320329
330+
# acc -s "ccr=battery/current_now 1450000 100 20"
331+
# acc -s "cooldown_current=battery/current_now 1450000 100 20"
332+
321333
322334
# FINE, BUT WHAT DOES EACH OF THESE VARIABLES ACTUALLY MEAN?
323335
@@ -367,6 +379,9 @@ dynPowerSaving=0
367379
# When not set, the cycle is disabled.
368380
# Note that cooldown_capacity and cooldown_temp can be disabled individually by assigning them values that would never be reached under normal circumstances.
369381
382+
# cooldown_current #
383+
# Dedicated and independent cooldown settings for quick charging
384+
370385
# reset_batt_stats_on_pause (rbsp) #
371386
# Reset battery stats after pausing charging.
372387
@@ -901,6 +916,12 @@ It's a software (Android/kernel) issue. Use the `capacity_offset` or `capacity_s
901916
---
902917
## LATEST CHANGES
903918

919+
**2020.3.14-dev (202003140)**
920+
- `acc -s v`: fixed "voltage unit not shown"
921+
- `cooldownCurrent=(file raw_current charge_seconds pause_seconds)`, cooldown_current (ccr): dedicated and independent cooldown settings for quick charging
922+
- General optimizations
923+
- Updated documentation
924+
904925
**2020.3.11-dev (202003110)**
905926
- Fixed capacity_sync issues
906927

TODO.txt

+2-18
Original file line numberDiff line numberDiff line change
@@ -1,19 +1,3 @@
1-
Hangs and reboots
2-
Samsung GT-I9082
3-
Android 4.2.2
4-
Busybox: v1.28.3-Stericson installed in /system/xbin
5-
Root: SuperSU
6-
7-
spreadtrum
8-
flare s5
9-
101
cooldown
11-
cooldownCapacity=(capacity charge/pause)
12-
cooldownCurrent=(current charge/pause)
13-
cooldownTemp=(temp charge/pause)
14-
15-
capacity_sync inconsistencies
16-
incorrect battery status
17-
dumpsys
18-
19-
auto-shutdown not happening
2+
cooldownTemp=(min_temp charge_seconds pause_seconds max_temp max_temp_pause)
3+
cooldownCapacity=(capacity charge_seconds pause_seconds)

acc/accd.sh

+53-38
Original file line numberDiff line numberDiff line change
@@ -47,8 +47,9 @@ is_charging() {
4747
applyOnUnplug=true
4848

4949
# forceChargingStatusFullAt100
50-
if ! $forcedChargingStatusFullAt100 && [[ ${forceChargingStatusFullAt100:-x} == [0-9]* ]] \
51-
&& [ $(cat $batt/capacity) -gt 99 ]
50+
if ! $forcedChargingStatusFullAt100 \
51+
&& [ -n "${forceChargingStatusFullAt100-}" ] \
52+
&& [ $(( $(cat $batt/capacity) ${capacity[4]} )) -gt 99 ]
5253
then
5354
dumpsys battery set level 100 \
5455
&& dumpsys battery set status $forceChargingStatusFullAt100 \
@@ -93,10 +94,7 @@ is_charging() {
9394
# while unplugged, this keeps accd asleep most of the time to save resources
9495
# detecting plugged/unplugged states is possible (with acpi -a), but not universally
9596
if [ "$dynPowerSaving" != 0 ] && grep -iq dis $batt/status; then
96-
if [ $secondsUnplugged == 0 ]; then
97-
[ $(( ${capacity[3]} - ${capacity[2]} )) -gt 4 ] \
98-
&& hibernate=true || hibernate=false
99-
fi
97+
[ $secondsUnplugged == 0 ] && hibernate=true || hibernate=false
10098
secondsUnplugged=$(( secondsUnplugged + ${loopDelay[1]} ))
10199
! $hibernate || sleep $secondsUnplugged
102100
[ $secondsUnplugged -lt $dynPowerSaving ] || secondsUnplugged=0
@@ -112,7 +110,7 @@ is_charging() {
112110
$cooldown || {
113111
if $isCharging; then
114112
dumpsys battery set ac 1 \
115-
&& dumpsys battery set status $chgStatusCode || :
113+
&& dumpsys battery set status $chgStatusCode || :
116114
else
117115
dumpsys battery unplug \
118116
&& dumpsys battery set status $dischgStatusCode || :
@@ -131,44 +129,52 @@ is_charging() {
131129
disable_charging() {
132130
if is_charging; then
133131
if [ -f "${chargingSwitch[0]-}" ]; then
134-
if chmod +w ${chargingSwitch[0]} && echo "${chargingSwitch[2]//::/ }" > ${chargingSwitch[0]}; then
132+
if chmod +w ${chargingSwitch[0]} \
133+
&& echo "${chargingSwitch[2]//::/ }" > ${chargingSwitch[0]}
134+
then
135135
# secondary switch
136136
if [ -f "${chargingSwitch[3]-}" ]; then
137-
chmod +w ${chargingSwitch[3]} && echo "${chargingSwitch[5]//::/ }" > ${chargingSwitch[3]} \
137+
chmod +w ${chargingSwitch[3]} \
138+
&& echo "${chargingSwitch[5]//::/ }" > ${chargingSwitch[3]} \
138139
|| /sbin/acca $config --set charging_switch= > /dev/null
139140
fi
140141
sleep $switchDelay
141142
else
142143
/sbin/acca $config --set charging_switch= > /dev/null
143144
fi
144145
else
145-
[[ ${chargingSwitch[0]:-x} != */* ]] || /sbin/acca $config --set charging_switch= > /dev/null
146+
[[ ${chargingSwitch[0]:-x} != */* ]] \
147+
|| /sbin/acca $config --set charging_switch= > /dev/null
146148
! $prioritizeBattIdleMode || cycle_switches off not
147149
! is_charging || cycle_switches off
148150
fi
149151
if is_charging; then
150-
[[ ${chargingSwitch[0]:-x} != */* ]] || /sbin/acca $config --set charging_switch= > /dev/null
152+
[[ ${chargingSwitch[0]:-x} != */* ]] \
153+
|| /sbin/acca $config --set charging_switch= > /dev/null
151154
echo "(!) Failed to disable charging"
152155
exit 7
156+
else
157+
# if maxTemp is reached, keep charging paused for ${temperature[2]} seconds more
158+
! [ $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) -ge $(( ${temperature[1]} * 10 )) ] \
159+
|| sleep ${temperature[2]}
153160
fi
154161
fi
155-
# if maxTemp is reached, pause charging regardless of cooldownRatio
156-
! is_charging && [ $(( $(cat $batt/temp 2>/dev/null \
157-
|| cat $batt/batt_temp) / 10 )) -ge ${temperature[1]} ] \
158-
&& sleep ${temperature[2]} || :
159162
}
160163

161164

162165
enable_charging() {
163166
if ! is_charging; then
164-
if ! $ghostCharging || { $ghostCharging && [[ "$(acpi -a)" == *on-line* ]]; }; then
167+
if ! $ghostCharging \
168+
|| { $ghostCharging && [[ "$(acpi -a)" == *on-line* ]]; }
169+
then
165170
if [ -f "${chargingSwitch[0]-}" ]; then
166171
if chmod +w ${chargingSwitch[0]} \
167172
&& echo "${chargingSwitch[1]//::/ }" > ${chargingSwitch[0]}
168173
then
169174
# secondary switch
170175
if [ -f "${chargingSwitch[3]-}" ]; then
171-
chmod +w ${chargingSwitch[3]} && echo "${chargingSwitch[4]//::/ }" > ${chargingSwitch[3]} \
176+
chmod +w ${chargingSwitch[3]} \
177+
&& echo "${chargingSwitch[4]//::/ }" > ${chargingSwitch[3]} \
172178
|| /sbin/acca $config --set charging_switch= > /dev/null
173179
fi
174180
sleep $switchDelay
@@ -181,7 +187,9 @@ enable_charging() {
181187
cycle_switches on
182188
fi
183189
# detect and block ghost charging
184-
if ! $ghostCharging && ! grep -Eiq 'dis|not' $batt/status && [[ "$(acpi -a)" != *on-line* ]]; then
190+
if ! $ghostCharging && ! grep -Eiq 'dis|not' $batt/status \
191+
&& [[ "$(acpi -a)" != *on-line* ]]
192+
then
185193
disable_charging
186194
ghostCharging=true
187195
touch $TMPDIR/.ghost-charging
@@ -199,14 +207,12 @@ ctrl_charging() {
199207

200208
if is_charging; then
201209

202-
sleep ${loopDelay[0]}
203-
204210
# clear "rebooted on pause" flag
205-
[ $(( $(cat $batt/capacity) ${capacity[4]} )) -gt ${capacity[2]} ] \
206-
|| rm ${config%/*}/.rebootedOnPause 2>/dev/null || :
211+
[ $(( $(cat $batt/capacity) ${capacity[4]} )) -gt ${capacity[2]} ] \
212+
|| rm ${config%/*}/.rebootedOnPause 2>/dev/null || :
207213

208214
# disable charging under <conditions>
209-
if [ $(( $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) / 10 )) -ge ${temperature[1]} ] \
215+
if [ $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) -ge $(( ${temperature[1]} * 10 )) ] \
210216
|| [ $(( $(cat $batt/capacity) ${capacity[4]} )) -ge ${capacity[3]} ]
211217
then
212218
if [ ! -f ${config%/*}/.rebootedOnPause ]; then
@@ -241,27 +247,31 @@ ctrl_charging() {
241247

242248
if [ ! -f ${config%/*}/.rebootedOnPause ]; then
243249
# cooldown
244-
while [ -n "${cooldownRatio[0]:-}" ] && [ $(( ${capacity[3]} - ${capacity[2]} )) -gt 2 ] \
245-
&& is_charging && [ $(( $(cat $batt/capacity) ${capacity[4]} )) -lt ${capacity[3]} ] \
246-
&& [ $(( $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) / 10 )) -lt ${temperature[1]} ]
250+
while [ -n "${cooldownRatio[0]-}" -o -n "${cooldownCurrent[0]-}" ] && is_charging \
251+
&& [ $(( $(cat $batt/capacity) ${capacity[4]} )) -lt ${capacity[3]} ]
247252
do
248-
cooldown=true
249-
if [ $(( $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) / 10 )) -ge ${temperature[0]} ] \
250-
|| [ $(( $(cat $batt/capacity) ${capacity[4]} )) -ge ${capacity[1]} ]
253+
if [ $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) -ge $(( ${temperature[0]} * 10 )) ] \
254+
|| [ $(( $(cat $batt/capacity) ${capacity[4]} )) -ge ${capacity[1]} ] \
255+
|| [ $(cat ${cooldownCurrent[0]:-cooldownCurrent} 2>/dev/null || echo 0) -ge ${cooldownCurrent[1]:-1} ]
251256
then
257+
cooldown=true
252258
dumpsys battery set status $chgStatusCode || : # to block unwanted display wakeups
253259
disable_charging
254-
sleep ${cooldownRatio[1]:-1}
260+
[ $(cat ${cooldownCurrent[0]:-cooldownCurrent} 2>/dev/null || echo 0) -ge ${cooldownCurrent[1]:-1} ] \
261+
&& sleep ${cooldownCurrent[3]:-1} \
262+
|| sleep ${cooldownRatio[1]:-1}
255263
enable_charging
256-
${capacity[5]} || dumpsys battery reset || :
264+
${capacity[5]} || dumpsys battery reset || : # ${capacity[5]} == capacity_sync
265+
! [ $(cat ${cooldownCurrent[0]:-cooldownCurrent} 2>/dev/null || echo 0) -ge ${cooldownCurrent[1]:-1} ] \
266+
|| cooldownRatio[0]=${cooldownCurrent[2]-}
257267
count=0
258268
while ! grep -Eiq 'dis|not' $batt/status \
259269
&& [ $count -lt ${cooldownRatio[0]:-1} ]
260270
do
261271
sleep ${loopDelay[0]}
262272
[ $(( $(cat $batt/capacity) ${capacity[4]} )) -lt ${capacity[3]} ] \
263-
&& [ $(( $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) / 10 )) -lt ${temperature[1]} ] \
264-
&& count=$(( count + ${loopDelay[0]} )) || break
273+
&& count=$(( count + ${loopDelay[0]} )) \
274+
|| break
265275
done
266276
else
267277
break
@@ -270,23 +280,26 @@ ctrl_charging() {
270280
cooldown=false
271281
fi
272282

273-
else
283+
sleep ${loopDelay[0]}
274284

275-
sleep ${loopDelay[1]}
285+
else
276286

277287
# enable charging under <conditions>
278288
if [ $(( $(cat $batt/capacity) ${capacity[4]} )) -le ${capacity[2]} ] \
279-
&& [ $(( $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) / 10 )) -lt ${temperature[1]} ]
289+
&& [ $(cat $batt/temp 2>/dev/null || cat $batt/batt_temp) -lt $(( ${temperature[1]} * 10 )) ]
280290
then
281291
enable_charging
282292
fi
283293

284-
# auto-shutdown if battery is not charging and capacity is less than <shutdownCapacity>
294+
# auto-shutdown if battery is not charging and capacity is less than <shutdown_capacity>
285295
if ! is_charging && [ $(( $(cat $batt/capacity) ${capacity[4]} )) -le ${capacity[0]} ]; then
286296
sleep ${loopDelay[1]}
287297
is_charging \
288298
|| am start -n android/com.android.internal.app.ShutdownActivity 2>/dev/null || reboot -p || :
289299
fi
300+
301+
sleep ${loopDelay[1]}
302+
290303
fi
291304
done
292305
}
@@ -312,7 +325,9 @@ modPath=/sbin/.acc/acc
312325
export TMPDIR=${modPath%/*}
313326
forcedChargingStatusFullAt100=false
314327
config=/data/adb/acc-data/config.txt
315-
[ -f $TMPDIR/.ghost-charging ] && ghostCharging=true || ghostCharging=false
328+
329+
[ -f $TMPDIR/.ghost-charging ] \
330+
&& ghostCharging=true || ghostCharging=false
316331

317332

318333
. $modPath/setup-busybox.sh

0 commit comments

Comments
 (0)