Page MenuHomeFreeBSD

acpi_battery: avoid divide-by-zero when no devices have capacity info
ClosedPublic

Authored by jeffpc_josefsipek.net on Apr 16 2024, 10:34 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Dec 31, 2:25 PM
Unknown Object (File)
Dec 6 2024, 3:14 PM
Unknown Object (File)
Dec 6 2024, 1:23 PM
Unknown Object (File)
Nov 27 2024, 8:43 AM
Unknown Object (File)
Nov 27 2024, 8:28 AM
Unknown Object (File)
Nov 25 2024, 10:05 PM
Unknown Object (File)
Nov 25 2024, 5:39 PM
Unknown Object (File)
Nov 25 2024, 5:27 AM
Subscribers

Details

Summary

On laptops with builtin batteries, disconnecting the battery may show up as
a battery without any capacity information. (The theory is that one is
disconnecting the cells but the electronics identifying the battery are
still connected.) As a result, the loop over all batteries in
acpi_battery_get_battinfo results in total_lfcap == 0.

So, just check that total_lfcap is non-zero to avoid a division by zero
(triggerable by sysctl hw.acpi.battery).

Reported/tested by: Stefano Marinelli

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 57136
Build 54024: arc lint + arc unit

Event Timeline

sys/dev/acpica/acpi_battery.c
273

style(9) asks to avoid using non-booleans in a boolean context, so total_lfcap != 0 -- but then, we probably want total_lfcap > 0 since -ve values don't make sense. I'd also suggest an if-else like just above for valid_rate rather than the ternary op.

This revision is now accepted and ready to land.Apr 16 2024, 11:00 PM