停机形式:任一外部中止能够唤醒,体系保存代码运转状况,唤醒前后要别离进行电源办理装备和时钟装备。
示例:
停机形式进入之前:
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);
printf(“进入中止形式 “);
PWR_EnterSTOPMode(PWR_Regulator_LowPower,PWR_STOPEntry_WFI);
停机形式唤醒之后:
void SYSCLKConfig_STOP(void)
{
ErrorStatus HSEStartUpStatus;
}
为了验证程序唤醒后是不是从进入停机形式那一条句子接着运转,我进行如下编程:
int main(void)
{
LED_GPIO_Config();
EXTI_Key_Config();
SysTick_Init();
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);//电源办理
while(1)
{
LED1( ON );
Delay_us(100000); // 10000 * 10us = 100ms
LED1( OFF );
// SysTick->CTRL &= ~ SysTick_CTRL_ENABLE_Msk;
PWR_EnterSTOPMode(PWR_Regulator_LowPower,PWR_STOPEntry_WFI);
LED2( ON );
Delay_us(100000); // 10000 * 10us = 100ms
LED2( OFF );
LED3( ON );
Delay_us(100000); // 10000 * 10us = 100ms
LED3( OFF );
}
}
发现底子不进入停机形式,文档上写着:为了进入中止形式,一切的外部中止的恳求位(挂起寄存器(EXTI_PR))和RTC的闹钟标志都必须被铲除,不然中止形式的进入流程将会被越过,程序持续运转。我看看外部中止的标志也都请了啊,怎么回事?进一步研讨发现,SysTick_Init()里边并没有翻开systick,而是在Delay_us(100000)里边翻开的,那么我在进入停机之前应该关掉,所以把上述程序中的SysTick->CTRL &= ~ SysTick_CTRL_ENABLE_Msk翻开就好啦,嘎嘎!