|
|
@@ -265,6 +265,29 @@ void rtc_clk_apll_enable(bool enable, uint32_t sdm0, uint32_t sdm1, uint32_t sdm
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+void rtc_clk_set_xtal_wait(void)
|
|
|
+{
|
|
|
+ /*
|
|
|
+ the `xtal_wait` time need 1ms, so we need calibrate slow clk period,
|
|
|
+ and `RTC_CNTL_XTL_BUF_WAIT` depend on it.
|
|
|
+ */
|
|
|
+ rtc_slow_freq_t slow_clk_freq = rtc_clk_slow_freq_get();
|
|
|
+ rtc_slow_freq_t rtc_slow_freq_x32k = RTC_SLOW_FREQ_32K_XTAL;
|
|
|
+ rtc_slow_freq_t rtc_slow_freq_8MD256 = RTC_SLOW_FREQ_8MD256;
|
|
|
+ rtc_cal_sel_t cal_clk = RTC_CAL_RTC_MUX;
|
|
|
+ if (slow_clk_freq == (rtc_slow_freq_x32k)) {
|
|
|
+ cal_clk = RTC_CAL_32K_XTAL;
|
|
|
+ } else if (slow_clk_freq == rtc_slow_freq_8MD256) {
|
|
|
+ cal_clk = RTC_CAL_8MD256;
|
|
|
+ }
|
|
|
+ uint32_t slow_clk_period = rtc_clk_cal(cal_clk, 2000);
|
|
|
+ uint32_t xtal_wait_1ms = 100;
|
|
|
+ if (slow_clk_period) {
|
|
|
+ xtal_wait_1ms = (1000 << RTC_CLK_CAL_FRACT) / slow_clk_period;
|
|
|
+ }
|
|
|
+ REG_SET_FIELD(RTC_CNTL_TIMER1_REG, RTC_CNTL_XTL_BUF_WAIT, xtal_wait_1ms);
|
|
|
+}
|
|
|
+
|
|
|
void rtc_clk_slow_freq_set(rtc_slow_freq_t slow_freq)
|
|
|
{
|
|
|
REG_SET_FIELD(RTC_CNTL_CLK_CONF_REG, RTC_CNTL_ANA_CLK_RTC_SEL, slow_freq);
|
|
|
@@ -275,6 +298,11 @@ void rtc_clk_slow_freq_set(rtc_slow_freq_t slow_freq)
|
|
|
REG_SET_FIELD(RTC_CNTL_CLK_CONF_REG, RTC_CNTL_DIG_XTAL32K_EN,
|
|
|
(slow_freq == RTC_SLOW_FREQ_32K_XTAL) ? 1 : 0);
|
|
|
|
|
|
+ /* The clk_8m_d256 will be closed when rtc_state in SLEEP,
|
|
|
+ so if the slow_clk is 8md256, clk_8m must be force power on
|
|
|
+ */
|
|
|
+ REG_SET_FIELD(RTC_CNTL_CLK_CONF_REG,RTC_CNTL_CK8M_FORCE_PU, (slow_freq == RTC_SLOW_FREQ_8MD256) ? 1 : 0);
|
|
|
+ rtc_clk_set_xtal_wait();
|
|
|
ets_delay_us(DELAY_SLOW_CLK_SWITCH);
|
|
|
}
|
|
|
|
|
|
@@ -458,6 +486,7 @@ static void rtc_clk_cpu_freq_to_xtal(void)
|
|
|
|
|
|
rtc_clk_apb_freq_update(xtal_freq * MHZ);
|
|
|
s_cur_freq = RTC_CPU_FREQ_XTAL;
|
|
|
+ s_cur_pll = RTC_PLL_NONE;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
@@ -570,12 +599,15 @@ void rtc_clk_cpu_freq_set(rtc_cpu_freq_t cpu_freq)
|
|
|
}
|
|
|
|
|
|
if ((cpu_freq == RTC_CPU_FREQ_80M) || (cpu_freq == RTC_CPU_320M_80M)) {
|
|
|
+ REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DIG_DBIAS_WAK, DIG_DBIAS_80M_160M);
|
|
|
DPORT_REG_SET_FIELD(DPORT_CPU_PER_CONF_REG, DPORT_CPUPERIOD_SEL, 0);
|
|
|
ets_update_cpu_frequency(80);
|
|
|
} else if ((cpu_freq == RTC_CPU_FREQ_160M) || (cpu_freq == RTC_CPU_320M_160M)) {
|
|
|
+ REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DIG_DBIAS_WAK, DIG_DBIAS_80M_160M);
|
|
|
DPORT_REG_SET_FIELD(DPORT_CPU_PER_CONF_REG, DPORT_CPUPERIOD_SEL, 1);
|
|
|
ets_update_cpu_frequency(160);
|
|
|
} else if (cpu_freq == RTC_CPU_FREQ_240M) {
|
|
|
+ REG_SET_FIELD(RTC_CNTL_REG, RTC_CNTL_DIG_DBIAS_WAK, DIG_DBIAS_240M);
|
|
|
DPORT_REG_SET_FIELD(DPORT_CPU_PER_CONF_REG, DPORT_CPUPERIOD_SEL, 2);
|
|
|
ets_update_cpu_frequency(240);
|
|
|
}
|