|
|
@@ -79,36 +79,89 @@ void rtc_sleep_get_default_config(uint32_t sleep_flags, rtc_sleep_config_t *out_
|
|
|
};
|
|
|
|
|
|
if (sleep_flags & RTC_SLEEP_PD_DIG) {
|
|
|
- unsigned atten_deep_sleep = RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT;
|
|
|
-#if CONFIG_ESP32C3_REV_MIN_FULL < 3
|
|
|
+ assert(sleep_flags & RTC_SLEEP_PD_XTAL);
|
|
|
+ bool eco2_workaround = false;
|
|
|
+ #if CONFIG_ESP32C3_REV_MIN_FULL < 3
|
|
|
if (!ESP_CHIP_REV_ABOVE(efuse_hal_chip_revision(), 3)) {
|
|
|
- atten_deep_sleep = 0; /* workaround for deep sleep issue in high temp on ECO2 and below */
|
|
|
+ eco2_workaround = true; /* 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;
|
|
|
+ #endif
|
|
|
+ if (!(sleep_flags & RTC_SLEEP_PD_INT_8M)) {
|
|
|
+ /*
|
|
|
+ * dbg_att_slp need to set to 0: rtc voltage is about 0.83v
|
|
|
+ * support all features:
|
|
|
+ * - 8MD256 as RTC slow clock src
|
|
|
+ * - RTC memory under high temperature
|
|
|
+ * - RTC IO as input
|
|
|
+ */
|
|
|
+ out_config->rtc_regulator_fpu = 1;
|
|
|
+ out_config->dbg_atten_slp = RTC_CNTL_DBG_ATTEN_DEEPSLEEP_NODROP;
|
|
|
+ out_config->rtc_dbias_slp = 0;
|
|
|
+ } else if (sleep_flags & RTC_SLEEP_NO_ULTRA_LOW) {
|
|
|
+ /*
|
|
|
+ * Default mode
|
|
|
+ * rtc voltage in sleep need stable and not less than 0.7v
|
|
|
+ * support features:
|
|
|
+ * - RTC memory under high temperature
|
|
|
+ * - RTC IO as input
|
|
|
+ */
|
|
|
+ out_config->rtc_regulator_fpu = 1;
|
|
|
+ out_config->dbg_atten_slp = eco2_workaround ? RTC_CNTL_DBG_ATTEN_DEEPSLEEP_NODROP: RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT;
|
|
|
+ out_config->rtc_dbias_slp = RTC_CNTL_RTC_DBIAS_DEEPSLEEP_0V7;
|
|
|
+ } else {
|
|
|
+ /*
|
|
|
+ * rtc regulator not opened and rtc voltage is about 0.66v (ultra low power):
|
|
|
+ * not support features:
|
|
|
+ * - RTC IO as input
|
|
|
+ * - RTC memory under high temperature
|
|
|
+ */
|
|
|
+ out_config->rtc_regulator_fpu = 0;
|
|
|
+ out_config->dbg_atten_slp = eco2_workaround ? RTC_CNTL_DBG_ATTEN_DEEPSLEEP_NODROP: RTC_CNTL_DBG_ATTEN_DEEPSLEEP_DEFAULT;
|
|
|
+ out_config->rtc_dbias_slp = 0; /* not used */
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ out_config->rtc_regulator_fpu = 1;
|
|
|
+ // rtc & digital voltage from high to low
|
|
|
+ if ((sleep_flags & RTC_SLEEP_DIG_USE_8M) || !(sleep_flags & RTC_SLEEP_PD_XTAL)) {
|
|
|
+ /*
|
|
|
+ * digital voltage need to be >= 1.1v
|
|
|
+ * if 8MD256 select as RTC slow clock src, only need dbg_atten_slp set to 0
|
|
|
+ * Support all features:
|
|
|
+ * - XTAL
|
|
|
+ * - RC 8M used by digital system
|
|
|
+ * - 8MD256 as RTC slow clock src
|
|
|
+ */
|
|
|
+ out_config->dbg_atten_slp = RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_NODROP;
|
|
|
+ out_config->dig_dbias_slp = RTC_CNTL_DBIAS_1V10;
|
|
|
+ out_config->rtc_dbias_slp = RTC_CNTL_DBIAS_1V10;
|
|
|
+ } else if (!(sleep_flags & RTC_SLEEP_PD_INT_8M)){
|
|
|
+ /*
|
|
|
+ * dbg_att_slp need to set to 0: digital voltage is about 0.67v & rtc vol is about 0.83v
|
|
|
+ * Support features:
|
|
|
+ * - 8MD256 as RTC slow clock src
|
|
|
+ */
|
|
|
+ out_config->dbg_atten_slp = RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_NODROP;
|
|
|
+ out_config->dig_dbias_slp = 0;
|
|
|
+ out_config->rtc_dbias_slp = 0;
|
|
|
+ } else {
|
|
|
+ /*
|
|
|
+ * digital voltage not less than 0.6v.
|
|
|
+ * not support features:
|
|
|
+ * - XTAL
|
|
|
+ * - RC 8M used by digital system
|
|
|
+ * - 8MD256 as RTC slow clock src
|
|
|
+ */
|
|
|
+ out_config->dbg_atten_slp = RTC_CNTL_DBG_ATTEN_LIGHTSLEEP_DEFAULT;
|
|
|
+ out_config->dig_dbias_slp = RTC_CNTL_DIG_DBIAS_LIGHTSLEEP_0V6;
|
|
|
+ out_config->rtc_dbias_slp = RTC_CNTL_RTC_DBIAS_LIGHTSLEEP_0V6;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (!(sleep_flags & RTC_SLEEP_PD_XTAL)) {
|
|
|
+ out_config->bias_sleep_slp = RTC_CNTL_BIASSLP_SLEEP_ON;
|
|
|
+ out_config->pd_cur_slp = RTC_CNTL_PD_CUR_SLEEP_ON;
|
|
|
+ } else {
|
|
|
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;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
@@ -142,20 +195,19 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|
|
} else {
|
|
|
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);
|
|
|
+ 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_PD_CUR_MONITOR, RTC_CNTL_PD_CUR_MONITOR_DEFAULT);
|
|
|
|
|
|
+ assert(!cfg.pd_cur_slp || cfg.bias_sleep_slp);
|
|
|
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_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) {
|
|
|
REGI2C_WRITE_MASK(I2C_ULP, I2C_ULP_IR_FORCE_XPD_CK, 0);
|
|
|
- CLEAR_PERI_REG_MASK(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU);
|
|
|
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
|
|
CLEAR_PERI_REG_MASK(RTC_CNTL_ANA_CONF_REG,
|
|
|
RTC_CNTL_CKGEN_I2C_PU | RTC_CNTL_PLL_I2C_PU |
|
|
|
@@ -164,12 +216,11 @@ void rtc_sleep_init(rtc_sleep_config_t cfg)
|
|
|
} else {
|
|
|
SET_PERI_REG_MASK(RTC_CNTL_BIAS_CONF_REG, RTC_CNTL_DG_VDD_DRV_B_SLP_EN);
|
|
|
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);
|
|
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_DG_WRAP_PD_EN);
|
|
|
}
|
|
|
/* mem force pu */
|
|
|
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_LSLP_MEM_FORCE_PU);
|
|
|
-
|
|
|
+ REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_REGULATOR_FORCE_PU, cfg.rtc_regulator_fpu);
|
|
|
if (!cfg.int_8m_pd_en) {
|
|
|
SET_PERI_REG_MASK(RTC_CNTL_CLK_CONF_REG, RTC_CNTL_CK8M_FORCE_PU);
|
|
|
SET_PERI_REG_MASK(RTC_CNTL_CLK_CONF_REG, RTC_CNTL_CK8M_FORCE_NOGATING);
|