mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
pm: putting dbias and pd_cur code into same function
This commit is contained in:
parent
254870c3c4
commit
f46bd50884
@ -84,6 +84,38 @@ static void rtc_sleep_pd(rtc_sleep_pd_config_t cfg)
|
|||||||
REG_SET_FIELD(FE2_TX_INTERP_CTRL, FE2_TX_INF_FORCE_PU, ~cfg.fe_pd);
|
REG_SET_FIELD(FE2_TX_INTERP_CTRL, FE2_TX_INF_FORCE_PU, ~cfg.fe_pd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config)
|
||||||
|
{
|
||||||
|
*out_config = (rtc_sleep_config_t) {
|
||||||
|
.lslp_mem_inf_fpu = 0,
|
||||||
|
.rtc_mem_inf_fpu = 0,
|
||||||
|
.rtc_mem_inf_follow_cpu = ((sleep_flags) & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0,
|
||||||
|
.rtc_fastmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0,
|
||||||
|
.rtc_slowmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0,
|
||||||
|
.rtc_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0,
|
||||||
|
.wifi_pd_en = 0,
|
||||||
|
.int_8m_pd_en = ((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? 1 : 0,
|
||||||
|
.rom_mem_pd_en = 0,
|
||||||
|
.deep_slp = ((sleep_flags) & RTC_SLEEP_PD_DIG) ? 1 : 0,
|
||||||
|
.wdt_flashboot_mod_en = 0,
|
||||||
|
.lslp_meminf_pd = 1,
|
||||||
|
.vddsdio_pd_en = ((sleep_flags) & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0,
|
||||||
|
.xtal_fpu = ((sleep_flags) & RTC_SLEEP_PD_XTAL) ? 0 : 1,
|
||||||
|
};
|
||||||
|
|
||||||
|
if ((sleep_flags) & RTC_SLEEP_PD_DIG) {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = RTC_CNTL_DBIAS_0V90;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = RTC_CNTL_DBIAS_0V90;
|
||||||
|
} else {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 : RTC_CNTL_DBIAS_0V90;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 : RTC_CNTL_DBIAS_0V90;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
||||||
{
|
{
|
||||||
// set shortest possible sleep time limit
|
// set shortest possible sleep time limit
|
||||||
|
@ -53,6 +53,61 @@ void rtc_sleep_pu(rtc_sleep_pu_config_t cfg)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config)
|
||||||
|
{
|
||||||
|
*out_config = (rtc_sleep_config_t) {
|
||||||
|
.lslp_mem_inf_fpu = 0,
|
||||||
|
.rtc_mem_inf_follow_cpu = (sleep_flags & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0,
|
||||||
|
.rtc_fastmem_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0,
|
||||||
|
.rtc_slowmem_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0,
|
||||||
|
.rtc_peri_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0,
|
||||||
|
.wifi_pd_en = (sleep_flags & RTC_SLEEP_PD_WIFI) ? 1 : 0,
|
||||||
|
.bt_pd_en = (sleep_flags & RTC_SLEEP_PD_BT) ? 1 : 0,
|
||||||
|
.cpu_pd_en = (sleep_flags & RTC_SLEEP_PD_CPU) ? 1 : 0,
|
||||||
|
.int_8m_pd_en = (sleep_flags & RTC_SLEEP_PD_INT_8M) ? 1 : 0,
|
||||||
|
.dig_peri_pd_en = (sleep_flags & RTC_SLEEP_PD_DIG_PERIPH) ? 1 : 0,
|
||||||
|
.deep_slp = (sleep_flags & RTC_SLEEP_PD_DIG) ? 1 : 0,
|
||||||
|
.wdt_flashboot_mod_en = 0,
|
||||||
|
.vddsdio_pd_en = (sleep_flags & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0,
|
||||||
|
.xtal_fpu = (sleep_flags & RTC_SLEEP_PD_XTAL) ? 0 : 1,
|
||||||
|
.deep_slp_reject = 1,
|
||||||
|
.light_slp_reject = 1
|
||||||
|
};
|
||||||
|
|
||||||
|
if (sleep_flags & RTC_SLEEP_PD_DIG) {
|
||||||
|
unsigned atten_deep_sleep = RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT;
|
||||||
|
#if CONFIG_ESP32C3_REV_MIN < 3
|
||||||
|
if (esp_efuse_get_chip_ver() < 3) {
|
||||||
|
atten_deep_sleep = 0; /* workaround for deep sleep issue in high temp on ECO2 and below */
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = RTC_CNTL_DBIAS_SLP;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = RTC_CNTL_DBIAS_SLP;
|
||||||
|
|
||||||
|
out_config->dbg_atten_monitor = RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT;
|
||||||
|
out_config->bias_sleep_monitor = RTC_CNTL_BIASSLP_MONITOR_DEFAULT;
|
||||||
|
out_config->dbg_atten_slp = atten_deep_sleep;
|
||||||
|
out_config->bias_sleep_slp = RTC_CNTL_BIASSLP_SLEEP_DEFAULT;
|
||||||
|
out_config->pd_cur_monitor = RTC_CNTL_PD_CUR_MONITOR_DEFAULT;
|
||||||
|
out_config->pd_cur_slp = RTC_CNTL_PD_CUR_SLEEP_DEFAULT;
|
||||||
|
} else {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = !(sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 : RTC_CNTL_DBIAS_SLP;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = !(sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 : RTC_CNTL_DBIAS_SLP;
|
||||||
|
|
||||||
|
out_config->dbg_atten_monitor = RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT;
|
||||||
|
out_config->bias_sleep_monitor = RTC_CNTL_BIASSLP_MONITOR_DEFAULT;
|
||||||
|
out_config->dbg_atten_slp = (sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_DEFAULT : RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_NODROP;
|
||||||
|
out_config->bias_sleep_slp = !(sleep_flags & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_BIASSLP_SLEEP_ON : RTC_CNTL_BIASSLP_SLEEP_DEFAULT;
|
||||||
|
out_config->pd_cur_monitor = RTC_CNTL_PD_CUR_MONITOR_DEFAULT;
|
||||||
|
out_config->pd_cur_slp = !(sleep_flags & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_PD_CUR_SLEEP_ON : RTC_CNTL_PD_CUR_SLEEP_DEFAULT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
||||||
{
|
{
|
||||||
if (cfg.lslp_mem_inf_fpu) {
|
if (cfg.lslp_mem_inf_fpu) {
|
||||||
@ -82,23 +137,19 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_PERI_PD_EN);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_PERI_PD_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_MONITOR, RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT);
|
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_RTC_DREG_SLEEP, cfg.rtc_dbias_slp);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_MONITOR, RTC_CNTL_BIASSLP_MONITOR_DEFAULT);
|
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_DIG_DREG_SLEEP, cfg.dig_dbias_slp);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_DEEP_SLP,
|
|
||||||
(!cfg.deep_slp && cfg.xtal_fpu) ? RTC_CNTL_BIASSLP_SLEEP_ON : RTC_CNTL_BIASSLP_SLEEP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_MONITOR, cfg.dbg_atten_monitor);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_MONITOR, RTC_CNTL_PD_CUR_MONITOR_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_MONITOR, cfg.bias_sleep_monitor);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_DEEP_SLP,
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP, cfg.dbg_atten_slp);
|
||||||
(!cfg.deep_slp && cfg.xtal_fpu) ? RTC_CNTL_PD_CUR_SLEEP_ON : RTC_CNTL_PD_CUR_SLEEP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_DEEP_SLP, cfg.bias_sleep_slp);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_MONITOR, cfg.pd_cur_monitor);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_DEEP_SLP, cfg.pd_cur_slp);
|
||||||
|
|
||||||
if (cfg.deep_slp) {
|
if (cfg.deep_slp) {
|
||||||
REGI2C_WRITE_MASK(I2C_ULP, I2C_ULP_IR_FORCE_XPD_CK, 0);
|
REGI2C_WRITE_MASK(I2C_ULP, I2C_ULP_IR_FORCE_XPD_CK, 0);
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
||||||
unsigned atten_deep_sleep = RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT;
|
|
||||||
#if CONFIG_ESP32C3_REV_MIN < 3
|
|
||||||
if (esp_efuse_get_chip_ver() < 3) {
|
|
||||||
atten_deep_sleep = 0; /* workaround for deep sleep issue in high temp on ECO2 and below */
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP, atten_deep_sleep);
|
|
||||||
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_ANA_CONF_REG,
|
CLEAR_PERI_REG_MASK(RTC_CNTL_ANA_CONF_REG,
|
||||||
RTC_CNTL_CKGEN_I2C_PU | RTC_CNTL_PLL_I2C_PU |
|
RTC_CNTL_CKGEN_I2C_PU | RTC_CNTL_PLL_I2C_PU |
|
||||||
@ -109,8 +160,6 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DG_VDD_DRV_B_SLP, RTC_CNTL_DG_VDD_DRV_B_SLP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DG_VDD_DRV_B_SLP, RTC_CNTL_DG_VDD_DRV_B_SLP_DEFAULT);
|
||||||
SET_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
SET_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP,
|
|
||||||
cfg.int_8m_pd_en ? RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_DEFAULT : RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_NODROP);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!cfg.int_8m_pd_en) {
|
if (!cfg.int_8m_pd_en) {
|
||||||
@ -125,9 +174,6 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
REG_CLR_BIT(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_FORCE);
|
REG_CLR_BIT(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_FORCE);
|
||||||
REG_SET_FIELD(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_PD_EN, cfg.vddsdio_pd_en);
|
REG_SET_FIELD(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_PD_EN, cfg.vddsdio_pd_en);
|
||||||
|
|
||||||
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_RTC_DREG_SLEEP, cfg.rtc_dbias_slp);
|
|
||||||
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_DIG_DREG_SLEEP, cfg.dig_dbias_slp);
|
|
||||||
|
|
||||||
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_DEEP_SLP_REJECT_EN, cfg.deep_slp_reject);
|
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_DEEP_SLP_REJECT_EN, cfg.deep_slp_reject);
|
||||||
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_LIGHT_SLP_REJECT_EN, cfg.light_slp_reject);
|
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_LIGHT_SLP_REJECT_EN, cfg.light_slp_reject);
|
||||||
|
|
||||||
|
@ -154,6 +154,49 @@ void rtc_sleep_pmu_init(void)
|
|||||||
left_up_trx_fpu(0);
|
left_up_trx_fpu(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config)
|
||||||
|
{
|
||||||
|
*out_config = (rtc_sleep_config_t) {
|
||||||
|
.lslp_mem_inf_fpu = 0,
|
||||||
|
.rtc_mem_inf_follow_cpu = ((sleep_flags) & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0,
|
||||||
|
.rtc_fastmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0,
|
||||||
|
.rtc_slowmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0,
|
||||||
|
.rtc_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0,
|
||||||
|
.dig_ret_pd_en = ((sleep_flags) & RTC_SLEEP_PD_DIG_RET) ? 1 : 0,
|
||||||
|
.bt_pd_en = ((sleep_flags) & RTC_SLEEP_PD_BT) ? 1 : 0,
|
||||||
|
.cpu_pd_en = ((sleep_flags) & RTC_SLEEP_PD_CPU) ? 1 : 0,
|
||||||
|
.int_8m_pd_en = ((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? 1 : 0,
|
||||||
|
.dig_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_DIG_PERIPH) ? 1 : 0,
|
||||||
|
.deep_slp = ((sleep_flags) & RTC_SLEEP_PD_DIG) ? 1 : 0,
|
||||||
|
.wdt_flashboot_mod_en = 0,
|
||||||
|
.vddsdio_pd_en = ((sleep_flags) & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0,
|
||||||
|
.xtal_fpu = ((sleep_flags) & RTC_SLEEP_PD_XTAL) ? 0 : 1,
|
||||||
|
.deep_slp_reject = 1,
|
||||||
|
.light_slp_reject = 1
|
||||||
|
};
|
||||||
|
|
||||||
|
if ((sleep_flags) & RTC_SLEEP_PD_DIG) {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = RTC_CNTL_DBIAS_SLP;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = RTC_CNTL_DBIAS_SLP;
|
||||||
|
|
||||||
|
out_config->bias_sleep_monitor = RTC_CNTL_BIASSLP_MONITOR_DEFAULT;
|
||||||
|
out_config->bias_sleep_slp = RTC_CNTL_BIASSLP_SLEEP_DEFAULT;
|
||||||
|
out_config->pd_cur_monitor = RTC_CNTL_PD_CUR_MONITOR_DEFAULT;
|
||||||
|
out_config->pd_cur_slp = RTC_CNTL_PD_CUR_SLEEP_DEFAULT;
|
||||||
|
} else {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 : RTC_CNTL_DBIAS_SLP;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 : RTC_CNTL_DBIAS_SLP;
|
||||||
|
|
||||||
|
out_config->bias_sleep_monitor = RTC_CNTL_BIASSLP_MONITOR_DEFAULT;
|
||||||
|
out_config->bias_sleep_slp = RTC_CNTL_BIASSLP_SLEEP_DEFAULT;
|
||||||
|
out_config->pd_cur_monitor = RTC_CNTL_PD_CUR_MONITOR_DEFAULT;
|
||||||
|
out_config->pd_cur_slp = RTC_CNTL_PD_CUR_SLEEP_DEFAULT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
||||||
{
|
{
|
||||||
@ -182,10 +225,10 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_RET_PD_EN);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_RET_PD_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_MONITOR, RTC_CNTL_BIASSLP_MONITOR_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_MONITOR, cfg.bias_sleep_monitor);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_DEEP_SLP, RTC_CNTL_BIASSLP_SLEEP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_DEEP_SLP, cfg.bias_sleep_slp);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_MONITOR, RTC_CNTL_PD_CUR_MONITOR_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_MONITOR, cfg.pd_cur_monitor);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_DEEP_SLP, RTC_CNTL_PD_CUR_SLEEP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_DEEP_SLP, cfg.pd_cur_slp);
|
||||||
// ESP32-H2 TO-DO: IDF-3693
|
// ESP32-H2 TO-DO: IDF-3693
|
||||||
if (cfg.deep_slp) {
|
if (cfg.deep_slp) {
|
||||||
// REGI2C_WRITE_MASK(I2C_ULP, I2C_ULP_IR_FORCE_XPD_CK, 0);
|
// REGI2C_WRITE_MASK(I2C_ULP, I2C_ULP_IR_FORCE_XPD_CK, 0);
|
||||||
|
@ -44,6 +44,55 @@ void rtc_sleep_pd(rtc_sleep_pd_config_t cfg)
|
|||||||
REG_SET_FIELD(FE2_TX_INTERP_CTRL, FE2_TX_INF_FORCE_PU, cfg.fe_fpu);
|
REG_SET_FIELD(FE2_TX_INTERP_CTRL, FE2_TX_INF_FORCE_PU, cfg.fe_fpu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config)
|
||||||
|
{
|
||||||
|
*out_config = (rtc_sleep_config_t) {
|
||||||
|
.lslp_mem_inf_fpu = 0,
|
||||||
|
.rtc_mem_inf_follow_cpu = (sleep_flags & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0,
|
||||||
|
.rtc_fastmem_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0,
|
||||||
|
.rtc_slowmem_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0,
|
||||||
|
.rtc_peri_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0,
|
||||||
|
.wifi_pd_en = (sleep_flags & RTC_SLEEP_PD_WIFI) ? 1 : 0,
|
||||||
|
.int_8m_pd_en = (sleep_flags & RTC_SLEEP_PD_INT_8M) ? 1 : 0,
|
||||||
|
.deep_slp = (sleep_flags & RTC_SLEEP_PD_DIG) ? 1 : 0,
|
||||||
|
.wdt_flashboot_mod_en = 0,
|
||||||
|
.vddsdio_pd_en = (sleep_flags & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0,
|
||||||
|
.xtal_fpu = (sleep_flags & RTC_SLEEP_PD_XTAL) ? 0 : 1,
|
||||||
|
.deep_slp_reject = 1,
|
||||||
|
.light_slp_reject = 1
|
||||||
|
};
|
||||||
|
|
||||||
|
if (sleep_flags & RTC_SLEEP_PD_DIG) {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DIG_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = RTC_CNTL_DIG_DBIAS_0V90;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = RTC_CNTL_DBIAS_1V00;
|
||||||
|
|
||||||
|
out_config->dbg_atten_monitor = RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT;
|
||||||
|
out_config->bias_sleep_monitor = RTC_CNTL_BIASSLP_MONITOR_DEFAULT;
|
||||||
|
out_config->dbg_atten_slp = RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT;
|
||||||
|
out_config->bias_sleep_slp = RTC_CNTL_BIASSLP_SLEEP_DEFAULT;
|
||||||
|
out_config->pd_cur_monitor = RTC_CNTL_PD_CUR_MONITOR_DEFAULT;
|
||||||
|
out_config->pd_cur_slp = RTC_CNTL_PD_CUR_SLEEP_DEFAULT;
|
||||||
|
} else {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DIG_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = !(sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DIG_DBIAS_1V10
|
||||||
|
: !(sleep_flags & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_DIG_DBIAS_1V10
|
||||||
|
: RTC_CNTL_DIG_DBIAS_0V90;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = !(sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10
|
||||||
|
: !(sleep_flags & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_DBIAS_1V10
|
||||||
|
: RTC_CNTL_DBIAS_1V00;
|
||||||
|
|
||||||
|
out_config->dbg_atten_monitor = RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT;
|
||||||
|
out_config->bias_sleep_monitor = RTC_CNTL_BIASSLP_MONITOR_DEFAULT;
|
||||||
|
out_config->dbg_atten_slp = (sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_DEFAULT : RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_NODROP;
|
||||||
|
out_config->bias_sleep_slp = !(sleep_flags & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_BIASSLP_SLEEP_ON : RTC_CNTL_BIASSLP_SLEEP_DEFAULT;
|
||||||
|
out_config->pd_cur_monitor = RTC_CNTL_PD_CUR_MONITOR_DEFAULT;
|
||||||
|
out_config->pd_cur_slp = !(sleep_flags & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_PD_CUR_SLEEP_ON : RTC_CNTL_PD_CUR_SLEEP_DEFAULT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
||||||
{
|
{
|
||||||
if (cfg.lslp_mem_inf_fpu) {
|
if (cfg.lslp_mem_inf_fpu) {
|
||||||
@ -89,16 +138,20 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_WIFI_PD_EN);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_WIFI_PD_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_MONITOR, RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DBIAS_SLP, cfg.rtc_dbias_slp);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_MONITOR, RTC_CNTL_BIASSLP_MONITOR_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DBIAS_WAK, cfg.rtc_dbias_wak);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_DEEP_SLP,
|
REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DIG_DBIAS_WAK, cfg.dig_dbias_wak);
|
||||||
(!cfg.deep_slp && cfg.xtal_fpu) ? RTC_CNTL_BIASSLP_SLEEP_ON : RTC_CNTL_BIASSLP_SLEEP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DIG_DBIAS_SLP, cfg.dig_dbias_slp);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_MONITOR, RTC_CNTL_PD_CUR_MONITOR_DEFAULT);
|
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_DEEP_SLP,
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_MONITOR, cfg.dbg_atten_monitor);
|
||||||
(!cfg.deep_slp && cfg.xtal_fpu) ? RTC_CNTL_PD_CUR_SLEEP_ON : RTC_CNTL_PD_CUR_SLEEP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_MONITOR, cfg.bias_sleep_monitor);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_DEEP_SLP, cfg.bias_sleep_slp);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_MONITOR, cfg.pd_cur_monitor);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_DEEP_SLP, cfg.pd_cur_slp);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP, cfg.dbg_atten_slp);
|
||||||
|
|
||||||
if (cfg.deep_slp) {
|
if (cfg.deep_slp) {
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP, RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT);
|
|
||||||
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_ANA_CONF_REG,
|
CLEAR_PERI_REG_MASK(RTC_CNTL_ANA_CONF_REG,
|
||||||
RTC_CNTL_CKGEN_I2C_PU | RTC_CNTL_PLL_I2C_PU |
|
RTC_CNTL_CKGEN_I2C_PU | RTC_CNTL_PLL_I2C_PU |
|
||||||
@ -107,8 +160,6 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
} else {
|
} else {
|
||||||
SET_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
SET_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP,
|
|
||||||
cfg.int_8m_pd_en ? RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_DEFAULT : RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_NODROP);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!cfg.int_8m_pd_en) {
|
if (!cfg.int_8m_pd_en) {
|
||||||
@ -121,11 +172,6 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
REG_CLR_BIT(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_FORCE);
|
REG_CLR_BIT(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_FORCE);
|
||||||
REG_SET_FIELD(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_PD_EN, cfg.vddsdio_pd_en);
|
REG_SET_FIELD(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_PD_EN, cfg.vddsdio_pd_en);
|
||||||
|
|
||||||
REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DBIAS_SLP, cfg.rtc_dbias_slp);
|
|
||||||
REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DBIAS_WAK, cfg.rtc_dbias_wak);
|
|
||||||
REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DIG_DBIAS_WAK, cfg.dig_dbias_wak);
|
|
||||||
REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DIG_DBIAS_SLP, cfg.dig_dbias_slp);
|
|
||||||
|
|
||||||
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_DEEP_SLP_REJECT_EN, cfg.deep_slp_reject);
|
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_DEEP_SLP_REJECT_EN, cfg.deep_slp_reject);
|
||||||
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_LIGHT_SLP_REJECT_EN, cfg.light_slp_reject);
|
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_LIGHT_SLP_REJECT_EN, cfg.light_slp_reject);
|
||||||
/* Set wait cycle for touch or COCPU after deep sleep and light sleep. */
|
/* Set wait cycle for touch or COCPU after deep sleep and light sleep. */
|
||||||
|
@ -53,6 +53,54 @@ void rtc_sleep_pu(rtc_sleep_pu_config_t cfg)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config)
|
||||||
|
{
|
||||||
|
*out_config = (rtc_sleep_config_t) {
|
||||||
|
.lslp_mem_inf_fpu = 0,
|
||||||
|
.rtc_mem_inf_follow_cpu = (sleep_flags & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0,
|
||||||
|
.rtc_fastmem_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0,
|
||||||
|
.rtc_slowmem_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0,
|
||||||
|
.rtc_peri_pd_en = (sleep_flags & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0,
|
||||||
|
.wifi_pd_en = (sleep_flags & RTC_SLEEP_PD_WIFI) ? 1 : 0,
|
||||||
|
.bt_pd_en = (sleep_flags & RTC_SLEEP_PD_BT) ? 1 : 0,
|
||||||
|
.cpu_pd_en = (sleep_flags & RTC_SLEEP_PD_CPU) ? 1 : 0,
|
||||||
|
.int_8m_pd_en = (sleep_flags & RTC_SLEEP_PD_INT_8M) ? 1 : 0,
|
||||||
|
.dig_peri_pd_en = (sleep_flags & RTC_SLEEP_PD_DIG_PERIPH) ? 1 : 0,
|
||||||
|
.deep_slp = (sleep_flags & RTC_SLEEP_PD_DIG) ? 1 : 0,
|
||||||
|
.wdt_flashboot_mod_en = 0,
|
||||||
|
.vddsdio_pd_en = (sleep_flags & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0,
|
||||||
|
.xtal_fpu = (sleep_flags & RTC_SLEEP_PD_XTAL) ? 0 : 1,
|
||||||
|
.deep_slp_reject = 1,
|
||||||
|
.light_slp_reject = 1
|
||||||
|
};
|
||||||
|
|
||||||
|
if (sleep_flags & RTC_SLEEP_PD_DIG) {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = RTC_CNTL_DBIAS_SLP;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = RTC_CNTL_DBIAS_SLP;
|
||||||
|
|
||||||
|
out_config->dbg_atten_monitor = RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT;
|
||||||
|
out_config->bias_sleep_monitor = RTC_CNTL_BIASSLP_MONITOR_DEFAULT;
|
||||||
|
out_config->dbg_atten_slp = RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT;
|
||||||
|
out_config->bias_sleep_slp = RTC_CNTL_BIASSLP_SLEEP_DEFAULT;
|
||||||
|
out_config->pd_cur_monitor = RTC_CNTL_PD_CUR_MONITOR_DEFAULT;
|
||||||
|
out_config->pd_cur_slp = RTC_CNTL_PD_CUR_SLEEP_DEFAULT;
|
||||||
|
} else {
|
||||||
|
out_config->dig_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->dig_dbias_slp = !(sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 : RTC_CNTL_DBIAS_SLP;
|
||||||
|
out_config->rtc_dbias_wak = RTC_CNTL_DBIAS_1V10;
|
||||||
|
out_config->rtc_dbias_slp = !(sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 : RTC_CNTL_DBIAS_SLP;
|
||||||
|
|
||||||
|
out_config->dbg_atten_monitor = RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT;
|
||||||
|
out_config->bias_sleep_monitor = RTC_CNTL_BIASSLP_MONITOR_DEFAULT;
|
||||||
|
out_config->dbg_atten_slp = (sleep_flags & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_DEFAULT : RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_NODROP;
|
||||||
|
out_config->bias_sleep_slp = !(sleep_flags & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_BIASSLP_SLEEP_ON : RTC_CNTL_BIASSLP_SLEEP_DEFAULT;
|
||||||
|
out_config->pd_cur_monitor = RTC_CNTL_PD_CUR_MONITOR_DEFAULT;
|
||||||
|
out_config->pd_cur_slp = !(sleep_flags & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_PD_CUR_SLEEP_ON : RTC_CNTL_PD_CUR_SLEEP_DEFAULT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
void rtc_sleep_init(rtc_sleep_config_t cfg)
|
||||||
{
|
{
|
||||||
if (cfg.lslp_mem_inf_fpu) {
|
if (cfg.lslp_mem_inf_fpu) {
|
||||||
@ -95,16 +143,21 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
} else {
|
} else {
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_PWC_REG, RTC_CNTL_PD_EN);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_PWC_REG, RTC_CNTL_PD_EN);
|
||||||
}
|
}
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_MONITOR, RTC_CNTL_DBG_ATTEN_MONITOR_DEFAULT);
|
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_MONITOR, RTC_CNTL_BIASSLP_MONITOR_DEFAULT);
|
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_RTC_DREG_SLEEP, cfg.rtc_dbias_slp);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_DEEP_SLP,
|
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_RTC_DREG, cfg.rtc_dbias_wak);
|
||||||
(!cfg.deep_slp && cfg.xtal_fpu) ? RTC_CNTL_BIASSLP_SLEEP_ON : RTC_CNTL_BIASSLP_SLEEP_DEFAULT);
|
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_DIG_DREG_SLEEP, cfg.dig_dbias_slp);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_MONITOR, RTC_CNTL_PD_CUR_MONITOR_DEFAULT);
|
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_DIG_DREG, cfg.dig_dbias_wak);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_DEEP_SLP,
|
|
||||||
(!cfg.deep_slp && cfg.xtal_fpu) ? RTC_CNTL_PD_CUR_SLEEP_ON : RTC_CNTL_PD_CUR_SLEEP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_MONITOR, cfg.dbg_atten_monitor);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_MONITOR, cfg.bias_sleep_monitor);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP, cfg.dbg_atten_slp);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_BIAS_SLEEP_DEEP_SLP, cfg.bias_sleep_slp);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_MONITOR, cfg.pd_cur_monitor);
|
||||||
|
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_PD_CUR_DEEP_SLP, cfg.pd_cur_slp);
|
||||||
|
|
||||||
if (cfg.deep_slp) {
|
if (cfg.deep_slp) {
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP, RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT);
|
|
||||||
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_ANA_CONF_REG,
|
CLEAR_PERI_REG_MASK(RTC_CNTL_ANA_CONF_REG,
|
||||||
RTC_CNTL_CKGEN_I2C_PU | RTC_CNTL_PLL_I2C_PU |
|
RTC_CNTL_CKGEN_I2C_PU | RTC_CNTL_PLL_I2C_PU |
|
||||||
@ -114,8 +167,6 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
REG_SET_FIELD(RTC_CNTL_REGULATOR_DRV_CTRL_REG, RTC_CNTL_DG_VDD_DRV_B_SLP, RTC_CNTL_DG_VDD_DRV_B_SLP_DEFAULT);
|
REG_SET_FIELD(RTC_CNTL_REGULATOR_DRV_CTRL_REG, RTC_CNTL_DG_VDD_DRV_B_SLP, RTC_CNTL_DG_VDD_DRV_B_SLP_DEFAULT);
|
||||||
SET_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
SET_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
||||||
REG_SET_FIELD(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DBG_ATTEN_DEEP_SLP,
|
|
||||||
cfg.int_8m_pd_en ? RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_DEFAULT : RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_NODROP);
|
|
||||||
}
|
}
|
||||||
/* mem pd */
|
/* mem pd */
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_LSLP_MEM_FORCE_PU);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_LSLP_MEM_FORCE_PU);
|
||||||
@ -130,11 +181,6 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|||||||
REG_CLR_BIT(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_FORCE);
|
REG_CLR_BIT(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_FORCE);
|
||||||
REG_SET_FIELD(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_PD_EN, cfg.vddsdio_pd_en);
|
REG_SET_FIELD(RTC_CNTL_SDIO_CONF_REG, RTC_CNTL_SDIO_PD_EN, cfg.vddsdio_pd_en);
|
||||||
|
|
||||||
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_RTC_DREG_SLEEP, cfg.rtc_dbias_slp);
|
|
||||||
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_RTC_DREG, cfg.rtc_dbias_wak);
|
|
||||||
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_DIG_DREG_SLEEP, cfg.dig_dbias_slp);
|
|
||||||
REGI2C_WRITE_MASK(I2C_DIG_REG, I2C_DIG_REG_EXT_DIG_DREG, cfg.dig_dbias_wak);
|
|
||||||
|
|
||||||
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_DEEP_SLP_REJECT_EN, cfg.deep_slp_reject);
|
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_DEEP_SLP_REJECT_EN, cfg.deep_slp_reject);
|
||||||
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_LIGHT_SLP_REJECT_EN, cfg.light_slp_reject);
|
REG_SET_FIELD(RTC_CNTL_SLP_REJECT_CONF_REG, RTC_CNTL_LIGHT_SLP_REJECT_EN, cfg.light_slp_reject);
|
||||||
|
|
||||||
|
@ -178,6 +178,10 @@ static bool s_light_sleep_wakeup = false;
|
|||||||
static portMUX_TYPE spinlock_rtc_deep_sleep = portMUX_INITIALIZER_UNLOCKED;
|
static portMUX_TYPE spinlock_rtc_deep_sleep = portMUX_INITIALIZER_UNLOCKED;
|
||||||
|
|
||||||
static const char *TAG = "sleep";
|
static const char *TAG = "sleep";
|
||||||
|
static bool s_adc_tsen_enabled = false;
|
||||||
|
//in this mode, 2uA is saved, but RTC memory can't use at high temperature, and RTCIO can't be used as INPUT.
|
||||||
|
static bool s_ultra_low_enabled = false;
|
||||||
|
|
||||||
|
|
||||||
static uint32_t get_power_down_flags(void);
|
static uint32_t get_power_down_flags(void);
|
||||||
#if SOC_PM_SUPPORT_EXT_WAKEUP
|
#if SOC_PM_SUPPORT_EXT_WAKEUP
|
||||||
@ -462,8 +466,21 @@ static uint32_t IRAM_ATTR esp_sleep_start(uint32_t pd_flags)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Append some flags in addition to power domains
|
||||||
|
uint32_t sleep_flags = pd_flags;
|
||||||
|
if (s_adc_tsen_enabled) {
|
||||||
|
sleep_flags |= RTC_SLEEP_USE_ADC_TESEN_MONITOR;
|
||||||
|
}
|
||||||
|
if (!s_ultra_low_enabled) {
|
||||||
|
sleep_flags |= RTC_SLEEP_NO_ULTRA_LOW;
|
||||||
|
}
|
||||||
|
if (rtc_dig_8m_enabled()) {
|
||||||
|
sleep_flags |= RTC_SLEEP_DIG_USE_8M;
|
||||||
|
}
|
||||||
|
|
||||||
// Enter sleep
|
// Enter sleep
|
||||||
rtc_sleep_config_t config = RTC_SLEEP_CONFIG_DEFAULT(pd_flags);
|
rtc_sleep_config_t config;
|
||||||
|
rtc_sleep_get_default_config(sleep_flags, &config);
|
||||||
rtc_sleep_init(config);
|
rtc_sleep_init(config);
|
||||||
|
|
||||||
// Set state machine time for light sleep
|
// Set state machine time for light sleep
|
||||||
@ -1330,3 +1347,13 @@ void esp_deep_sleep_disable_rom_logging(void)
|
|||||||
{
|
{
|
||||||
rtc_suppress_rom_log();
|
rtc_suppress_rom_log();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void rtc_sleep_enable_adc_tesn_monitor(bool enable)
|
||||||
|
{
|
||||||
|
s_adc_tsen_enabled = enable;
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtc_sleep_enable_ultra_low(bool enable)
|
||||||
|
{
|
||||||
|
s_ultra_low_enabled = enable;
|
||||||
|
}
|
||||||
|
@ -511,40 +511,6 @@ typedef struct rtc_sleep_config_s {
|
|||||||
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
||||||
} rtc_sleep_config_t;
|
} rtc_sleep_config_t;
|
||||||
|
|
||||||
/**
|
|
||||||
* Default initializer for rtc_sleep_config_t
|
|
||||||
*
|
|
||||||
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
|
||||||
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
|
||||||
*
|
|
||||||
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
|
||||||
*/
|
|
||||||
#define is_dslp(pd_flags) ((pd_flags) & RTC_SLEEP_PD_DIG)
|
|
||||||
#define RTC_SLEEP_CONFIG_DEFAULT(sleep_flags) { \
|
|
||||||
.lslp_mem_inf_fpu = 0, \
|
|
||||||
.rtc_mem_inf_fpu = 0, \
|
|
||||||
.rtc_mem_inf_follow_cpu = ((sleep_flags) & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0, \
|
|
||||||
.rtc_fastmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0, \
|
|
||||||
.rtc_slowmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0, \
|
|
||||||
.rtc_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0, \
|
|
||||||
.wifi_pd_en = 0, \
|
|
||||||
.int_8m_pd_en = ((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? 1 : 0, \
|
|
||||||
.rom_mem_pd_en = 0, \
|
|
||||||
.deep_slp = ((sleep_flags) & RTC_SLEEP_PD_DIG) ? 1 : 0, \
|
|
||||||
.wdt_flashboot_mod_en = 0, \
|
|
||||||
.dig_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.dig_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_0V90 \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_0V90, \
|
|
||||||
.rtc_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.rtc_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_0V90 \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_0V90, \
|
|
||||||
.lslp_meminf_pd = 1, \
|
|
||||||
.vddsdio_pd_en = ((sleep_flags) & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0, \
|
|
||||||
.xtal_fpu = ((sleep_flags) & RTC_SLEEP_PD_XTAL) ? 0 : 1 \
|
|
||||||
};
|
|
||||||
|
|
||||||
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
||||||
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
||||||
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
||||||
@ -554,6 +520,21 @@ typedef struct rtc_sleep_config_s {
|
|||||||
#define RTC_SLEEP_PD_XTAL BIT(6) //!< Power down main XTAL
|
#define RTC_SLEEP_PD_XTAL BIT(6) //!< Power down main XTAL
|
||||||
#define RTC_SLEEP_PD_INT_8M BIT(7) //!< Power down Internal 8M oscillator
|
#define RTC_SLEEP_PD_INT_8M BIT(7) //!< Power down Internal 8M oscillator
|
||||||
|
|
||||||
|
//These flags are not power domains, but will affect some sleep parameters
|
||||||
|
#define RTC_SLEEP_DIG_USE_8M BIT(16)
|
||||||
|
#define RTC_SLEEP_USE_ADC_TESEN_MONITOR BIT(17)
|
||||||
|
#define RTC_SLEEP_NO_ULTRA_LOW BIT(18) //!< Avoid using ultra low power in deep sleep, in which RTCIO cannot be used as input, and RTCMEM can't work under high temperature
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default initializer for rtc_sleep_config_t
|
||||||
|
*
|
||||||
|
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
||||||
|
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
||||||
|
*
|
||||||
|
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
||||||
|
*/
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config);
|
||||||
|
|
||||||
/* Various delays to be programmed into power control state machines */
|
/* Various delays to be programmed into power control state machines */
|
||||||
#define RTC_CNTL_XTL_BUF_WAIT_SLP_US (500)
|
#define RTC_CNTL_XTL_BUF_WAIT_SLP_US (500)
|
||||||
#define RTC_CNTL_PLL_BUF_WAIT_SLP_CYCLES (1)
|
#define RTC_CNTL_PLL_BUF_WAIT_SLP_CYCLES (1)
|
||||||
|
@ -647,48 +647,18 @@ typedef struct {
|
|||||||
uint32_t dig_dbias_slp : 5; //!< set bias for digital domain, in sleep mode
|
uint32_t dig_dbias_slp : 5; //!< set bias for digital domain, in sleep mode
|
||||||
uint32_t rtc_dbias_wak : 5; //!< set bias for RTC domain, in active mode
|
uint32_t rtc_dbias_wak : 5; //!< set bias for RTC domain, in active mode
|
||||||
uint32_t rtc_dbias_slp : 5; //!< set bias for RTC domain, in sleep mode
|
uint32_t rtc_dbias_slp : 5; //!< set bias for RTC domain, in sleep mode
|
||||||
|
uint32_t dbg_atten_monitor : 4; //!< voltage parameter, in monitor mode
|
||||||
|
uint32_t bias_sleep_monitor : 1; //!< circuit control parameter, in monitor mode
|
||||||
|
uint32_t dbg_atten_slp : 4; //!< voltage parameter, in sleep mode
|
||||||
|
uint32_t bias_sleep_slp : 1; //!< circuit control parameter, in sleep mode
|
||||||
|
uint32_t pd_cur_monitor : 1; //!< circuit control parameter, in monitor mode
|
||||||
|
uint32_t pd_cur_slp : 1; //!< circuit control parameter, in sleep mode
|
||||||
uint32_t vddsdio_pd_en : 1; //!< power down VDDSDIO regulator
|
uint32_t vddsdio_pd_en : 1; //!< power down VDDSDIO regulator
|
||||||
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
||||||
uint32_t deep_slp_reject : 1;
|
uint32_t deep_slp_reject : 1;
|
||||||
uint32_t light_slp_reject : 1;
|
uint32_t light_slp_reject : 1;
|
||||||
} rtc_sleep_config_t;
|
} rtc_sleep_config_t;
|
||||||
|
|
||||||
/**
|
|
||||||
* Default initializer for rtc_sleep_config_t
|
|
||||||
*
|
|
||||||
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
|
||||||
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
|
||||||
*
|
|
||||||
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
|
||||||
*/
|
|
||||||
#define is_dslp(pd_flags) ((pd_flags) & RTC_SLEEP_PD_DIG)
|
|
||||||
#define RTC_SLEEP_CONFIG_DEFAULT(sleep_flags) { \
|
|
||||||
.lslp_mem_inf_fpu = 0, \
|
|
||||||
.rtc_mem_inf_follow_cpu = ((sleep_flags) & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0, \
|
|
||||||
.rtc_fastmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0, \
|
|
||||||
.rtc_slowmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0, \
|
|
||||||
.rtc_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0, \
|
|
||||||
.wifi_pd_en = ((sleep_flags) & RTC_SLEEP_PD_WIFI) ? 1 : 0, \
|
|
||||||
.bt_pd_en = ((sleep_flags) & RTC_SLEEP_PD_BT) ? 1 : 0, \
|
|
||||||
.cpu_pd_en = ((sleep_flags) & RTC_SLEEP_PD_CPU) ? 1 : 0, \
|
|
||||||
.int_8m_pd_en = ((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? 1 : 0, \
|
|
||||||
.dig_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_DIG_PERIPH) ? 1 : 0, \
|
|
||||||
.deep_slp = ((sleep_flags) & RTC_SLEEP_PD_DIG) ? 1 : 0, \
|
|
||||||
.wdt_flashboot_mod_en = 0, \
|
|
||||||
.dig_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.dig_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_SLP \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_SLP, \
|
|
||||||
.rtc_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.rtc_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_SLP \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_SLP, \
|
|
||||||
.vddsdio_pd_en = ((sleep_flags) & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0, \
|
|
||||||
.xtal_fpu = ((sleep_flags) & RTC_SLEEP_PD_XTAL) ? 0 : 1, \
|
|
||||||
.deep_slp_reject = 1, \
|
|
||||||
.light_slp_reject = 1 \
|
|
||||||
};
|
|
||||||
|
|
||||||
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
||||||
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
||||||
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
||||||
@ -702,6 +672,21 @@ typedef struct {
|
|||||||
#define RTC_SLEEP_PD_INT_8M BIT(10) //!< Power down Internal 8M oscillator
|
#define RTC_SLEEP_PD_INT_8M BIT(10) //!< Power down Internal 8M oscillator
|
||||||
#define RTC_SLEEP_PD_XTAL BIT(11) //!< Power down main XTAL
|
#define RTC_SLEEP_PD_XTAL BIT(11) //!< Power down main XTAL
|
||||||
|
|
||||||
|
//These flags are not power domains, but will affect some sleep parameters
|
||||||
|
#define RTC_SLEEP_DIG_USE_8M BIT(16)
|
||||||
|
#define RTC_SLEEP_USE_ADC_TESEN_MONITOR BIT(17)
|
||||||
|
#define RTC_SLEEP_NO_ULTRA_LOW BIT(18) //!< Avoid using ultra low power in deep sleep, in which RTCIO cannot be used as input, and RTCMEM can't work under high temperature
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default initializer for rtc_sleep_config_t
|
||||||
|
*
|
||||||
|
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
||||||
|
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
||||||
|
*
|
||||||
|
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
||||||
|
*/
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Prepare the chip to enter sleep mode
|
* @brief Prepare the chip to enter sleep mode
|
||||||
*
|
*
|
||||||
|
@ -666,48 +666,16 @@ typedef struct {
|
|||||||
uint32_t dig_dbias_slp : 5; //!< set bias for digital domain, in sleep mode
|
uint32_t dig_dbias_slp : 5; //!< set bias for digital domain, in sleep mode
|
||||||
uint32_t rtc_dbias_wak : 5; //!< set bias for RTC domain, in active mode
|
uint32_t rtc_dbias_wak : 5; //!< set bias for RTC domain, in active mode
|
||||||
uint32_t rtc_dbias_slp : 5; //!< set bias for RTC domain, in sleep mode
|
uint32_t rtc_dbias_slp : 5; //!< set bias for RTC domain, in sleep mode
|
||||||
|
uint32_t bias_sleep_monitor : 1; //!< circuit control parameter, in monitor mode
|
||||||
|
uint32_t bias_sleep_slp : 1; //!< circuit control parameter, in sleep mode
|
||||||
|
uint32_t pd_cur_monitor : 1; //!< circuit control parameter, in monitor mode
|
||||||
|
uint32_t pd_cur_slp : 1; //!< circuit control parameter, in sleep mode
|
||||||
uint32_t vddsdio_pd_en : 1; //!< power down VDDSDIO regulator
|
uint32_t vddsdio_pd_en : 1; //!< power down VDDSDIO regulator
|
||||||
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
||||||
uint32_t deep_slp_reject : 1;
|
uint32_t deep_slp_reject : 1;
|
||||||
uint32_t light_slp_reject : 1;
|
uint32_t light_slp_reject : 1;
|
||||||
} rtc_sleep_config_t;
|
} rtc_sleep_config_t;
|
||||||
|
|
||||||
/**
|
|
||||||
* Default initializer for rtc_sleep_config_t
|
|
||||||
*
|
|
||||||
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
|
||||||
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
|
||||||
*
|
|
||||||
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
|
||||||
*/
|
|
||||||
#define is_dslp(pd_flags) ((pd_flags) & RTC_SLEEP_PD_DIG)
|
|
||||||
#define RTC_SLEEP_CONFIG_DEFAULT(sleep_flags) { \
|
|
||||||
.lslp_mem_inf_fpu = 0, \
|
|
||||||
.rtc_mem_inf_follow_cpu = ((sleep_flags) & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0, \
|
|
||||||
.rtc_fastmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0, \
|
|
||||||
.rtc_slowmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0, \
|
|
||||||
.rtc_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0, \
|
|
||||||
.dig_ret_pd_en = ((sleep_flags) & RTC_SLEEP_PD_DIG_RET) ? 1 : 0, \
|
|
||||||
.bt_pd_en = ((sleep_flags) & RTC_SLEEP_PD_BT) ? 1 : 0, \
|
|
||||||
.cpu_pd_en = ((sleep_flags) & RTC_SLEEP_PD_CPU) ? 1 : 0, \
|
|
||||||
.int_8m_pd_en = ((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? 1 : 0, \
|
|
||||||
.dig_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_DIG_PERIPH) ? 1 : 0, \
|
|
||||||
.deep_slp = ((sleep_flags) & RTC_SLEEP_PD_DIG) ? 1 : 0, \
|
|
||||||
.wdt_flashboot_mod_en = 0, \
|
|
||||||
.dig_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.dig_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_SLP \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_SLP, \
|
|
||||||
.rtc_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.rtc_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_SLP \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_SLP, \
|
|
||||||
.vddsdio_pd_en = ((sleep_flags) & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0, \
|
|
||||||
.xtal_fpu = ((sleep_flags) & RTC_SLEEP_PD_XTAL) ? 0 : 1, \
|
|
||||||
.deep_slp_reject = 1, \
|
|
||||||
.light_slp_reject = 1 \
|
|
||||||
};
|
|
||||||
|
|
||||||
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
||||||
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
||||||
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
||||||
@ -721,6 +689,21 @@ typedef struct {
|
|||||||
#define RTC_SLEEP_PD_INT_8M BIT(10) //!< Power down Internal 8M oscillator
|
#define RTC_SLEEP_PD_INT_8M BIT(10) //!< Power down Internal 8M oscillator
|
||||||
#define RTC_SLEEP_PD_XTAL BIT(11) //!< Power down main XTAL
|
#define RTC_SLEEP_PD_XTAL BIT(11) //!< Power down main XTAL
|
||||||
|
|
||||||
|
//These flags are not power domains, but will affect some sleep parameters
|
||||||
|
#define RTC_SLEEP_DIG_USE_8M BIT(16)
|
||||||
|
#define RTC_SLEEP_USE_ADC_TESEN_MONITOR BIT(17)
|
||||||
|
#define RTC_SLEEP_NO_ULTRA_LOW BIT(18) //!< Avoid using ultra low power in deep sleep, in which RTCIO cannot be used as input, and RTCMEM can't work under high temperature
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default initializer for rtc_sleep_config_t
|
||||||
|
*
|
||||||
|
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
||||||
|
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
||||||
|
*
|
||||||
|
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
||||||
|
*/
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Prepare the chip to enter sleep mode
|
* @brief Prepare the chip to enter sleep mode
|
||||||
*
|
*
|
||||||
|
@ -673,47 +673,18 @@ typedef struct {
|
|||||||
uint32_t dig_dbias_slp : 3; //!< set bias for digital domain, in sleep mode
|
uint32_t dig_dbias_slp : 3; //!< set bias for digital domain, in sleep mode
|
||||||
uint32_t rtc_dbias_wak : 3; //!< set bias for RTC domain, in active mode
|
uint32_t rtc_dbias_wak : 3; //!< set bias for RTC domain, in active mode
|
||||||
uint32_t rtc_dbias_slp : 3; //!< set bias for RTC domain, in sleep mode
|
uint32_t rtc_dbias_slp : 3; //!< set bias for RTC domain, in sleep mode
|
||||||
|
uint32_t dbg_atten_monitor : 4; //!< voltage parameter, in monitor mode
|
||||||
|
uint32_t bias_sleep_monitor : 1; //!< circuit control parameter, in monitor mode
|
||||||
|
uint32_t dbg_atten_slp : 4; //!< voltage parameter, in sleep mode
|
||||||
|
uint32_t bias_sleep_slp : 1; //!< circuit control parameter, in sleep mode
|
||||||
|
uint32_t pd_cur_monitor : 1; //!< circuit control parameter, in monitor mode
|
||||||
|
uint32_t pd_cur_slp : 1; //!< circuit control parameter, in sleep mode
|
||||||
uint32_t vddsdio_pd_en : 1; //!< power down VDDSDIO regulator
|
uint32_t vddsdio_pd_en : 1; //!< power down VDDSDIO regulator
|
||||||
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
||||||
uint32_t deep_slp_reject : 1;
|
uint32_t deep_slp_reject : 1;
|
||||||
uint32_t light_slp_reject : 1;
|
uint32_t light_slp_reject : 1;
|
||||||
} rtc_sleep_config_t;
|
} rtc_sleep_config_t;
|
||||||
|
|
||||||
/**
|
|
||||||
* Default initializer for rtc_sleep_config_t
|
|
||||||
*
|
|
||||||
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
|
||||||
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
|
||||||
*
|
|
||||||
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
|
||||||
*/
|
|
||||||
#define is_dslp(pd_flags) ((pd_flags) & RTC_SLEEP_PD_DIG)
|
|
||||||
#define RTC_SLEEP_CONFIG_DEFAULT(sleep_flags) { \
|
|
||||||
.lslp_mem_inf_fpu = 0, \
|
|
||||||
.rtc_mem_inf_follow_cpu = ((sleep_flags) & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0, \
|
|
||||||
.rtc_fastmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0, \
|
|
||||||
.rtc_slowmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0, \
|
|
||||||
.rtc_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0, \
|
|
||||||
.wifi_pd_en = ((sleep_flags) & RTC_SLEEP_PD_WIFI) ? 1 : 0, \
|
|
||||||
.int_8m_pd_en = ((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? 1 : 0, \
|
|
||||||
.deep_slp = ((sleep_flags) & RTC_SLEEP_PD_DIG) ? 1 : 0, \
|
|
||||||
.wdt_flashboot_mod_en = 0, \
|
|
||||||
.dig_dbias_wak = RTC_CNTL_DIG_DBIAS_1V10, \
|
|
||||||
.dig_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DIG_DBIAS_0V90 \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DIG_DBIAS_1V10 \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_DIG_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DIG_DBIAS_0V90, \
|
|
||||||
.rtc_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.rtc_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_1V00 \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_XTAL) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_1V00, \
|
|
||||||
.vddsdio_pd_en = ((sleep_flags) & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0, \
|
|
||||||
.xtal_fpu = ((sleep_flags) & RTC_SLEEP_PD_XTAL) ? 0 : 1, \
|
|
||||||
.deep_slp_reject = 1, \
|
|
||||||
.light_slp_reject = 1 \
|
|
||||||
};
|
|
||||||
|
|
||||||
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
||||||
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
||||||
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
||||||
@ -724,6 +695,21 @@ typedef struct {
|
|||||||
#define RTC_SLEEP_PD_INT_8M BIT(7) //!< Power down Internal 8M oscillator
|
#define RTC_SLEEP_PD_INT_8M BIT(7) //!< Power down Internal 8M oscillator
|
||||||
#define RTC_SLEEP_PD_XTAL BIT(8) //!< Power down main XTAL
|
#define RTC_SLEEP_PD_XTAL BIT(8) //!< Power down main XTAL
|
||||||
|
|
||||||
|
//These flags are not power domains, but will affect some sleep parameters
|
||||||
|
#define RTC_SLEEP_DIG_USE_8M BIT(16)
|
||||||
|
#define RTC_SLEEP_USE_ADC_TESEN_MONITOR BIT(17)
|
||||||
|
#define RTC_SLEEP_NO_ULTRA_LOW BIT(18) //!< Avoid using ultra low power in deep sleep, in which RTCIO cannot be used as input, and RTCMEM can't work under high temperature
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default initializer for rtc_sleep_config_t
|
||||||
|
*
|
||||||
|
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
||||||
|
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
||||||
|
*
|
||||||
|
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
||||||
|
*/
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Prepare the chip to enter sleep mode
|
* @brief Prepare the chip to enter sleep mode
|
||||||
*
|
*
|
||||||
|
@ -654,48 +654,18 @@ typedef struct {
|
|||||||
uint32_t dig_dbias_slp : 5; //!< set bias for digital domain, in sleep mode
|
uint32_t dig_dbias_slp : 5; //!< set bias for digital domain, in sleep mode
|
||||||
uint32_t rtc_dbias_wak : 5; //!< set bias for RTC domain, in active mode
|
uint32_t rtc_dbias_wak : 5; //!< set bias for RTC domain, in active mode
|
||||||
uint32_t rtc_dbias_slp : 5; //!< set bias for RTC domain, in sleep mode
|
uint32_t rtc_dbias_slp : 5; //!< set bias for RTC domain, in sleep mode
|
||||||
|
uint32_t dbg_atten_monitor : 4; //!< voltage parameter, in monitor mode
|
||||||
|
uint32_t bias_sleep_monitor : 1; //!< circuit control parameter, in monitor mode
|
||||||
|
uint32_t dbg_atten_slp : 4; //!< voltage parameter, in sleep mode
|
||||||
|
uint32_t bias_sleep_slp : 1; //!< circuit control parameter, in sleep mode
|
||||||
|
uint32_t pd_cur_monitor : 1; //!< circuit control parameter, in monitor mode
|
||||||
|
uint32_t pd_cur_slp : 1; //!< circuit control parameter, in sleep mode
|
||||||
uint32_t vddsdio_pd_en : 1; //!< power down VDDSDIO regulator
|
uint32_t vddsdio_pd_en : 1; //!< power down VDDSDIO regulator
|
||||||
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
uint32_t xtal_fpu : 1; //!< keep main XTAL powered up in sleep
|
||||||
uint32_t deep_slp_reject : 1;
|
uint32_t deep_slp_reject : 1;
|
||||||
uint32_t light_slp_reject : 1;
|
uint32_t light_slp_reject : 1;
|
||||||
} rtc_sleep_config_t;
|
} rtc_sleep_config_t;
|
||||||
|
|
||||||
/**
|
|
||||||
* Default initializer for rtc_sleep_config_t
|
|
||||||
*
|
|
||||||
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
|
||||||
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
|
||||||
*
|
|
||||||
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
|
||||||
*/
|
|
||||||
#define is_dslp(pd_flags) ((pd_flags) & RTC_SLEEP_PD_DIG)
|
|
||||||
#define RTC_SLEEP_CONFIG_DEFAULT(sleep_flags) { \
|
|
||||||
.lslp_mem_inf_fpu = 0, \
|
|
||||||
.rtc_mem_inf_follow_cpu = ((sleep_flags) & RTC_SLEEP_PD_RTC_MEM_FOLLOW_CPU) ? 1 : 0, \
|
|
||||||
.rtc_fastmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_FAST_MEM) ? 1 : 0, \
|
|
||||||
.rtc_slowmem_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_SLOW_MEM) ? 1 : 0, \
|
|
||||||
.rtc_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_RTC_PERIPH) ? 1 : 0, \
|
|
||||||
.wifi_pd_en = ((sleep_flags) & RTC_SLEEP_PD_WIFI) ? 1 : 0, \
|
|
||||||
.bt_pd_en = ((sleep_flags) & RTC_SLEEP_PD_BT) ? 1 : 0, \
|
|
||||||
.cpu_pd_en = ((sleep_flags) & RTC_SLEEP_PD_CPU) ? 1 : 0, \
|
|
||||||
.int_8m_pd_en = ((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? 1 : 0, \
|
|
||||||
.dig_peri_pd_en = ((sleep_flags) & RTC_SLEEP_PD_DIG_PERIPH) ? 1 : 0, \
|
|
||||||
.deep_slp = ((sleep_flags) & RTC_SLEEP_PD_DIG) ? 1 : 0, \
|
|
||||||
.wdt_flashboot_mod_en = 0, \
|
|
||||||
.dig_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.dig_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_SLP \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_SLP, \
|
|
||||||
.rtc_dbias_wak = RTC_CNTL_DBIAS_1V10, \
|
|
||||||
.rtc_dbias_slp = is_dslp(sleep_flags) ? RTC_CNTL_DBIAS_SLP \
|
|
||||||
: !((sleep_flags) & RTC_SLEEP_PD_INT_8M) ? RTC_CNTL_DBIAS_1V10 \
|
|
||||||
: RTC_CNTL_DBIAS_SLP, \
|
|
||||||
.vddsdio_pd_en = ((sleep_flags) & RTC_SLEEP_PD_VDDSDIO) ? 1 : 0, \
|
|
||||||
.xtal_fpu = ((sleep_flags) & RTC_SLEEP_PD_XTAL) ? 0 : 1, \
|
|
||||||
.deep_slp_reject = 1, \
|
|
||||||
.light_slp_reject = 1 \
|
|
||||||
};
|
|
||||||
|
|
||||||
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
#define RTC_SLEEP_PD_DIG BIT(0) //!< Deep sleep (power down digital domain)
|
||||||
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
#define RTC_SLEEP_PD_RTC_PERIPH BIT(1) //!< Power down RTC peripherals
|
||||||
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
#define RTC_SLEEP_PD_RTC_SLOW_MEM BIT(2) //!< Power down RTC SLOW memory
|
||||||
@ -709,6 +679,21 @@ typedef struct {
|
|||||||
#define RTC_SLEEP_PD_INT_8M BIT(10) //!< Power down Internal 8M oscillator
|
#define RTC_SLEEP_PD_INT_8M BIT(10) //!< Power down Internal 8M oscillator
|
||||||
#define RTC_SLEEP_PD_XTAL BIT(11) //!< Power down main XTAL
|
#define RTC_SLEEP_PD_XTAL BIT(11) //!< Power down main XTAL
|
||||||
|
|
||||||
|
//These flags are not power domains, but will affect some sleep parameters
|
||||||
|
#define RTC_SLEEP_DIG_USE_8M BIT(16)
|
||||||
|
#define RTC_SLEEP_USE_ADC_TESEN_MONITOR BIT(17)
|
||||||
|
#define RTC_SLEEP_NO_ULTRA_LOW BIT(18) //!< Avoid using ultra low power in deep sleep, in which RTCIO cannot be used as input, and RTCMEM can't work under high temperature
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default initializer for rtc_sleep_config_t
|
||||||
|
*
|
||||||
|
* This initializer sets all fields to "reasonable" values (e.g. suggested for
|
||||||
|
* production use) based on a combination of RTC_SLEEP_PD_x flags.
|
||||||
|
*
|
||||||
|
* @param RTC_SLEEP_PD_x flags combined using bitwise OR
|
||||||
|
*/
|
||||||
|
void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_config);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Prepare the chip to enter sleep mode
|
* @brief Prepare the chip to enter sleep mode
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user