亲测实验,stm32待机模式和停机模式唤醒程序的区别,以及唤醒后
这两天研究了STM32的低功耗知识,低功耗里主要研究的是STM32的待机模式和停机模式。让单片机进入的待机模式和停机模式比较容易,实验中通过设置中断口PA1来响应待机和停机模式。 void EXTI1_IRQHandler(void) RTC_SetAlarm(RTC_GetCounter()+4); ?//设置4S后闹钟唤醒 Standby(); ? ? ? ? ? ? //进入待机(停机)状态 }
PWR_WakeUpPinCmd(ENABLE);//使能唤醒引脚,默认PA0 ? ? ? ? ?PWR_EnterSTANDBYMode();//进入待机
主要问题有: 1:如何对他们进行唤醒? 2:唤醒的闹钟中断能否执行? 2:唤醒后的程序入口在哪? 通过各种实验和查资料,得到了如下结论:(本实验通过设定RTC_SetAlarm(RTC_GetCounter()+4); 为设置4S后进行闹钟唤醒,并开启闹钟中断,手册中可以查到闹钟中断能产生唤醒,故用闹钟中断进行实验) 先研究待机模式下的唤醒,在闹钟中断函数如下: void RTCAlarm_IRQHandler(void)
} 实验结果:PA5的LED不指示,并且从其他LED灯的指示可以知道程序又重新开始运行。也就是被复位。 因此待机模式下的唤醒结论如下: 1:唤醒形式直接产生闹钟中断就能唤醒。 2:唤醒后不会进入闹钟中断函数 3:唤醒后程序复位,重新执行 ? 再研究停机模式下的唤醒,停机模式唤醒和待机唤醒差别很大,开始还以为两者相同,停机唤醒相对复杂些,中途调试了很长时间,才明白了停机唤醒的过程,贴上闹钟中断程序如下: char Wakeflag=0; void RTCAlarm_IRQHandler(void) ? ? ? if(PWR_GetFlagStatus(PWR_FLAG_WU) != RESET) ? ? ? ?Wakeflag=!Wakeflag; } 相比待机的闹钟中断是不复杂了很多,停机模式下的唤醒的中断函数需要注意这两点(能得到这两点,耗费了大量时间,终于还是搞定了,嗨皮!!): 1:重要,对于程序可能产生的标志位必须的清除干净,不清除会出现唤醒失灵现象!! 2:重要,由于停机下对所有时钟关闭,所以唤醒需要重新配置时钟!! 实验现象:LED可以产生开通与关断的效果。并且从其他LED的指示可以看到程序没有被复位,而是继续原来运行。 因此停机模式下的唤醒结论如下: 1:唤醒形式产生闹钟中断不一定就唤醒,需要对任何可能的标志位清楚,并且时钟要重新配置。 2:唤醒后进入闹钟中断函数 3:唤醒后程序进入闹钟中断函数,然后再进入原来停机的位置继续运行。没有复位,单片机寄存器里的各种变量值仍然保留!! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |