flipperzero-firmware/firmware/targets/furi_hal_include/furi_hal_power.h

210 lines
4.5 KiB
C
Raw Normal View History

/**
* @file furi_hal_power.h
* Power HAL API
*/
#pragma once
#include <stdint.h>
#include <stdbool.h>
#include <m-string.h>
#ifdef __cplusplus
extern "C" {
#endif
/** Power IC type */
2020-12-22 18:16:32 +00:00
typedef enum {
2021-08-08 18:03:25 +00:00
FuriHalPowerICCharger,
FuriHalPowerICFuelGauge,
} FuriHalPowerIC;
2020-12-22 18:16:32 +00:00
/** Initialize drivers */
2021-08-08 18:03:25 +00:00
void furi_hal_power_init();
/** Check if gauge is ok
*
* Verifies that:
* - gauge is alive
* - correct profile loaded
* - self diagnostic status is good
*
* @return true if gauge is ok
*/
bool furi_hal_power_gauge_is_ok();
/** Get current insomnia level
*
* @return insomnia level: 0 - no insomnia, >0 - insomnia, bearer count.
*/
2021-08-08 18:03:25 +00:00
uint16_t furi_hal_power_insomnia_level();
/** Enter insomnia mode Prevents device from going to sleep
* @warning Internally increases insomnia level Must be paired with
* furi_hal_power_insomnia_exit
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_insomnia_enter();
/** Exit insomnia mode Allow device to go to sleep
* @warning Internally decreases insomnia level. Must be paired with
* furi_hal_power_insomnia_enter
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_insomnia_exit();
/** Check if sleep availble
*
* @return true if available
*/
2021-08-08 18:03:25 +00:00
bool furi_hal_power_sleep_available();
/** Check if deep sleep availble
*
* @return true if available
*/
2021-08-08 18:03:25 +00:00
bool furi_hal_power_deep_sleep_available();
[FL-781] FURI, CLI, stdlib: stdout hooks, integration between subsystems, uniform printf usage (#311) * FURI stdglue: stdout hooks, local and global, ISR safe printf. Uniform newlines for terminal/debug output. Power: prevent sleep while core 2 has not started. * Furi record, stdglue: check mutex allocation * remove unused test * Furi stdglue: buferized output, dynamically allocated state. Furi record: dynamically allocated state. Input dump: proper line ending. Hal VCP: dynamically allocated state. * Interrupt manager: explicitly init list. * Makefile: cleanup rules, fix broken dfu upload. F4: add compiler stack protection options. * BLE: call debug uart callback on transmission complete * FreeRTOS: add configUSE_NEWLIB_REENTRANT * API HAL Timebase: fix issue with idle thread stack corruption caused by systick interrupt. BT: cleanup debug info output. FreeRTOS: disable reentry for newlib. * F4: update stack protection CFLAGS to match used compiller * F4: disable compiller stack protection because of incompatibility with current compiller * Makefile: return openocd logs to gdb * BLE: fixed pin, moar power, ble trace info. * Prevent sleep when connection is active * Makefile: return serial port to upload rule, add workaround for mac os * Furi: prevent usage of stack for cmsis functions. * F4: add missing includes, add debugger breakpoints * Applications: per app stack size. * Furi: honor kernel state in stdglue * FreeRTOS: remove unused hooks * Cleanup and format sources Co-authored-by: DrZlo13 <who.just.the.doctor@gmail.com>
2021-01-29 00:09:33 +00:00
/** Go to sleep
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_sleep();
/** Get predicted remaining battery capacity in percents
*
* @return remaining battery capacity in percents
*/
2021-08-08 18:03:25 +00:00
uint8_t furi_hal_power_get_pct();
/** Get battery health state in percents
*
* @return health in percents
*/
2021-08-08 18:03:25 +00:00
uint8_t furi_hal_power_get_bat_health_pct();
/** Get charging status
*
* @return true if charging
*/
2021-08-08 18:03:25 +00:00
bool furi_hal_power_is_charging();
/** Poweroff device
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_off();
/** Reset device
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_reset();
/** OTG enable
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_enable_otg();
/** OTG disable
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_disable_otg();
/** Check OTG status and disable it if falt happened
*/
void furi_hal_power_check_otg_status();
/** Get OTG status
*
* @return true if enabled
*/
bool furi_hal_power_is_otg_enabled();
/** Get remaining battery battery capacity in mAh
*
* @return capacity in mAh
*/
2021-08-08 18:03:25 +00:00
uint32_t furi_hal_power_get_battery_remaining_capacity();
2020-12-22 18:16:32 +00:00
/** Get full charge battery capacity in mAh
*
* @return capacity in mAh
*/
2021-08-08 18:03:25 +00:00
uint32_t furi_hal_power_get_battery_full_capacity();
2020-12-22 18:16:32 +00:00
/** Get battery capacity in mAh from battery profile
*
* @return capacity in mAh
*/
uint32_t furi_hal_power_get_battery_design_capacity();
/** Get battery voltage in V
*
* @param ic FuriHalPowerIc to get measurment
*
* @return voltage in V
*/
2021-08-08 18:03:25 +00:00
float furi_hal_power_get_battery_voltage(FuriHalPowerIC ic);
/** Get battery current in A
*
* @param ic FuriHalPowerIc to get measurment
*
* @return current in A
*/
2021-08-08 18:03:25 +00:00
float furi_hal_power_get_battery_current(FuriHalPowerIC ic);
/** Get temperature in C
*
* @param ic FuriHalPowerIc to get measurment
*
* @return temperature in C
*/
2021-08-08 18:03:25 +00:00
float furi_hal_power_get_battery_temperature(FuriHalPowerIC ic);
2020-12-22 18:16:32 +00:00
/** Get System voltage in V
*
* @return voltage in V
*/
2021-08-08 18:03:25 +00:00
float furi_hal_power_get_system_voltage();
2020-12-22 18:16:32 +00:00
/** Get USB voltage in V
*
* @return voltage in V
*/
2021-08-08 18:03:25 +00:00
float furi_hal_power_get_usb_voltage();
2020-12-18 18:03:28 +00:00
/** Get power system component state
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_dump_state();
/** Enable 3.3v on external gpio and sd card
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_enable_external_3_3v();
/** Disable 3.3v on external gpio and sd card
*/
2021-08-08 18:03:25 +00:00
void furi_hal_power_disable_external_3_3v();
/** Enter supress charge mode.
*
* Use this function when your application need clean power supply.
*/
void furi_hal_power_suppress_charge_enter();
/** Exit supress charge mode
*/
void furi_hal_power_suppress_charge_exit();
/** Callback type called by furi_hal_power_info_get every time another key-value pair of information is ready
*
* @param key[in] power information type identifier
* @param value[in] power information value
* @param last[in] whether the passed key-value pair is the last one
* @param context[in] to pass to callback
*/
typedef void (
*FuriHalPowerInfoCallback)(const char* key, const char* value, bool last, void* context);
/** Get power information
*
* @param[in] callback callback to provide with new data
* @param[in] context context to pass to callback
*/
void furi_hal_power_info_get(FuriHalPowerInfoCallback callback, void* context);
#ifdef __cplusplus
}
#endif