unleashed-firmware/applications/services/power/power_service/power.h
2023-04-21 15:55:06 +03:00

105 lines
2 KiB
C

#pragma once
#include <stdint.h>
#include <core/pubsub.h>
#include <stdbool.h>
#ifdef __cplusplus
extern "C" {
#endif
#define RECORD_POWER "power"
typedef struct Power Power;
typedef enum {
PowerBootModeNormal,
PowerBootModeDfu,
PowerBootModeUpdateStart,
} PowerBootMode;
typedef enum {
PowerEventTypeStopCharging,
PowerEventTypeStartCharging,
PowerEventTypeFullyCharged,
PowerEventTypeBatteryLevelChanged,
} PowerEventType;
typedef union {
uint8_t battery_level;
} PowerEventData;
typedef struct {
PowerEventType type;
PowerEventData data;
} PowerEvent;
typedef struct {
bool gauge_is_ok;
bool is_charging;
float current_charger;
float current_gauge;
float voltage_battery_charge_limit;
float voltage_charger;
float voltage_gauge;
float voltage_vbus;
uint32_t capacity_remaining;
uint32_t capacity_full;
float temperature_charger;
float temperature_gauge;
uint8_t charge;
uint8_t health;
} PowerInfo;
/** Power off device
*/
void power_off(Power* power);
/** Reboot device
*
* @param mode PowerBootMode
*/
void power_reboot(PowerBootMode mode);
/** Get power info
*
* @param power Power instance
* @param info PowerInfo instance
*/
void power_get_info(Power* power, PowerInfo* info);
/** Get power event pubsub handler
*
* @param power Power instance
*
* @return FuriPubSub instance
*/
FuriPubSub* power_get_pubsub(Power* power);
/** Check battery health
*
* @return true if battery is healthy
*/
bool power_is_battery_healthy(Power* power);
/** Enable or disable battery low level notification message
*
* @param power Power instance
* @param enable true - enable, false - disable
*/
void power_enable_low_battery_level_notification(Power* power, bool enable);
/** Trigger UI update for changing battery layout
*
* @param power Power instance
*/
void power_trigger_ui_update(Power* power);
#ifdef __cplusplus
}
#endif