你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【经验分享】STM32L4系列单片机的低功耗问题

[复制链接]
STMCU小助手 发布时间:2022-1-2 09:00
基于STM32L4系列单片机的低功耗问题
% Z# u$ X% g0 {% [
2 C- p$ A3 v$ |, i4 E4 M2 e首先看ST关于L4系列的官方文档官方给出了多个低功耗模式并且介绍了这几种模式
% Q0 T; |9 j2 ^8 a* Y) NSleep mode:CUP时钟关闭,IO口保持与运行状态相同的状态。可由wake事件,NVIC,SysTick,外部中断等,无唤醒时间,唤醒后执行唤醒源中断回调函数(和标准库中断服务函数功能一样,但意义不同),然后按原来代码执行
9 {2 s4 P; Z( k  M3 Q
/ R) s5 C$ R5 v( S/ X" T) S8 B**Low-power run mode:**当系统时钟频率降低到2MHZ以下时,即可实现此模式。代码可从SRAM或闪存中执行。调整器处于低功耗模式,以最小化调整器的工作电流。IO口保持与运行状态相同的状态,退出此模式需按照三步1:清除PWR CR1寄存器中的LPR位,强制调整器进入主模式。2:等待直到PWR SR2寄存器中的REGLPF 位被清除3:增加时钟频率: C3 ^( Q' l# V

+ I+ Y4 B) ]+ bLow-power sleep mode: 此模式从Low-power run mode进入,IO口状态与运行模式相同,可由外部中断,wake事件唤醒,无唤醒时间,唤醒后执行中断回调函数,后按原来代码执行
9 r; B5 Q; f. k) d2 I
4 K0 A- H# }# u0 `. j! w**Stop 0, Stop 1 and Stop 2 modes:**此模式中SRAM1,SRAM2和寄存器中的内容都将保留,所有时钟在VCORE 域停止,PLL,MSI,HSI16,HSE禁止。LSE和LSI保持运行,RTC可保持运行,一些具有唤醒功能的外设也可等待唤醒条件。在STOP2模式下,大多数的VCORE域处于低泄漏状态。SPOP1模式提供了最多数量的活动外设和唤醒源,唤醒时间较小,但电流比STOP2消耗更多,在STOP0模式主调节器仍然时开着的,这允许最快的唤醒时间,但消耗多。功耗大小SPOP2< STOP1<STOP0.可由wake事件,外部中断唤醒。当退出SPOP模式时时钟源可选MSI或HSI16这取决于软件配置。退出后执行唤醒源中断回调,后按主代码执行。
3 C& G0 b" H4 G8 `" g: C% W+ u3 W5 b% [" G' m
Standby mode: VCORE域是关闭电源的。然而,它可以保留SRAM2的内容:待机模式与SRAM2保留当位RRS被设置在CR3寄存器,在这种情况下。SRAM2由低功率调节器提供。在PWR CR3寄存器中清除位RRS时的备用模式。在这种情况下,主调节器和低功率调节器电源关闭,所有的时钟在VCORE域停止,PLL,MSI,HSI16和HSE被禁止。LSI和LSE可以继续运行。IO口可配置位上拉或下拉或模拟。RTC可以保持。外部中断和wake时间唤醒等可退出Standby模式,唤醒后系统复位* T: Y. h& k- Q" B8 Q4 z& l7 i

& _! }9 y9 k2 K2 j8 W# ^4 h**Shutdown:**VCORE域电源关闭,所有时钟在VCORE停止,PLL,MSI,HSI16,HSE禁止,LSE可以保持运行,系统时钟,当退出Shutdowm模式MSI在4MHZ在这种模式下电源监控是关闭的。IO口可配置成 上拉,下拉,模拟。可用wake事件唤醒,io口外部中断,唤醒后系统复位。
- o. B' c* Z8 J6 C+ _0 W几种模式的相互转换关系:7 ?5 F$ H8 r8 F7 ~# M8 }, X' J5 K

