
前言+ b* k( N5 ?+ g' x STM32L0 和 STM32L4 系列微控制器具有复用的 UART 接口,这一设计令 MCU 仅需最小功耗即可工作。 本文的目的是解释怎样充分利用低功耗 UART (LPUART)的优势,扩展上述产品的电池寿命。 它显示了在实际示例中,等待通信设备的极低功耗。9 \ X; _6 S# P" _ B$ t " y+ }' A1 f, V/ g/ O. m5 ~ 下列文件可作为参考: • 应用笔记 AN4445:“STM32L0xx 超低功耗特性概述 ”( U2 |3 p; A$ J • 应用笔记 AN4621:“STM32L4xx 超低功耗特性概述 ” • 应用笔记 AN4746:“ 优化 STM32L4xx 的功耗和性能 ”+ K j$ E: D+ V • 参考手册 RM0351:“STM32L4x6 高级的基于 ARM® 的 32 位 MCU”6 o7 m# H" Z) r8 r7 H0 x • 参考手册 RM0376:“ 超低功耗 STM32L0x2 高级的基于 ARM® 的 32 位 MCU”。 $ \8 {8 [% H/ D 1 定义$ X9 V+ v, `: E6 A5 h* L+ M% ` ![]() 0 Z4 a7 X- o$ X) U X 2 特性总结( G2 \, R6 v% z" x 2.1 L0 和 L4 系列比较% `6 N: k( M6 s: j 虽然 STM32L4 和 STM32L0 系列上的 LPUART 外设实际上相同,但这两种产品有很大区别。除了 ARM® Cortex® 内核不同,还有其它区别影响了 LPUART 的效率。! [% I5 _' e/ c" B+ p6 I 2.1.1 时钟子系统" c4 r* s- x9 s7 V; | STM32L4xx MCU 可支持更高的时钟速度,这有效地降低了高要求任务的处理时间。 MSI 内部时钟源也因此调整以达到更高时钟速度。这一 MSI 的加速降低了低速的选择范围,STM32L4 MSI 的最低可能频率为 100 kHz,而 STM32L0xx MCU 为 65 kHz。 1 MHz 以下的可选速度是不同的,因此难以直接比较两种 MCU 的效率。另外,在STM32L4 系列中,MSI 可在其 PLL 模式中使用 LSE 硬件自动校准。这使得 MSI 更加精确,而 STM32L0 产品无此选项。' _* Q v9 K) D STM32L0 系列对于 HSI 时钟源具有一个简单的时钟因子 4 分频器,这使得 HSI 成为 16 或 4MHz 的有效源。 STM32L4 MCU 在 HSI16 时钟上没有直接的分频器。因此,在一些 UART速度需要高于 9600 Bd 的应用中, STM32L0 可能会高效很多。对于 STM32L4,若 16 MHz不够有效,解决方案为使用第二时钟源做系统时钟。- R; O g& p6 v m LSI 时钟频率也有不同,但这与我们的情况无关。: a5 L1 c" k6 n9 U3 V 2.1.2 电源管理 STM32L4 系列的主调压器仅有两个范围,而 STM32L0xx MCU 有三个。此外,由于有更强的 MCU 支持,这两个范围被移到了更高频率。& M# o; K: d3 d" | 非常有用的低功耗运行模式弥补了这一不足。 STM32L0xx MCU 在从 Sleep 或 Stop 低功耗模式唤醒后,无法直接返回至低功耗运行模式,而 STM32L4 系列不存在这一限制。 STM32L4xx 上的低功耗运行也不限于 MSI 范围 1,还能工作于高达 2 MHz 的系统时钟速度。即使在低功耗运行中, HSI16 仍可被用作外设时钟。 / [ O- F+ i8 @& g n, P 2.2 与 USART 外设的比较0 G' U" \$ S( d ^- A LPUART 比 USART 特性更少,但可用更低功耗工作,并可更有效地使用 LSE 时钟。8 F R3 [/ Q9 W" Y) W/ ~( q, w 两种外设的主要特性总结于表 2 中。 ; m3 ^! q- z2 X9 k' u! H u2 i, U ![]() # R5 o3 A$ T. n, L USART 还可使用 LSE 时钟工作,当过采样为 8 时,通信速度最高为 4000 波特,当过采样为 16 时,为 2000 波特。; y4 |- ~' \" x6 a+ p# x6 { 当使用 LPUART 时,仅需 32.768 kHz LSE 时钟即可达到 9600 波特的串行通信,功耗最低,外部晶振可允许非常精确的速度设置。% O; V3 U! ]) f' s 对于更高的速率 (例如用于 BT LE 的 57600 波特), LPUART 能效优势下降,但仍可测量为 5% 左右 (参见第 6.1.9 节:更高通信速率)。% ?! t5 S: J/ x7 x1 Q 本文侧重于 9600 波特处的通信,这对很多应用是通用的:当在 9600 波特速率设置处从Stop 唤醒时, LPUART 的能效优势更加显著。8 }3 t9 a. ~4 o- j) d - p" M- A& M6 l0 L/ ^( ^$ Y 3 工作模式 实际场景可能覆盖多种配置,使用不同的波特率、发 / 收比以及消息间时延。所有这些因素都会影响工作模式的选择。 3.1 轮询模式 轮询模式为最简单的可能的工作模式,也称为阻塞模式。CPU 处理单个任务,在非激活期间切换至低功耗模式。几乎没有处理开销,因此可使用非常低的系统时钟速度。% }( }0 N8 u9 ^ Z Q) _4 b 对于非常简单的场景,此模式极其有效。然而阻塞模式有效地阻塞了 CPU,使其不处理任何其它任务,例如数据处理或并发通信。 3.2 IT 模式 第二个选项是完全依赖于中断,对于每个传输的字节都唤醒 CPU。此工作模式利用 ARM®Cortex® 高级 NVIC 的优势,将处理分割为原子操作,永不阻塞 CPU,实现实时响应。" U" g# o; X; _4 `8 G c 然而,此模式会略微加重 CPU 负担,它增加了与栈和上下文恢复有关的处理开销。; T2 v- a( i2 G: E & Z: C* E( d8 R: X- A8 T / X+ A/ O' m4 G; T* h; H+ b7 s1 O 3.3 DMA 模式 在 DMA 模式中, CPU 空余了一大部分的处理,设置 DMA 通道在外设和 SRAM 间移动数据。 CPU 可能会花费一部分处理时间在 Sleep 模式。对于循环缓冲管理,用户应在不需要时禁用半缓冲中断,以让 CPU 内核休息更长时间。然而,DMA 无法与 Stop 模式组合使用,在进入 Stop 低功耗模式之前,应禁用所有 DMA 通道。- e( A. R; s$ w LPUART 传输的实现得益于批采集模式 (BAM),在该模式中 MCU 处于 Sleep 或低功耗Sleep 模式 (CPU 时钟关闭)。通过将 Flash 存储器配置为掉电模式并关闭其时钟,以及仅对 DMA、 LPUART、 SRAM 提供时钟,可优化功耗。 3.4 组合模式举例 实际应用通常是以上所述模式的混合,开发者一直尝试在冲突的需求间达到最佳。下面的例子并不在附带的源代码中,只是为了抛砖引玉。 3.4.1 带轮询的中断 一些嵌入式系统可能不需要严格实时,在此情况下,可阻塞 CPU 一段时间以处理一个消息帧。尤其是对于发送的情况,通常用于处理所有 TC 中断的能量被保留,在阻塞模式中发送消息,这时时钟速度可降低,功耗调压器切换至低功耗模式 (LPRUN)。如果 CPU 可在阻塞模式中处理消息,则大约仅需要一半时钟速度。之后恢复正常工作,最好在 Stop 模式中等待进入的应答中断。. a' a( h5 d. { 3.4.2 DMA 和直接访问组合 DMA 通道方便发送数据,它在接收期间是节约功耗的。3 z/ `& v. p w- l+ \ 它的缺点是,在 DMA 模式, LPUART 无法利用从 Stop 模式唤醒的功能。原因是,在唤醒事件之后, DMA 获取正在进行的通信有困难。对于所有可能长时间空闲的应用来说,这是一个严重的缺点。 然而, DMA 仍可用于发送,然后用阻塞或中断方法接收。在通信系统中,若进入的消息快速连续或时序可预期,基于 DMA 的接收也可能是一个有效的选项。4 E! V' v6 i2 v) p7 ]9 w0 ~ & b. `( Z* e8 a 4 其他注意事项 若需低功耗优势的完整概述,请参考已经提及的 AN4445 和 AN4621。下列建议针对我们的情况和用例。 0 Y( W X) ^& y* m 4.1 从 SRAM 执行9 f0 X8 l. Z7 y6 G- w# p: A7 a 如果可从 SRAM 执行程序,则有一个选项可以关闭嵌入式 Flash 存储器 (通过时钟门控),进一步降低功耗。 ! L! Q8 i! x/ [% }) @8 k 4.2 GPIO 配置$ z& B8 l) |8 ?- M 一些 GPIO 设置可能对功耗有极大影响,而其它设置则不然。 用于 UART 通信线的引脚应配置为它们的复用功能模式。如果最重要的目标是达到可能的最低功耗,则不建议激活上拉,然而,在一些应用中,可能有必要增强通信的可靠性。速率设置与被测波特率处的功耗没有因果关系。 在半双工模式适用的地方,也可能做进一步的功耗节省,然而本文不涉及此配置。 其它应用不用的引脚应配置为模拟输入。一旦应用可以部署后,开发者不要忘记将调试线置为模拟。 & g: V P7 F" L- ~2 `$ Z 4.3 时钟配置 对于 LPUART 外设时钟,为达到 9600 波特并从 Stop 模式唤醒,应选择 LSE 源。 建议对于更高速率使用 HSI。 i) a9 U4 a5 t2 @ 系统时钟显而易见的 (也是默认的)选择通常是 MSI 振荡器。除此之外, STM32L0xx 微控制器提供了 HSI 时钟分支上简单的 4 因子分频器,以产生 4 MHz。在 STM32L4xx 产品上,MSI 提供了更高的灵活性,可在 LSE 为 PLL 模式时,使用硬件自动校准纠正它的波动。" u( ~ H- q3 t0 X* p 可使用预分频器和 PLL 生成其它速度,本文随后会分析不同的选项。当功耗为第一考虑因素时,这些解决方案都不是最佳的。用户必须参考产品数据手册,以得到不同时钟配置的典型功耗。5 T; S# y3 \* O0 }% F; g% t) K& g 7 z0 x- ^5 }/ ?1 f ![]() . q+ l7 z# B4 h% y1 W 完整版请查看:附件 v. W; Y1 r' i + S% \8 X; c8 X7 } |
在 STM32L0 和 STM32L4 系列微控制器中使用 LPUART 使功耗最小.pdf
下载1.34 MB, 下载次数: 13
STM32如何分配原理图IO
【实测教程】STM32CubeMX-STM32L4之研究(ADC)
【STWINKT1B评测】2.初步测试IIS3DWB振动传感器
STM32ADC过采样及几种ADC采样的处理方法
分享一个STM32L031的串口调试程序
【圣诞专享活动】使用TouchGFX做GUI显示:圣诞快乐&Merry Christmas!
串口通信波特率异常的解决办法
【STWINKT1B 评测】6. NanoEdge AI 音频分类器 (2)
【STWINKT1B 评测】5. NanoEdge AI 音频分类器 (1)
STWINKT1B评测】4.测试板载ISM330DHCX(6轴)