引言
现在的电子产品,对低功耗的要求越来越高。产品低功耗的问题是经常让产品设计者头痛而又不得不面对的一个问题。以 单片机 为核心的 系统 ,其功耗主要由单片机功耗和单片机外围电路功耗组成。要降低单片机系统的功耗,需要从硬件和软件两方面入手。美国公司SILICon laboratories(以下简称Silabs)设计的高速C
本文将从以下三个方面来谈Silabs MCU 低功耗优势及其实现方法:
一、如何设计低功耗单片机系统;
二、Silabs MCU在低功耗方面的优势;
三、Silabs MCU低功耗实现方法。
一、如何设计低功耗单片机系统
低功耗单片机系统设计,需要从硬件设计和应用软件设计两方面入手。
1、 硬件设计
要满足单片机系统的低功耗要求,选用具有低功耗特性的单片机可以很容易实现。因为具有低功
耗特性的单片机可以大大降低系统功耗,这可以从单片机的供电电压、内部结构、系统时钟和低功耗模式等几方面来考察一款单片机的低功耗特性。
(1)选择简单的CPU内核
选择CPU内核时切忌一味追求性能,以“够用就好”为原则。8位机够用,就没有必要选用16
位机、32位机;单片机的运行速度越快,往往其功耗也越大。一个CPU越复杂、集成度越高、功能越强,片内晶体管越多,总漏电流也越大,即使进入STOP状态,漏电流也会变得不可忽视;而简单的CPU内核不仅功耗低,成本也低。
(2)选择低电压供电的单片机系统
单片机系统的供电电压低,可以有效的降低其系统功耗。由于半导体制造工艺的发展,现在单片
机的供电电压从5V供电降低到3.3 V、3 V、2 V乃至1.8 V。供电电压低,不紧可以降低单片机的功耗,还可以降低单片机外围电路的功耗。
(3)选择带有低功耗模式的单片机系统
低功耗模式指的是系统的Idle、Stop和Suspend等模式。处于这些模式下的功耗将远远小于正常运行下的功耗。
Idle模式下,CPU停止工作,但内部系统时钟并不停止,单片机的外围I/O模块也不停止工作;系统功耗一般降低有限,相当于工作模式功耗的50%左右。
Stop模式下,CPU和内部系统时钟停止工作,所有的数字外设也自动停止工作,内部RAM的信息以最小功耗被保持,CPU消耗电流可降到μA级,由外部或内部的复位使系统退出Stop模式,进而唤醒CPU继续工作。如果在CPU进入Stop模式时,将各个模拟外设关掉,这时的功耗可以降低到nA级。但是在Stop模式下, CPU被唤醒后要重新对系统作初始化,所有特殊功能寄存器的内容将被重新初始化。这在某些低功耗应用场合需要注意。
Suspend模式下,CPU、内部系统时钟停止工作,I/O模块等被悬挂起来,片内RAM中存储的数据将被保持,CPU的功耗可以降低到nA级,由唤醒事件唤醒。当CPU被唤醒后,系统不会被CPU复位,继续从进入Suspend
模式的地方开始执行程序。这是一种非常理想的低功耗模式。
 
