Lines Matching +full:fuel +full:- +full:gauge

5  * SPDX-License-Identifier: Apache-2.0
12 * @brief Fuel Gauge Interface
13 * @defgroup fuel_gauge_interface Fuel Gauge Interface
41 /** Used to cutoff the battery from the system - useful for storage/shipping of devices */
45 /** Whether the battery underlying the fuel-gauge is cut off from charge */
65 /** Absolute state of charge (percent, 0-100) - expressed as % of design capacity */
67 /** Relative state of charge (percent, 0-100) - expressed as % of full charge capacity */
104 /** Reserved to demark end of common fuel gauge properties */
107 * Reserved to demark downstream custom properties - use this value as the actual value may
241 * Note: Historically this API allowed drivers to implement a custom multi-get/set property
253 * @brief Fetch a battery fuel-gauge property
255 * @param dev Pointer to the battery fuel-gauge device
258 * fuel gauge device.
267 const struct fuel_gauge_driver_api *api = (const struct fuel_gauge_driver_api *)dev->api; in z_impl_fuel_gauge_get_prop()
269 if (api->get_property == NULL) { in z_impl_fuel_gauge_get_prop()
270 return -ENOSYS; in z_impl_fuel_gauge_get_prop()
273 return api->get_property(dev, prop, val); in z_impl_fuel_gauge_get_prop()
277 * @brief Fetch multiple battery fuel-gauge properties. The default implementation is the same as
279 * of the fuel gauge driver APIs struct to override this implementation.
281 * @param dev Pointer to the battery fuel-gauge device
285 * the fuel gauge device. The vals array is not permuted.
297 const struct fuel_gauge_driver_api *api = (const struct fuel_gauge_driver_api *)dev->api; in z_impl_fuel_gauge_get_props()
300 int ret = api->get_property(dev, props[i], vals + i); in z_impl_fuel_gauge_get_props()
311 * @brief Set a battery fuel-gauge property
313 * @param dev Pointer to the battery fuel-gauge device
325 const struct fuel_gauge_driver_api *api = (const struct fuel_gauge_driver_api *)dev->api; in z_impl_fuel_gauge_set_prop()
327 if (api->set_property == NULL) { in z_impl_fuel_gauge_set_prop()
328 return -ENOSYS; in z_impl_fuel_gauge_set_prop()
331 return api->set_property(dev, prop, val); in z_impl_fuel_gauge_set_prop()
334 * @brief Set a battery fuel-gauge property
336 * @param dev Pointer to the battery fuel-gauge device
340 * the fuel gauge device. The vals array is not permuted.
364 * @brief Fetch a battery fuel-gauge buffer property
366 * @param dev Pointer to the battery fuel-gauge device
368 * @param dst byte array or struct that will hold the buffer data that is read from the fuel gauge
381 const struct fuel_gauge_driver_api *api = (const struct fuel_gauge_driver_api *)dev->api; in z_impl_fuel_gauge_get_buffer_prop()
383 if (api->get_buffer_property == NULL) { in z_impl_fuel_gauge_get_buffer_prop()
384 return -ENOSYS; in z_impl_fuel_gauge_get_buffer_prop()
387 return api->get_buffer_property(dev, prop_type, dst, dst_len); in z_impl_fuel_gauge_get_buffer_prop()
391 * @brief Have fuel gauge cutoff its associated battery.
393 * @param dev Pointer to the battery fuel-gauge device
402 const struct fuel_gauge_driver_api *api = (const struct fuel_gauge_driver_api *)dev->api; in z_impl_fuel_gauge_battery_cutoff()
404 if (api->battery_cutoff == NULL) { in z_impl_fuel_gauge_battery_cutoff()
405 return -ENOSYS; in z_impl_fuel_gauge_battery_cutoff()
408 return api->battery_cutoff(dev); in z_impl_fuel_gauge_battery_cutoff()