我正在为 STANDBY 模式调整stm32l100
。 MCU 应该每秒唤醒2次。为此,我使用 RTC唤醒定时器。但在 MCU 进入 STANDBY 模式之后,它会立即唤醒。
如果改为 STANDBY 模式,我使用简单的睡眠模式( __ WFI ),一切正常。
我的代码在这里
MCU 启动后
一个。保存标志 CSR_SBF 和 CSR_WUF ,然后清除它们。
if (PWR->CSR & PWR_CSR_SBF_BIT) {
// ...
}
if (PWR->CSR & PWR_CSR_WUF_BIT) {
// ...
}
PWR->CR |= PWR_CR_CSBF_BIT|PWR_CR_CWUF_BIT;
//while (PWR->CSR & PWR_CSR_SBF_BIT);
while (PWR->CSR & PWR_CSR_WUF_BIT);
我注意到 CSR_SBF 永远不会清除。如果我用while
取消注释字符串,那么 MCU 就会停止。我不明白为什么。
湾保存重置源标志,然后清除它们。
volatile uint32_t csr;
csr = RCC->CSR;
// .... saving
// clear flags
RCC->CSR |= RCC_CSR_RMVF_BIT;
MCU 从 STANDBY 中醒来后,所有复位源标志都被清除。似乎缺少重置源,但代码是从0x0执行的。
调整 RTC唤醒定时器
void rtc_set_wakeup_mode(const uint32_t wakeup_counter)
{
RTC_WRITE_PROTECT_DISABLE();
RTC->CR &= ~RTC_CR_WUTE_BIT;
while (!(RTC->ISR & RTC_ISR_WUTWF_BIT));
RTC->WUTR = wakeup_counter;
RTC->CR &= 0xfffffff7;
RTC->CR |= RTC_WAKEUPCLOCK_RTCCLK_DIV2;
__HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_IT();
__HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE();
RTC->CR |= RTC_CR_WUTIE_BIT|RTC_CR_WUTE_BIT;
RTC_WRITE_PROTECT_ENABLE();
}
进入 STANDBY 模式
void pwdm_enter_standby_mode(void)
{
PWR->CR |= PWR_CR_PDDS_BIT;
SCB->SCR |= SCB_SCR_SLEEPDEEP_BIT;
__WFI();
}
答案 0 :(得分:1)
所以,最后我明白了。
启动初始化是我自己的失败。关键在于:
我注意到CSR_SBF永远不会清除。如果我用while取消注释字符串 然后MCU停在它的地方。我不明白为什么。
我在main
的开头使用唤醒/待机标记放置了代码。但是这段代码没有执行此操作__HAL_RCC_PWR_CLK_ENABLE();
,因为该操作将在oscill初始化例程中执行。因此,PWR->CSR
处于未定义状态,PWR_CSR_WUF
标志永远不会清除。