向右滑动:上一篇 向左滑动:下一篇 我知道了
广告

让微控制器进入休眠状态后,到底能省多少能耗?

时间:2019-08-15 作者:Jacob Beningo,EEWeb 阅读:
低功耗模式如何在真正的微控制器(MCU)上实现?这些模式如何影响嵌入式系统?在这篇文章中,将更详细探讨如何让微控制器进入睡眠状态,并看看到底能够节省多少能耗。

在《Arm Cortex-M低功耗模式基本原理(Arm Cortex-M low-power mode fundamentals)》中,探讨了在每种Arm Cortex-M处理器上可以找到的低功耗模式的基本原理,以及如何使用WFI和WFE指令让处理器进入休眠模式。实际上我们真正要了解的是,低功耗模式如何在真正的微控制器(MCU)上实现?这些模式如何影响嵌入式系统?在这篇文章中,将更详细探讨如何让微控制器进入休眠状态,并看看到底能够节省多少能耗。

低功耗模式实验

探索低功耗模式的最佳方法是选择一个微控制器并以各种低功耗模式实际执行该处理器。本文中,笔者决定翻出积尘已久的NXP Kinetis-L Freedom电路板,我曾经不仅用它进行过实验,而且还应用于许多产品、应用和课程。无论对错,我决定不仅要测量微控制器的能耗,还要测量整个开发板的能耗。微控制器通常是电路板上的耗能大户之一,但测量整个系统的电流经常提醒我它并不是电路板上唯一的耗电组件。微控制器的优化长路迢迢,但其实它并不是唯一需要优化能耗的组件。

从基线测量开始

每当我努力优化一个产品的能耗时,首先会从基线能量测量开始。通常我会透过分析几秒或几分钟内设备的电流消耗来了解应该从哪里开始,在我的开发板实验中,将Kinetis-L置于运作模式,无休眠模式,所有周边均运作并设置电路板定期切换LED。透过采用IAR嵌入式工作台的I-Jet除错器,以及I-Scope,可以为该电路板配置一个简单基线,即LED关闭时电流消耗大约为16.9mA,LED打开时大约为18.0mA,如图1所示。显然,从哪里开始进行测量很重要,否则分析结果可能明显偏离。

016ednc20190814

图1 开发板的电流测量,LED每秒切换一次。(数据源:作者)

采用等待模式和深度休眠模式优化能耗

节省能耗最快的方法是执行等待或深度休眠模式。研究Kinetis-L处理器的数据表可以得出,等待模式的能耗在3V电压下的电流介于3.7和5.0mA之间。在此模式下,CPU和周边频率被禁用,而闪存处于休眠模式,此时允许处理器在中断时间范围内(12~15个频率周期)仍然可以被唤醒。等待模式易于实现,设置进入等待模式的程序代码如下所示:

void Sleep_Wait(void)

{

SCB_SCR &=~ SCB_SCR_SLEEPDEEP_MASK;

asm(“WFI”);

}

只需这两行程序代码,开发板的电流消耗就从18.0mA降至15.9mA。电流消耗减少了11.6%。如果电路板由680mA电池供电,则该设备的电池寿命将从37.8小时变为42.8小时,两行程序代码就可以将电池寿命延长五小时。

这些高阶电源模式的好处在于可以轻松地再向前迈一步。可以使用以下程序代码将处理器置于深度休眠等待模式,而不仅仅是等待模式:

void Sleep_Deep(void)

{

SCB_SCR |= SCB_SCR_SLEEPDEEP_MASK;

asm(“WFI”);

}

我们所做的仅仅是调整了SCB_SCR寄存器中的1位,就已经将最初的18mA电流消耗减少为14.8mA。电流消耗减少了17.8%。同样,假设电路板由680mA电池供电,电池寿命现在已经从37.8小时增长为46小时,只需几行程序代码就可以节省大量能耗,而这只是冰山一角。

利用Stop模式和VLLS模式实现微安级电流消耗

采用停止模式可以禁用核心和系统频率,这有可能将微控制器电流消耗再进一步降低2mA。 你会发现,功耗模式越低,实现它所需的程序代码就越多,而唤醒系统恢复工作的程序代码就越复杂。使Kinetis-L进入停止模式的程序代码如下所示:

void Sleep_Stop(void)

{

volatile unsigned int dummyread = 0;

SMC_PMCTRL &=~ SMC_PMCTRL_STOPM_MASK;

SMC_PMCTRL |= SMC_PMCTRL_STOPM(0);

dummyread = SMC_PMCTRL;

Sleep_Deep();

}

