2021-10-03 10:36:05 +00:00
|
|
|
/**
|
2022-01-05 16:10:18 +00:00
|
|
|
* @file furi_hal_power.h
|
2021-10-03 10:36:05 +00:00
|
|
|
* Power HAL API
|
|
|
|
*/
|
|
|
|
|
2020-11-11 06:31:35 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
2022-11-29 09:08:08 +00:00
|
|
|
#include <core/string.h>
|
2024-03-19 14:43:52 +00:00
|
|
|
#include <core/common_defines.h>
|
2022-11-29 09:08:08 +00:00
|
|
|
#include <toolbox/property.h>
|
2020-12-02 10:47:13 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2020-11-11 06:31:35 +00:00
|
|
|
|
2021-03-24 09:35:33 +00:00
|
|
|
/** 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
|
|
|
|
2022-04-18 23:09:11 +00:00
|
|
|
/** Initialize drivers */
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_init(void);
|
2020-11-11 06:31:35 +00:00
|
|
|
|
2022-04-18 23:09:11 +00:00
|
|
|
/** Check if gauge is ok
|
|
|
|
*
|
|
|
|
* Verifies that:
|
|
|
|
* - gauge is alive
|
|
|
|
* - correct profile loaded
|
|
|
|
* - self diagnostic status is good
|
|
|
|
*
|
|
|
|
* @return true if gauge is ok
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
bool furi_hal_power_gauge_is_ok(void);
|
2022-04-18 23:09:11 +00:00
|
|
|
|
2023-07-18 10:46:38 +00:00
|
|
|
/** Check if gauge requests system shutdown
|
|
|
|
*
|
|
|
|
* @return true if system shutdown requested
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
bool furi_hal_power_is_shutdown_requested(void);
|
2023-07-18 10:46:38 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get current insomnia level
|
|
|
|
*
|
|
|
|
* @return insomnia level: 0 - no insomnia, >0 - insomnia, bearer count.
|
2021-02-12 17:24:34 +00:00
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
uint16_t furi_hal_power_insomnia_level(void);
|
2021-02-12 17:24:34 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Enter insomnia mode Prevents device from going to sleep
|
|
|
|
* @warning Internally increases insomnia level Must be paired with
|
|
|
|
* furi_hal_power_insomnia_exit
|
2021-02-12 17:24:34 +00:00
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_insomnia_enter(void);
|
2021-02-12 17:24:34 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Exit insomnia mode Allow device to go to sleep
|
|
|
|
* @warning Internally decreases insomnia level. Must be paired with
|
|
|
|
* furi_hal_power_insomnia_enter
|
2021-02-12 17:24:34 +00:00
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_insomnia_exit(void);
|
2021-02-12 17:24:34 +00:00
|
|
|
|
2024-01-29 12:35:46 +00:00
|
|
|
/** Check if sleep available
|
2021-10-03 10:36:05 +00:00
|
|
|
*
|
|
|
|
* @return true if available
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
bool furi_hal_power_sleep_available(void);
|
2021-03-31 17:55:00 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Go to sleep
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_sleep(void);
|
2021-01-20 07:43:12 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get predicted remaining battery capacity in percents
|
|
|
|
*
|
|
|
|
* @return remaining battery capacity in percents
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
uint8_t furi_hal_power_get_pct(void);
|
2020-11-11 06:31:35 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get battery health state in percents
|
|
|
|
*
|
|
|
|
* @return health in percents
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
uint8_t furi_hal_power_get_bat_health_pct(void);
|
2021-03-02 16:07:26 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get charging status
|
|
|
|
*
|
|
|
|
* @return true if charging
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
bool furi_hal_power_is_charging(void);
|
2020-11-11 06:31:35 +00:00
|
|
|
|
2022-09-26 15:34:59 +00:00
|
|
|
/** Get charge complete status
|
|
|
|
*
|
|
|
|
* @return true if done charging and connected to charger
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
bool furi_hal_power_is_charging_done(void);
|
2022-09-26 15:34:59 +00:00
|
|
|
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 13:29:51 +00:00
|
|
|
/** Switch MCU to SHUTDOWN */
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_shutdown(void);
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 13:29:51 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Poweroff device
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_off(void);
|
2020-11-11 06:31:35 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Reset device
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
FURI_NORETURN void furi_hal_power_reset(void);
|
2021-04-30 04:51:48 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** OTG enable
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
bool furi_hal_power_enable_otg(void);
|
2020-11-11 06:31:35 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** OTG disable
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_disable_otg(void);
|
2020-12-02 10:47:13 +00:00
|
|
|
|
2023-07-05 16:48:02 +00:00
|
|
|
/** Check OTG status fault
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
bool furi_hal_power_check_otg_fault(void);
|
2023-07-05 16:48:02 +00:00
|
|
|
|
2022-01-21 16:55:44 +00:00
|
|
|
/** Check OTG status and disable it if falt happened
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_check_otg_status(void);
|
2022-01-21 16:55:44 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get OTG status
|
|
|
|
*
|
|
|
|
* @return true if enabled
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
bool furi_hal_power_is_otg_enabled(void);
|
2021-09-30 20:03:28 +00:00
|
|
|
|
2023-02-26 17:23:39 +00:00
|
|
|
/** Get battery charge voltage limit in V
|
2022-12-08 06:57:49 +00:00
|
|
|
*
|
|
|
|
* @return voltage in V
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
float furi_hal_power_get_battery_charge_voltage_limit(void);
|
2022-12-08 06:57:49 +00:00
|
|
|
|
2023-02-26 17:23:39 +00:00
|
|
|
/** Set battery charge voltage limit in V
|
2022-12-08 06:57:49 +00:00
|
|
|
*
|
2023-02-26 17:23:39 +00:00
|
|
|
* Invalid values will be clamped downward to the nearest valid value.
|
2022-12-08 06:57:49 +00:00
|
|
|
*
|
2024-03-06 06:25:21 +00:00
|
|
|
* @param[in] voltage voltage in V
|
2022-12-08 06:57:49 +00:00
|
|
|
*/
|
2023-02-26 17:23:39 +00:00
|
|
|
void furi_hal_power_set_battery_charge_voltage_limit(float voltage);
|
2022-12-08 06:57:49 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get remaining battery battery capacity in mAh
|
|
|
|
*
|
|
|
|
* @return capacity in mAh
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
uint32_t furi_hal_power_get_battery_remaining_capacity(void);
|
2020-12-22 18:16:32 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get full charge battery capacity in mAh
|
|
|
|
*
|
|
|
|
* @return capacity in mAh
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
uint32_t furi_hal_power_get_battery_full_capacity(void);
|
2020-12-22 18:16:32 +00:00
|
|
|
|
2022-04-07 15:00:45 +00:00
|
|
|
/** Get battery capacity in mAh from battery profile
|
|
|
|
*
|
|
|
|
* @return capacity in mAh
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
uint32_t furi_hal_power_get_battery_design_capacity(void);
|
2022-04-07 15:00:45 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get battery voltage in V
|
|
|
|
*
|
2024-03-06 06:25:21 +00:00
|
|
|
* @param[in] ic FuriHalPowerIc to get measurment
|
2021-10-03 10:36:05 +00:00
|
|
|
*
|
|
|
|
* @return voltage in V
|
|
|
|
*/
|
2021-08-08 18:03:25 +00:00
|
|
|
float furi_hal_power_get_battery_voltage(FuriHalPowerIC ic);
|
2020-12-02 10:47:13 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get battery current in A
|
|
|
|
*
|
2024-03-06 06:25:21 +00:00
|
|
|
* @param[in] ic FuriHalPowerIc to get measurment
|
2021-10-03 10:36:05 +00:00
|
|
|
*
|
|
|
|
* @return current in A
|
|
|
|
*/
|
2021-08-08 18:03:25 +00:00
|
|
|
float furi_hal_power_get_battery_current(FuriHalPowerIC ic);
|
2020-12-02 10:47:13 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get temperature in C
|
|
|
|
*
|
2024-03-06 06:25:21 +00:00
|
|
|
* @param[in] ic FuriHalPowerIc to get measurment
|
2021-10-03 10:36:05 +00:00
|
|
|
*
|
|
|
|
* @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
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get USB voltage in V
|
|
|
|
*
|
|
|
|
* @return voltage in V
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
float furi_hal_power_get_usb_voltage(void);
|
2020-12-18 18:03:28 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Enable 3.3v on external gpio and sd card
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_enable_external_3_3v(void);
|
2021-03-09 11:53:33 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Disable 3.3v on external gpio and sd card
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_disable_external_3_3v(void);
|
2021-03-09 11:53:33 +00:00
|
|
|
|
2021-10-04 07:01:41 +00:00
|
|
|
/** Enter supress charge mode.
|
|
|
|
*
|
|
|
|
* Use this function when your application need clean power supply.
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_suppress_charge_enter(void);
|
2021-10-04 07:01:41 +00:00
|
|
|
|
|
|
|
/** Exit supress charge mode
|
|
|
|
*/
|
2024-03-19 14:43:52 +00:00
|
|
|
void furi_hal_power_suppress_charge_exit(void);
|
2021-10-04 07:01:41 +00:00
|
|
|
|
2022-11-29 09:08:08 +00:00
|
|
|
/** Get power information
|
2022-04-07 15:00:45 +00:00
|
|
|
*
|
2022-11-29 09:08:08 +00:00
|
|
|
* @param[in] callback callback to provide with new data
|
|
|
|
* @param[in] sep category separator character
|
|
|
|
* @param[in] context context to pass to callback
|
2022-04-07 15:00:45 +00:00
|
|
|
*/
|
2022-11-29 09:08:08 +00:00
|
|
|
void furi_hal_power_info_get(PropertyValueCallback callback, char sep, void* context);
|
2022-04-07 15:00:45 +00:00
|
|
|
|
2022-11-29 09:08:08 +00:00
|
|
|
/** Get power debug information
|
2022-04-07 15:00:45 +00:00
|
|
|
*
|
|
|
|
* @param[in] callback callback to provide with new data
|
|
|
|
* @param[in] context context to pass to callback
|
|
|
|
*/
|
2022-11-29 09:08:08 +00:00
|
|
|
void furi_hal_power_debug_get(PropertyValueCallback callback, void* context);
|
2022-04-07 15:00:45 +00:00
|
|
|
|
2020-12-02 10:47:13 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|