Back to Zephyr

Fuel Gauge

doc/hardware/peripherals/fuel_gauge.rst

4.4.01.4 KB
Original Source

.. _fuel_gauge_api:

Fuel Gauge ##########

The fuel gauge subsystem exposes an API to uniformly access battery fuel gauge devices.

Basic Operation


Properties

Fundamentally, a property is a quantity that a fuel gauge device can measure.

Fuel gauges typically support multiple properties, such as temperature readings of the battery-pack or present-time current/voltage.

Properties are fetched by the client one at a time using :c:func:fuel_gauge_get_prop, or fetched in a batch using :c:func:fuel_gauge_get_props. Buffer properties, e.g. device name, are fetched by using :c:func:fuel_gauge_get_buffer_prop.

Properties are set by the client one at a time using :c:func:fuel_gauge_set_prop, or set in a batch using :c:func:fuel_gauge_set_props.

Battery Cutoff

Many fuel gauges embedded within battery packs expose a register address that when written to with a specific payload will do a battery cutoff. This battery cutoff is often referred to as ship, shelf, or sleep mode due to its utility in reducing battery drain while devices are stored or shipped.

The fuel gauge API exposes battery cutoff with the :c:func:fuel_gauge_battery_cutoff function.

Caching

The Fuel Gauge API explicitly provides no caching for its clients.

.. _fuel_gauge_api_reference:

API Reference


.. doxygengroup:: fuel_gauge_interface .. doxygengroup:: fuel_gauge_emulator_backend