12#ifndef ZEPHYR_INCLUDE_DRIVERS_CHARGER_H_
13#define ZEPHYR_INCLUDE_DRIVERS_CHARGER_H_
393static inline int z_impl_charger_charge_enable(
const struct device *dev,
const bool enable)
408#include <syscalls/charger.h>
int charger_set_prop(const struct device *dev, const charger_prop_t prop, const union charger_propval *val)
Set a battery charger property.
int charger_get_prop(const struct device *dev, const charger_prop_t prop, union charger_propval *val)
Fetch a battery charger property.
int(* charger_get_property_t)(const struct device *dev, const charger_prop_t prop, union charger_propval *val)
Callback API for getting a charger property.
Definition: charger.h:308
charger_notification_severity
Charger severity levels for system notifications.
Definition: charger.h:224
int(* charger_set_property_t)(const struct device *dev, const charger_prop_t prop, const union charger_propval *val)
Callback API for setting a charger property.
Definition: charger.h:317
charger_status
Charging states.
Definition: charger.h:138
int(* charger_charge_enable_t)(const struct device *dev, const bool enable)
Callback API enabling or disabling a charge cycle.
Definition: charger.h:326
charger_property
Runtime Dynamic Battery Parameters.
Definition: charger.h:35
void(* charger_status_notifier_t)(enum charger_status status)
The charger status change callback to notify the system.
Definition: charger.h:250
charger_health
Charger health conditions.
Definition: charger.h:189
void(* charger_online_notifier_t)(enum charger_online online)
The charger online change callback to notify the system.
Definition: charger.h:257
int charger_charge_enable(const struct device *dev, const bool enable)
Enable or disable a charge cycle.
uint16_t charger_prop_t
A charger property's identifier.
Definition: charger.h:121
charger_online
External supply states.
Definition: charger.h:126
charger_charge_type
Charge algorithm types.
Definition: charger.h:154
@ CHARGER_SEVERITY_WARNING
Base severity level.
Definition: charger.h:230
@ CHARGER_SEVERITY_PEAK
Most severe level, typically triggered instantaneously.
Definition: charger.h:226
@ CHARGER_SEVERITY_CRITICAL
More severe than the warning level, less severe than peak.
Definition: charger.h:228
@ CHARGER_STATUS_FULL
The battery is full and the charging device will not attempt charging.
Definition: charger.h:148
@ CHARGER_STATUS_NOT_CHARGING
Charging device is not charging a battery.
Definition: charger.h:146
@ CHARGER_STATUS_DISCHARGING
Charging device is not able to charge a battery.
Definition: charger.h:144
@ CHARGER_STATUS_UNKNOWN
Charging device state is unknown.
Definition: charger.h:140
@ CHARGER_STATUS_CHARGING
Charging device is charging a battery.
Definition: charger.h:142
@ CHARGER_PROP_PRESENT
Reports whether or not a battery is present.
Definition: charger.h:41
@ CHARGER_PROP_ONLINE
Indicates if external supply is present for the charger.
Definition: charger.h:38
@ CHARGER_PROP_INPUT_REGULATION_VOLTAGE_UV
Configuration of the input voltage regulation target in µV.
Definition: charger.h:72
@ CHARGER_PROP_CUSTOM_BEGIN
Reserved to demark downstream custom properties - use this value as the actual value may change over ...
Definition: charger.h:110
@ CHARGER_PROP_HEALTH
Represents the health of the charger.
Definition: charger.h:50
@ CHARGER_PROP_ONLINE_NOTIFICATION
Configuration to issue a notification to the system based on the charger online change.
Definition: charger.h:103
@ CHARGER_PROP_COMMON_COUNT
Reserved to demark end of common charger properties.
Definition: charger.h:105
@ CHARGER_PROP_DISCHARGE_CURRENT_NOTIFICATION
Configuration to issue a notification to the system based on the battery discharge current level and ...
Definition: charger.h:86
@ CHARGER_PROP_CONSTANT_CHARGE_VOLTAGE_UV
Configuration of charge voltage regulation target in µV.
Definition: charger.h:58
@ CHARGER_PROP_INPUT_REGULATION_CURRENT_UA
Configuration of the input current regulation target in µA.
Definition: charger.h:65
@ CHARGER_PROP_INPUT_CURRENT_NOTIFICATION
Configuration to issue a notification to the system based on the input current level and timing.
Definition: charger.h:79
@ CHARGER_PROP_STATUS
Represents the charging status of the charger.
Definition: charger.h:44
@ CHARGER_PROP_CONSTANT_CHARGE_CURRENT_UA
Configuration of current sink used for charging in µA.
Definition: charger.h:52
@ CHARGER_PROP_STATUS_NOTIFICATION
Configuration to issue a notification to the system based on the charger status change.
Definition: charger.h:97
@ CHARGER_PROP_MAX
Reserved to demark end of valid enum properties.
Definition: charger.h:112
@ CHARGER_PROP_PRECHARGE_CURRENT_UA
Configuration of current sink used for conditioning in µA.
Definition: charger.h:54
@ CHARGER_PROP_CHARGE_TERM_CURRENT_UA
Configuration of charge termination target in µA.
Definition: charger.h:56
@ CHARGER_PROP_SYSTEM_VOLTAGE_NOTIFICATION_UV
Configuration of the falling system voltage threshold where a notification is issued to the system,...
Definition: charger.h:91
@ CHARGER_PROP_CHARGE_TYPE
Represents the charging algo type of the charger.
Definition: charger.h:47
@ CHARGER_HEALTH_SAFETY_TIMER_EXPIRE
The charger device's safety timer has expired.
Definition: charger.h:208
@ CHARGER_HEALTH_CALIBRATION_REQUIRED
The charger device requires calibration.
Definition: charger.h:210
@ CHARGER_HEALTH_WARM
The battery temperature is in the "warm" range.
Definition: charger.h:212
@ CHARGER_HEALTH_UNKNOWN
Charger health condition is unknown.
Definition: charger.h:191
@ CHARGER_HEALTH_COLD
The battery temperature is below the "cold" threshold.
Definition: charger.h:204
@ CHARGER_HEALTH_NO_BATTERY
The charger device does not detect a battery.
Definition: charger.h:218
@ CHARGER_HEALTH_UNSPEC_FAILURE
The battery or charger device is experiencing an unspecified failure.
Definition: charger.h:202
@ CHARGER_HEALTH_GOOD
Charger health condition is good.
Definition: charger.h:193
@ CHARGER_HEALTH_HOT
The battery temperature is below the "hot" threshold.
Definition: charger.h:216
@ CHARGER_HEALTH_COOL
The battery temperature is in the "cool" range.
Definition: charger.h:214
@ CHARGER_HEALTH_WATCHDOG_TIMER_EXPIRE
The charger device's watchdog timer has expired.
Definition: charger.h:206
@ CHARGER_HEALTH_OVERVOLTAGE
The battery voltage has exceeded its overvoltage threshold.
Definition: charger.h:197
@ CHARGER_HEALTH_OVERHEAT
The charger device is overheated.
Definition: charger.h:195
@ CHARGER_ONLINE_FIXED
External supply is present and of fixed output.
Definition: charger.h:130
@ CHARGER_ONLINE_PROGRAMMABLE
External supply is present and of programmable output.
Definition: charger.h:132
@ CHARGER_ONLINE_OFFLINE
External supply not present.
Definition: charger.h:128
@ CHARGER_CHARGE_TYPE_STANDARD
Charging is occurring at a moderate charge rate.
Definition: charger.h:167
@ CHARGER_CHARGE_TYPE_NONE
Charging is not occurring.
Definition: charger.h:158
@ CHARGER_CHARGE_TYPE_ADAPTIVE
Definition: charger.h:171
@ CHARGER_CHARGE_TYPE_UNKNOWN
Charge type is unknown.
Definition: charger.h:156
@ CHARGER_CHARGE_TYPE_BYPASS
Definition: charger.h:181
@ CHARGER_CHARGE_TYPE_LONGLIFE
Definition: charger.h:176
@ CHARGER_CHARGE_TYPE_TRICKLE
Charging is occurring at the slowest desired charge rate, typically for battery detection or precondi...
Definition: charger.h:163
@ CHARGER_CHARGE_TYPE_FAST
Charging is occurring at the fastest desired charge rate.
Definition: charger.h:165
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
#define UINT16_MAX
Definition: stdint.h:28
__UINT16_TYPE__ uint16_t
Definition: stdint.h:89
The input current thresholds for the charger to notify the system.
Definition: charger.h:236
uint8_t severity
The severity of the notification where CHARGER_SEVERITY_PEAK is the most severe.
Definition: charger.h:238
uint32_t duration_us
The duration of excess current before notifying the system.
Definition: charger.h:242
uint32_t current_ua
The current threshold to be exceeded.
Definition: charger.h:240
Charging device API.
Definition: charger.h:333
charger_charge_enable_t charge_enable
Definition: charger.h:336
charger_set_property_t set_property
Definition: charger.h:335
charger_get_property_t get_property
Definition: charger.h:334
Runtime device structure (in ROM) per driver instance.
Definition: device.h:399
const void * api
Address of the API structure exposed by the device instance.
Definition: device.h:405
container for a charger_property value
Definition: charger.h:263
struct charger_current_notifier input_current_notification
CHARGER_PROP_INPUT_CURRENT_NOTIFICATION.
Definition: charger.h:291
uint32_t precharge_current_ua
CHARGER_PROP_PRECHARGE_CURRENT_UA.
Definition: charger.h:281
uint32_t system_voltage_notification
CHARGER_PROP_SYSTEM_VOLTAGE_NOTIFICATION_UV.
Definition: charger.h:295
uint32_t const_charge_voltage_uv
CHARGER_PROP_CONSTANT_CHARGE_VOLTAGE_UV.
Definition: charger.h:285
enum charger_status status
CHARGER_PROP_STATUS.
Definition: charger.h:273
enum charger_online online
CHARGER_PROP_ONLINE.
Definition: charger.h:269
uint32_t charge_term_current_ua
CHARGER_PROP_CHARGE_TERM_CURRENT_UA.
Definition: charger.h:283
bool present
CHARGER_PROP_PRESENT.
Definition: charger.h:271
charger_online_notifier_t online_notification
CHARGER_PROP_ONLINE_NOTIFICATION.
Definition: charger.h:299
enum charger_health health
CHARGER_PROP_HEALTH.
Definition: charger.h:277
enum charger_charge_type charge_type
CHARGER_PROP_CHARGE_TYPE.
Definition: charger.h:275
charger_status_notifier_t status_notification
CHARGER_PROP_STATUS_NOTIFICATION.
Definition: charger.h:297
uint32_t input_current_regulation_current_ua
CHARGER_PROP_INPUT_REGULATION_CURRENT_UA.
Definition: charger.h:287
struct charger_current_notifier discharge_current_notification
CHARGER_PROP_DISCHARGE_CURRENT_NOTIFICATION.
Definition: charger.h:293
uint32_t const_charge_current_ua
CHARGER_PROP_CONSTANT_CHARGE_CURRENT_UA.
Definition: charger.h:279
uint32_t input_voltage_regulation_voltage_uv
CHARGER_PROP_INPUT_REGULATION_VOLTAGE_UV.
Definition: charger.h:289