embedded-batteries

Crates.ioembedded-batteries
lib.rsembedded-batteries
version0.2.1
created_at2025-05-19 16:29:25.087201+00
updated_at2025-07-31 21:26:15.506082+00
descriptionA blocking Hardware Abstraction Layer (HAL) for battery fuel gauges and battery chargers used in embedded systems.
homepage
repositoryhttps://github.com/OpenDevicePartnership/embedded-batteries
max_upload_size
id1679998
size100,890
Matteo Tullo (tullom)

documentation

README

embedded-batteries

A blocking Hardware Abstraction Layer (HAL) for battery fuel gauges and battery chargers used in embedded systems.

Intro

This library is a set of traits designed to standardize interactions with battery systems in portable electronics. It follows the Smart Battery System specification to define generic functions that all battery chargers and all smart batteries (AKA fuel gauge, gas gauge) must implement to enforce a standard interface.

Additionally, the ACPI Specification's Power Source and Power Meter Devices battery control messages are defined as an supplementary superset of the Smart Battery specification, for users building systems compliant with ACPI.

Design Principles

Generic Design Diagram

    classDiagram
        Application Level Task --> ChargerDriver: non-std calls (ex. MFG)
        Application Level Task --> SmartBatteryDriver: non-std calls (ex. MFG)
        Application Level Task: -> charging FSMs
        Application Level Task: -> monitoring state of charge
        Application Level Task: -> calls std and non-std fn's
        Application Level Task: +do_startup()
        Application Level Task: +enable_autocharging()
        Application Level Task: +get_cell_voltages()
        Application Level Task: +...()
        Application Level Task --> embedded-batteries-charger: std calls
        Application Level Task --> embedded-batteries-smart-battery: std calls
        embedded-batteries-smart-battery <|-- SmartBatteryDriver: implements
        embedded-batteries-charger <|-- ChargerDriver: implements
        embedded-batteries-charger: -> Platform/HW agnostic charger fn's
        embedded-batteries-charger: -> Conforms to SBS spec
        embedded-batteries-charger: +charging_current()
        embedded-batteries-charger: +charging_voltage()
        embedded-batteries-smart-battery: -> Platform/HW agnostic fuel gauge fn's
        embedded-batteries-smart-battery: -> Conforms to SBS spec
        embedded-batteries-smart-battery: +voltage()
        embedded-batteries-smart-battery: +current()
        embedded-batteries-smart-battery: +battery_status()
        embedded-batteries-smart-battery: +temperature()
        embedded-batteries-smart-battery: +cycle_count()
        embedded-batteries-smart-battery: +...()
        <<interface>> embedded-batteries-charger
        <<interface>> embedded-batteries-smart-battery
        ChargerDriver --> platform-specific-hal
        ChargerDriver: -> Specific to charging chip
        ChargerDriver: -> Conforms to chip datasheet
        ChargerDriver: -> has non-std MFG specific fn's
        ChargerDriver: +[std] charging_current()
        ChargerDriver: +[std] charging_voltage()
        ChargerDriver: +[non-std] auto_charge()
        ChargerDriver: +[non-std] ...()
        SmartBatteryDriver --> platform-specific-hal
        SmartBatteryDriver: -> Specific to charging chip
        SmartBatteryDriver: -> Conforms to chip datasheet
        SmartBatteryDriver: -> has non-std MFG specific fn's
        SmartBatteryDriver: +[std] voltage()
        SmartBatteryDriver: +[std] current()
        SmartBatteryDriver: +[std] battery_status()
        SmartBatteryDriver: +[std] ...()
        SmartBatteryDriver: +[non-std] unseal()
        SmartBatteryDriver: +[non-std] ...()
        class platform-specific-hal["platform-specific-hal comm system"]
        platform-specific-hal: -> communication system agnostic
        platform-specific-hal: -> can be uC, kernel driver, etc.
        platform-specific-hal: +read_word()
        platform-specific-hal: +write_word()
        platform-specific-hal: +...()

Specific Example Design

    classDiagram
        class battery-service["battery-service"]
        click battery-service href "https://github.com/OpenDevicePartnership/embedded-services"
        battery-service --> BQ25773: non-std calls (ex. MFG)
        battery-service --> BQ40Z50: non-std calls (ex. MFG)
        battery-service: +do_startup()
        battery-service: +enable_autocharging()
        battery-service: +get_cell_voltages()
        battery-service: +...()
        battery-service --> embedded-batteries-charger: std calls
        battery-service --> embedded-batteries-smart-battery: std calls
        embedded-batteries-smart-battery <|-- BQ40Z50: implements
        embedded-batteries-charger <|-- BQ25773: implements
        embedded-batteries-charger: +charging_current()
        embedded-batteries-charger: +charging_voltage()
        embedded-batteries-smart-battery: +voltage()
        embedded-batteries-smart-battery: +current()
        embedded-batteries-smart-battery: +battery_status()
        embedded-batteries-smart-battery: +temperature()
        embedded-batteries-smart-battery: +cycle_count()
        embedded-batteries-smart-battery: +...()
        <<interface>> embedded-batteries-charger
        <<interface>> embedded-batteries-smart-battery
        class BQ25773["BQ25773"]
        click BQ25773 href "https://github.com/OpenDevicePartnership/bq25773"
        BQ25773 --> platform-specific-hal
        BQ25773: +[std] charging_current()
        BQ25773: +[std] charging_voltage()
        BQ25773: +[non-std] auto_charge()
        BQ25773: +[non-std] ...()
        class BQ40Z50["BQ40Z50"]
        click BQ40Z50 href "https://github.com/OpenDevicePartnership/bq40z50"
        BQ40Z50 --> platform-specific-hal
        BQ40Z50: +[std] voltage()
        BQ40Z50: +[std] current()
        BQ40Z50: +[std] battery_status()
        BQ40Z50: +[std] ...()
        BQ40Z50: +[non-std] unseal()
        BQ40Z50: +[non-std] ...()
        class platform-specific-hal["embassy-imxrt I2C driver"]
        click platform-specific-hal href "https://github.com/OpenDevicePartnership/embassy-imxrt"
        platform-specific-hal: +read()
        platform-specific-hal: +write()