" s" k+ |$ ]. e4 g0 c/ E, t, M
20201215085233410.png
# j* H8 p7 r4 P  U% U

  ~. H" b5 ~; H8 x1 _- Q" s& f由这几种模式转换且保持系统运行无异常,最初我选择了Run mode(运行)和Shutdown mode 和Standby mode 模式进行测试,手里的板子的MCU是STM32L31RCT6.对比官方库中的测试和自己的工程看电流,刚开始测试的时候电流差距很大,首先找硬件原因,因为我使用的不是ST官方的板,无引出的电流测试点,所以我测的是整体板子的电流,我所使用的板子比较简单,无任何外设,去除5转3.3芯片,直接使用3.3v供电,单片机的启动模式为模式0在FLASH中启动 BOOT0和B00T1设置为上拉电阻。(BOOT0和BOOT1一定要处理好影响电流很大)" g3 B. d% Z2 H; c$ p  j

7 ^, s4 t- \/ w& `7 h) Z/ t1 S# k, n首先单独测试Shutdown模式,最初测试的时候电流还是很大,在经过硬件与软件的结合后最终电流最低可达到0.03uA 且可由外部中断唤醒。加上RTC周期唤醒后,电流最低到0.52uA# @/ d- `* O( v; N
20201215085332654.png

/ k" _& d8 P& y% a+ `0 I" F: U0 f( B: g0 ^, A  L8 Y* ]  @! \, x
图为官方给出的标准参照  ?1 M$ D  K! T/ O- I' y$ M) n
具体的软件处理方法:
. f( o; v$ |* ?1:底层初始化HAL_Init();重置所有外设,FLASH 和Systick,
' P' n: Q3 p5 A/ V/ c2:系统时钟配置SystemClock_Config();STM32L4最高时钟可跑到80M,我在STM32Cube中时钟设置为72MHZ因为现在只是测试低功耗对系统的运行速度无太大要求
$ U9 I, j1 k( ?! d1 x0 Q3:开启所用时钟MX_GPIO_Init();在这我开启了所有时钟,并在此处将没' F& \4 o$ c' ~4 t$ e5 }
用到的引脚全部设置为模拟输入,外设我只用了串口.并开启外部中断。
; q4 \3 m. t( \# m" V4:串口的配置及初始化,按照常规配置即可
0 \5 [2 g8 D" q5:进入低功耗模式前的准备,首先在此函数中禁用Debug调试端口,关闭所有时钟。关闭串口,然后进入Shutdowm模式。
2 j( O! Y. C, {8 Y进入Standy模式和Shutdowm模式软件配置相同只不过最后进入的是Standy模式,Standy模式测试电流为0.12uA 加入RTC后电流大约在0.63uA
' H0 D9 d7 q5 X! U. L5 _% R在之后唤醒这一开始使用的RTC周期唤醒即HAL_RTCEx_SetWakeUpTimer_IT()函数,此函数使用的是一个16位可编程自动重载递减计数器(RTC_WUTR)生成,可用于周期性中断/唤醒。此唤醒定时器的时钟输入可以是:2,4,8或16分频的RTC时钟,也可以是ck_spre时钟(一般为1HZ)当使用RTC时钟时,可配置的唤醒中断介于122us和32s之间。当使用ck_spre时钟的时候唤醒时间为1s到36h左右分辨率为1s,这个范围分为两个部分% `6 Y5 k# F- H! C( q/ M: x
当WUCKSEL[2:1]=10时为:1s到18h。4 \- L9 q7 ?6 W* Z
当WUCKSEL[2:1]=11时约为:18h到36h。7 V& t' k" x  w4 J
在后一种情况下,会将2^16添加到16位计数器当前值(即扩展到17位,相当于最高位用WUCKSEL[1]代替) 如图& V/ ]) Y( i/ r& m* Z3 m& Q# {
- J$ F6 c, G% d6 E% m
20201215085412675.png
, c/ o) l! [4 C. ^( _- r
! `! R$ p! k' {- P' p. v7 S; K# P
在使用RTC周期唤醒的时候 要清零WUTF标志,因为当计数器到0时,RTC_ISR寄存器的WUTF标志会置1,并且唤醒寄存器会使用其重载值重载,会出现进不去低功耗模式的情况。用此种方式退出低功耗模式,系统复位以及低功耗模式不会影响计数器的计数。3 K0 E- ^0 C& P, e* a5 G6 F. N
但是一开始的时候我并没有注意到唤醒Shutdown和Standy模式后会复位确实是周期性唤醒,但是每次都复位,这样不方便添加外部中断唤醒方式。(在软件的第五步进入低功耗模式前加入RTC唤醒函数,开启计数或者闹钟)闹钟的话根据所配置来唤醒,闹钟在唤醒Standy和Shutdown时也可以实现周期性唤醒。- N, Z  K2 j1 |# y! B1 I
因此换用第三功耗小的模式,STOP2模式。STOP2无RTC可跑电流1.1uA,加入RTC后1.4uA左右。STOP2模式具体软件处理方法与整体框架相同。4 W4 T9 p) o9 d7 D2 _8 t
现在来看一下加入RTC的处理方法* q& A; ~2 H+ L+ u/ [2 _* J, C7 t+ Z
1:底层初始化HAL_Init();重置所有外设,FLASH 和Systick,
0 u% T9 w% O8 ]9 v# V) E2:系统时钟配置SystemClock_Config();STM32L4最高时钟可跑到80M,我在STM32Cube中时钟设置为72MHZ因为现在只是测试低功耗对系统的运行速度无太大要求0 |) }2 C  J0 @% c7 A% \& E2 O
3:开启所用时钟MX_GPIO_Init();在这我开启了所有时钟,并在此处将没
9 |  \0 n' C  L" N" I2 G1 R4 X用到的引脚全部设置为模拟输入,外设我只用了串口.并开启外部中断。
" I  j% A; J6 P- \" n2 U7 B4:串口的配置及初始化,按照常规配置即可
/ R) o4 H6 T% E8 G5:RTC初始化目的主要是为了开启RTC的时钟(如果需要RTC时钟需要另加时间配置函数,闹钟函数也可直接在此设置)# j4 v  D) F+ z8 X
5:进入低功耗模式前的准备,首先在此函数中禁用Debug调试端口,关闭所有时钟。关闭串口,然后进入低功耗模式。
& _! r* V! C& f% I. Q4 {6:进入低功耗模式后,系统等待RTC计数减到0,发生中断,然后进入相应的中断服务函数。
0 `# K$ ?! T2 r; _/ e0 \7:在服务函数中,重新初始化底层硬件并配置时钟,初始化所用外设,具体的函数功能在这添加,清除WKAEUP_pin标志,然后再次进入低功耗模式(除Shutdown和Standy)
; e) x+ ^# X( Y) l加入外部中断唤醒,也只需开启对应引脚外设,开启中断,配置优先级,然后在低功耗模式只能上升沿触发中断,在中断服务函数中的处理与RTC唤醒中断服务函数一样。
; H0 e6 S0 P$ P+ U3 b因为复位和中断都不会引起RTC计数器的异样,所以这两个中断只要不是同时发生是不会产生冲突的。
  H6 f1 r6 p& N  L" u- q; c9 R综合来看,依需求来选择,
; s8 ^( E% i, G7 y一:第一种方案可以使用RTC闹钟,实现按天唤醒,或按星期唤醒,当然RTC与Shutdown和Standy结合可以实现超低低功耗0.4uA左右,并加上这两种模式的唤醒复位的特性,也可实现周期唤醒,就是这样每唤醒一次都需要系统配置相应的RTC寄存器,时间长了可能对MCU有损坏
% h# @5 C' Y$ j- H7 ~4 R二:在就是使用wake计数器周期唤醒,搭配STOP模式,唤醒周期方便调节,精确度为S,电流达到1.4uA。
" n% K+ ]; d2 y7 ~还有存在的一些问题就是:
, H# R' v7 [! [1 m8 `1:串口和下载器对电流的测量很大,测量时要去掉。' I. q; k1 b$ O8 J1 ?5 n
2:然后下载完程序后需要重新上电,要不电流可能会有误。
" y, \2 @& X  E9 _3:然后就是外部中断我测试的时候硬件连接可能不规范,有些不稳定。! U6 f+ h3 r3 l% U2 P4 p
4:然后就是功耗问题,与官方的这几种功耗模式多多少少的有点差距,软件部分对比官方测试代码,没有什么本质上的区别。猜测可能是硬件部分,也有可能官方说的是MCU的功耗。
+ x* O. x9 A% K+ Q2 R+ K' n# V0 J) @$ w( w5 D+ p
& m7 h$ j4 T0 |4 \4 K- n; T7 G

9 T, s# C) K0 W
收藏 评论0 发布时间:2022-1-2 09:00

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版