www.55dianzi.com
; (4)选择合适的时钟方案
时钟的选择对于 系统 的功耗相当敏感,需要注意三方面的问题:
A 系统总线频率应当尽量低
单片机 内部的总电流消耗可分为运行电流和漏电流两部份。单片机集成度越高,环境温度越高,漏电流也越大。在单片机运行时,开关电路不断由“
B 选择适合低功耗的单时钟方案
单片机时钟是使用锁相环、外部振荡器,还是内部振荡器,这与单片机的功耗有很大关系。现代单片机普遍采用锁相环技术,允许用户在片外使用频率较低的振荡器,通过程序控制,系统时钟可以在一个很宽的范围内调整,总线频率往往能升得很高,但是会带来额外的功率消耗。仅仅就时钟方案来讲,使用外部振荡器且不使用锁相环是功率消耗最小的一种。
C 选择适合低功耗的双时钟方案
有些场合的应用比较复杂,对 MCU 的速度要求也很高。尽管采用新的半导体工艺,但MCU速度越高,一般来说功耗也越大。因此很多高速MCU提供了双时钟系统,并允许MCU在运行中实时快速的进行时钟切换,以达到降低功耗的目的。
SILabs MCU带有内部高速振荡器,又可以使用外部振荡器,并且可以在CPU运行中实时高速地进行内、外振荡器切换。这对于间歇工作的系统是一种非常好的低功耗方式。当要处理数据时,使用内部高速振荡器;当CPU空闲时,切换到外部低速振荡器,以降低功耗。
(5)使用每MIPS功耗来衡量MCU的低功耗性能是相对比较准确
尽管我们强调要降低单片机系统的功耗,必须尽量降低单片机的系统时钟。但使用每MIPS功耗来衡量MCU的功耗与之并不矛盾。这是相对的,要具体问题具体分析。
例如,执行一个需要10K条指令的任务,甲MCU的工作电流为3mA,速度为10MIPS,则甲MCU需要工作1mS完成该任务,消耗3mA*1mS*VCC,然后甲MCU就可以进入低功耗模式了.而乙MCU的工作电流为1mA,速度为2MIPS,则乙MCU需要工作5mS完成,这样乙MCU完成该任务的消耗为1mA*5mS*Vcc。
从上面的例子我们可以得出结论:电流大但速度快的MCU可能更省电。
2、应用软件设计
应用软件设计对于一个低功耗系统的重要性常常被人们忽略。一个重要的原因是,软件设计上的缺陷并不像硬件那样容易发现,同时也没有一个严格的标准来判断一个软件的低功耗特性。但是设计者如果能尽量将应用的低功耗特性反映在软件中,就可以避免那些“看不见”的功耗损失。
(1)用“中断”代替“查询”
在没有要求低功耗的场合,程序使用中断方式还是查询方式并不重要。但在要求低功耗场合,这两种方式相差甚远。使用中断方式,CPU可以什么都不做,甚至可以进入等待模式或停止模式;而查询方式下,CPU必须不停地访问I/O寄存器,这会带来很多额外的功耗。
(2)用“宏”代替“子程序”
子程序调用的入栈出栈操作,要对RAM进行两次操作,会带来更大的功耗。宏在编译时展开,CPU按顺序执行指令。使用宏,会增加程序的代码量,但对不在乎程序代码量大的应用,使用宏无疑会降低系统的功耗。
(3)尽量减少CPU的运算量
减少CPU的运算工作量,可以有效地降低CPU的功耗。减少CPU运算的工作可以从很多方面入手:
A 用查表的方法替代实时的计算;
B 不可避免的实时计算,算到精度够了就结束,避免“过度”的计算;
C 尽量使用短的数据类型,例如,尽量使用字符型的8位数据替代16位的整型数据,尽量使用分数运算而避免浮点数运算等。
(4) 让I/O模块间歇运行
A 不用的I/O模块要关掉,间歇使用的I/O模块要及时关掉,以节省电能。
B 不用的I/O引脚要设置成输出或设置成输入,用上拉电阻拉高。
总之,在 单片机 系统 设计过程中,深入理解单片机低功耗的特性,并在硬件和应用软件的设计过程中充分利用单片机的低功耗特性,来设计出符合低功耗要求的产品。
二、SILabs MCU 在低功耗方面的优势
Silabs 的C
1、供电电压范围宽
Silabs MCU的供电电压范围为2~5.25V。宽的供电电压范围不仅为单片机系统设计带来方便,而且低的供电电压可以有效地降低整个单片机系统的功耗。
2、有多种低功耗模式
Silabs MCU有Idle、Stop和Suspend三种低功耗模式。各种模式下片上资源状态、功耗及唤醒的情况如表1所示。在Stop和Suspend模式下,MCU的功耗可以降低到nA级。在Suspend模式下,有多种唤醒源,当被唤醒时(非复位源唤醒),CPU不会对系统复位。在Stop模式下,Silabs MCU有丰富的复位源使CPU被唤醒,如图1所示。
点击看原图
3、有多种时钟方案供选择
Silabs MCU都设计有两套时钟方案供选择。用户可以根据实际需要选择内部振荡器或外部振荡器,或者同时选择内、外振荡器。内部振荡器可以通过相关寄存器设置来选择不同的频率。其频率范围为:80KHz~100MHZ。更为重要的是在MCU运行中,可以实时高速地进行内、外时钟切换。时钟切换速度快,切换产生的功耗小。这种特性,对于间歇工作的单片机系统低功耗设计,特别有帮助。
4、灵活的I/O设计
Silabs MCU的I/O口资源丰富,配置灵活。有三种配置方式:漏极开路、推拉输出和弱上拉方式。用户可以根据实际需要通过相关寄存器的设置来禁止或使能这些方式。其中将端口配置成漏极开路方式是最省电的方式。
5、高速实时的中断响应
Silabs MCU响应中断的时间非常快,一般只需要5个系统时钟周期。中断响应速度快,CPU花费在等待方面的时间少,这可以节省不少的等待功耗。
6、运算速度快,处理数据能力强
虽然Silabs 的C
&nbs
www.55dianzi.com
p; 总之,深入理解SILabs MCU 低功耗的特性,根据实际情况,灵活运用,就可以设计出满足要求的低功耗产品。
三、Silabs MCU低功耗实现方法
这里举一个运动装置的应用,采用3V电池供电,间歇工作,要求平均功耗不大于200uA。使用Silabs mcu C
下面我们分析一下在不同情况下,CPU的功耗情况。
在温度-
点击看原图
IDD = IDD1 - ( F1 - F )×IDD2 (1)
其中IDD1是在不同电压、最高频率下正常工作时的最小功耗,F1是最高工作频率,IDD2是F>15MHZ,
不同电压下的IDD Frequency Sensitivity。例如,VDD = 3.0 V; F = 20 MHz时,根据图2可以算出:
IDD = 7.8 mA - (25 MHz -20 MHz) × 0.21 mA/MHz = 6.75 mA
当F≤15MHZ时,CPU的功耗可以用下面的公式来估算:
IDD = F ÷ 1MZ ×IDD2 (2)
例如,VDD = 3.0 V; F = 32.768KHZ时,根据图2可以算出:
&n
www.55dianzi.com
bsp; IDD =32.768KHz ÷ 1 MHz × 0.38 mA/MHz = 12.45184 uA
在温度-
根据公式(2),Idle模式下的功耗为:
IDD =32.768KHZ ÷ 1 MHz × 0.20 mA/MHz = 6.5536 uA
点击看原图
从上面的分析我们可以看出,使用外部低频振荡器,并进入Idle模式,CPU的功耗可以降的很低。如果能用上Stop模式,功耗可以降低到0.1uA以下。在模拟该运动装置真实使用环境的条件下,经过使用仪器测试,平均功耗降低到了150uA以下。该产品目前已经批量上市了。
结束
C
本文关键字:暂无联系方式DSP/FPGA技术,单片机-工控设备 - DSP/FPGA技术