Assumptions + Deviations from spec

As there is such a wide range of battery chargers and smart batteries, as well as different ways to electrically connect your smart battery system, a guiding principle of embedded-batteries is to make as little assumptions as possible. The SBS spec, which is the basis of the traits, is used as a guide rather than a strict constraint. Some common deviations and their solutions are listed below:

Chargers and Fuel Gauges partially/not implementing the SBS spec

Charger and smart battery driver authors are given the flexibility on how their driver implements each SBS function. For example, if the smart battery does not have thermistors onboard, a Result with an "not implemented" error can be returned. Application level code must be able to handle the error accordingly.

Smart Battery acting as a master

The SBS spec defines that the smart battery should be able to take control of the communication bus and broadcast alert messages. This functionality requires implementation of bus arbitration and as such, is not planned to be supported.

Spec Coverage

Charger

For detailed descriptions on how to use each function, please refer to the Smart Battery System spec.

Functions Code Access Data Implemented
charging_current 0x14 w mA (u16)
charging_voltage 0x15 w mV (u16)

Fuel Gauge

For detailed descriptions on how to use each function, please refer to the Smart Battery System spec.

Functions Code Access Data Implemented
manufacturer_access* 0x00 r/w word -
remaining_capacity_alarm 0x01 r/w mAh or 10mWh
remaining_time_alarm 0x02 r/w minutes
battery_mode 0x03 r bit flags
at_rate 0x04 r/w mA or 10mW
at_rate_time_to_full 0x05 r minutes
at_rate_time_to_empty 0x06 r minutes
at_rate_ok 0x07 r Boolean
temperature 0x08 r 0.1°K
voltage 0x09 r mV
current 0x0a r mA
average_current 0x0b r mA
max_error 0x0c r percent
relative_state_of_charge 0x0d r percent
absolute_state_of_charge 0x0e r percent
remaining_capacity 0x0f r mAh or 10mWh
full_charge_capacity 0x10 r mAh or 10mWh
run_time_to_empty 0x11 r minutes
average_time_to_empty 0x12 r minutes
average_time_to_full 0x13 r minutes
charging_current 0x14 r mA
charging_voltage 0x15 r mV
battery_status 0x16 r bit flags
cycle_count 0x17 r count
design_capacity 0x18 r mAh or 10mWh
design_voltage 0x19 r mV
specification_info 0x1a r unsigned int
manufacture_date 0x1b r unsigned int
serial_number 0x1c r number
reserved 0x1d - 0x1f -
manufacturer_name 0x20 r string
device_name 0x21 r string
device_chemistry 0x22 r string
manufacturer_data* 0x23 r data -
reserved 0x25 - 0x2e -
optional_mfg_function_5* 0x2f r/w data -
reserved 0x30 - 0x3b -
optional_mfg_function_4* 0x3c r/w word -
optional_mfg_function_3_1* 0x3d - 0x3f r/w word -

* refers to optional fn's that will not be implemented

ACPI Battery Control Methods

For detailed descriptions on how to use each method, please refer to the ACPI specification.

Table 10.1 Battery Control Methods

Object Description Implemented
_BCT Returns battery estimated charging time.
_BIF Returns static information about a battery (in other words, model number, serial number, design voltage, and so on).
_BIX Returns extended static information about a battery (in other words, model number, serial number, design voltage, and so on).
_BMA Sets the averaging interval of the battery capacity measurement, in milliseconds.
_BMC Control calibration and charging.
_BMD Returns battery information related to battery recalibration and charging control.
_BMS Sets the sampling time of the battery capacity measurement, in milliseconds.
_BPC Returns static variables that are associated with system power characteristics on the battery path and power threshold support settings.
_BPS Returns the power delivery capabilities of the battery at the present time.
_BPT Control method to set a Battery Power Threshold.
_BST Returns the current battery status (in other words, dynamic information about the battery, such as whether the battery is currently charging or discharging, an estimate of the remaining battery capacity, and so on).
_BTH Communicates battery thermal throttle limit set by battery thermal zone.
_BTM Returns battery estimated runtime at the present average rate of drain, or the runtime at a specified rate.
_BTP Sets the Battery Trip point, which generates an SCI when battery capacity reaches the specified point.
_OSC OSPM Capabilities conveyance for batteries.
_PSR Returns whether this power source device is currently online.
_PIF Returns static information about a power source.
Commit count: 43

cargo fmt