请注意,停止模式透过电源管理控制寄存器控制,一旦状态被设置,就会调用Sleep_Deep函数来完成电源模式的设置并执行WFI。

到目前为止,本文一直在谈论1~2mA的微控制器能耗,现代微控制器将提供仅消耗μA甚至nA的电源模式。Kinetis-L处理器于2013年左右首次亮相,其超低漏电停止(VLLS)模式仅耗能135~496μA。初始化此电源模式的程序代码如下所示:

void Sleep_VLLS1(void)

{

volatile unsigned int dummyread = 0;

SMC_PMCTRL &=~ SMC_PMCTRL_STOPM_MASK;

SMC_PMCTRL |= SMC_PMCTRL_STOPM(0x4);

SMC_VLLSTRL = SMC_VLLSCTRL_LLSM(1);

dummyread = VLLS_CTRL;

Sleep_Deep();

}

讲到这里,你会发现微控制器已经几乎不消耗任何能量了!

低功耗模式对唤醒延迟的影响

正如我们目前所看到的那样,将处理器设置为越来越低的电源模式是节省能源的好方法,但这是需要付出代价的。处理器的能量状态越低,唤醒处理器恢复工作所需的时间就越长。例如,如果使用标准停止模式,则处理器被唤醒并再次开始执行程序代码需要2μs加上中断延迟,这还可以接受。但是,如果在Kinetis-L上设置了其中一种VLLS模式,将需要启动处理器的唤醒延迟再加上额外的53~115μs。有些应用可能无法接受这种状况,表1显示了Kinetis-L从低功耗模式到运作状态的各种转换。

017ednc20190814

表1 Kinetis-L从低功耗模式到各种模式的转换时间。(数据源:Kinetis-L数据表)

结论

Arm微控制器都具有标准的低功耗模式,但每家芯片厂都会定制开发人员可用的更多低功耗模式。正如我们所看到的,芯片供货商通常会提供几种容易实现的模式,对唤醒延迟的影响最小,他们还会提供几种超低功耗模式,几乎可以关闭处理器并且仅消耗几百微安或更少能量。开发人员通常需要在能耗和系统被唤醒需要的时长,以及响应事件的速度之间进行权衡,而权衡一定是基于应用的,所以不要指望能够在每个产品和应用上都执行最低功耗模式。

(参考原文: How low (power) can you go?,by Jacob Beningo,EETTaiwan编译)

 

本文为EDN电子技术设计 原创文章,禁止转载。请尊重知识产权,违者本司保留追究责任的权利。
  • 微信扫一扫
    一键转发
  • 最前沿的电子设计资讯
    请关注“电子技术设计微信公众号”
您可能感兴趣的文章
  • 2019年中国最需要的十款创新国产IC 5月10日,一年一度的“松山湖中国IC创新高峰论坛”再次盛大举行。松山湖IC论坛已迈进第九个年头,2019年中国最需要的十款创新国产IC有哪些?
  • 2018 EDN Hot 100产品:处理器及系统 在2018 EDN Hot 100产品中,“处理器及系统”部分包括SoC、MCU、FPGA、微处理器等。
  • 拆解:专为残疾司机设计的半自动驾驶汽车 若让你设计一款让严重残疾人士也能开车的系统,你会怎么做?艾睿电子用半自动驾驶汽车(SAM)项目回答了这个问题。SAM团队的工程师主要依靠现货(OTS)产品,并设计了一些市面上买不到的东西,集成了一个系统,它可以获取传感器输入并将其发送到线控驱动系统。
  • 2019年趋势和创新,今年都有哪些看点? 2019年看起来已经像是一个不凡之年,一些重要的趋势和创新似乎正在从多个方面颠覆变半导体行业。因此我们认为,探究一下让未来12个月变得令人期待的技术是件很有意思的事情。这篇文章不是意法半导体的产品规划,更不是什么市场预测,而是我们对当下行业流行趋势的简单概述。
  • 创新的企业一定要做的事 有人问,为什么你要创立一个公司?对于我来说,我在高中时就决心创立一家自己的公司。当时并没有具体的愿景要成立多大的公司,只是希望有机会控制自己的命运。后来发现很多创新、创业者的想法都是一样的。
  • 工业物联网需要“翻译” 当将IoT原理应用到工厂流程时,在转换过程中会丢失什么?
相关推荐
    广告
    近期热点
    广告
    广告
    广告
    可能感兴趣的话题
    广告