THB2/bthome_phy6222/SDK/components/driver/pwrmgr/pwrmgr.h

87 lines
2.2 KiB
C

/************
pwrmgr.c
SDK_LICENSE
**************/
#ifndef _HAL_PWRMGR_HD
#define _HAL_PWRMGR_HD
#ifdef __cplusplus
extern "C" {
#endif
#include "bus_dev.h"
#include "gpio.h"
#include "clock.h"
#define PWR_MODE_NO_SLEEP 1
#define PWR_MODE_SLEEP 2
#define PWR_MODE_PWROFF_NO_SLEEP 4
//WAKEUP FROM STANDBY MODE
#define WAKEUP_PIN_MAX 3
#define HAL_PWRMGR_TASK_MAX_NUM 10
#define RET_SRAM0 BIT(0) /*32K, 0x1fff0000~0x1fff7fff*/
#define RET_SRAM1 BIT(1) /*16K, 0x1fff8000~0x1fffbfff*/
#define RET_SRAM2 BIT(2) /*16K, 0x1fffc000~0x1fffffff*/
#define DEF_CLKG_CONFIG_0 (_CLK_IOMUX|_CLK_UART0|_CLK_GPIO|_CLK_SPIF|_CLK_DMA|_CLK_TIMER5)
#define DEF_CLKG_CONFIG_1 (_CLK_M0_CPU | _CLK_BB |_CLK_TIMER |_CLK_BBREG \
|_CLK_TIMER1|_CLK_TIMER2|_CLK_TIMER3|_CLK_TIMER4|_CLK_COM)
typedef struct
{
gpio_pin_e pin;
gpio_polarity_e type;
uint16_t on_time;
} pwroff_cfg_t;
typedef struct
{
uint8_t sramRet_config:3;
uint8_t moudle_num:5;
} PWRMGR_CFG_BIT;
extern uint32_t g_system_reset_cause;
extern sysclk_t g_system_clk_change;
typedef void (*pwrmgr_Hdl_t)(void);
int hal_pwrmgr_init(void);
bool hal_pwrmgr_is_lock(MODULE_e mod);
int hal_pwrmgr_lock(MODULE_e mod);
int hal_pwrmgr_unlock(MODULE_e mod);
int hal_pwrmgr_register(MODULE_e mod, pwrmgr_Hdl_t sleepHandle, pwrmgr_Hdl_t wakeupHandle);
int hal_pwrmgr_unregister(MODULE_e mod);
int hal_pwrmgr_wakeup_process(void) __attribute__((weak));
int hal_pwrmgr_sleep_process(void) __attribute__((weak));
int hal_pwrmgr_RAM_retention(uint32_t sram);
int hal_pwrmgr_clk_gate_config(MODULE_e module);
int hal_pwrmgr_RAM_retention_clr(void);
int hal_pwrmgr_RAM_retention_set(void);
int hal_pwrmgr_LowCurrentLdo_enable(void);
int hal_pwrmgr_LowCurrentLdo_disable(void);
int hal_pwrmgr_get_module_lock_status(void);
void hal_pwrmgr_poweroff(pwroff_cfg_t* pcfg, uint8_t wakeup_pin_num);
__ATTR_SECTION_SRAM__ void hal_pwrmgr_enter_sleep_rtc_reset(uint32_t sleepRtcTick);
void hal_pwrmgr_enter_standby(pwroff_cfg_t* pcfg,uint8_t wakeup_pin_num) ;
void clk_change_mod_restore(void);
extern uint8_t hal_system_clock_change_req(sysclk_t clk);
extern uint8_t hal_system_clock_change_active(sysclk_t clk,pwrmgr_Hdl_t restoreHandle);
#ifdef __cplusplus
}
#endif
#endif