STM32 低功耗模式STOP、STANDBY配合RTC应用实例

项目背景
目标:进入低功耗模式120s左右唤醒。
结果:完成低功耗驱动,完成RTC定时驱动,完成目标;
Tip:使用一个新的模块时应主要参考官方文档和官方例程,有问题再上网寻找思路;(本文使用的例程在最后 )
环境:STM32F205、 IAR6.7、J-Link
:因为考虑到项目以后需要移植到 stm32F0系列上,而且 stm32F0系列没有 backup SRAM,所以这部分驱动不使用 backup SRAM;

注意:看门狗是不能开启的,否则会在sleep时watch dog重启;
一、STOP模式 +RTC
STOP模式: 可以理解为程序进入STOP模式后会暂停运行,直到中断触发退出STOP模式,程序会从刚刚停止的地方继续运行;
代码思路 :
1.进入低功耗模式之前,我们首先要关闭所有外设 ;
2.参考官方例程,对官方例程中的RTC 1s唤醒一次,修改里面的时钟配置,得到RTC 120s唤醒;
所以重点是时钟配置:
时钟选择 LSE(外部时钟),比LSI(内部时钟)更为精准;根据自己使用的晶振不同,有不同的频率。我的时钟源是 32.768kHz;
查看官方 STM32F205 参考手册(RM0033) 22.3 章节可知,
RTC wakeup时钟可以有各种 2,4,8,16分频选择,也可以自己配置分频;
但是 wakeup的计数寄存器只有 0-0xFFFF,计算一下,如果是32.768kHz的16分频,也就是
频率 32.768kHz */16=2048Hz
那么 即使计数寄存器走满,也只有
0xFFFF/2048Hz=31秒
31秒
这么短算什么男人!
区区31秒不能满足我们!
额,是不能满足的120s定时唤醒的要求。不过没关系,自己动手,丰衣足食。
那就只能自己配置分频了,计算公式都在手册上:

STM32 低功耗模式STOP、STANDBY配合RTC应用实例_第1张图片
上面的这个RTCCLK = 32.768kHz,PREDIV_S配置为 07,PREDIV_A配置为 07,
分频结果时钟是 512hz;
然后设置 RTC_WAKEUPCOUNTER(TIME * 512); 时钟配置结束
3.打开RTC wakeup
4.进入 STOP mode,设置WFI
这时要注意,进入STOP模式可以理解为程序会暂停,直到中断触发退出STOP模式,程序会从刚刚停止的地方继续运行;
5.默默等待120s,good,RTC中断触发了;
6.关闭RTCwakeup,并且反初始化RTC相关(就是各种不使能);
7.恢复之前关闭的外设;(大功告成)

二、STANDBY模式 +RTC
STANDBY 模式是最极限的低功耗模式了,内部SRAM也会断电,换句话说,进入STANDBY 模式再唤醒是和重启一样的,所有在SRAM中的参数都会丢失,程序从头开始;
代码思路和STOP模式基本一致,但是有个很大的坑在这里面:
基本流程:程序正在运行->配置并且开启RTC中断->进入STANDBY 模式->RTC中断->程序从头开始运行
以为这样就行了?图样图森破!忘记了之前开启RTC中断!这个中断并没有关!所以一定要在程序从头开始运行的时候把RTC中断关上。
很简单,在开头加上一点处理:
⑴使能时钟 APB1Periph PWR
⑵允许配置RTC
⑶然后就是关关关 RTC 时钟,RTCwakeup使能!中断使能等等!!!

最后是源码,要啥源码?不就是 ST的官方例程嘛。(手动滑稽)

你可能感兴趣的:(STM32)