3.1 低功耗系统设计概述
随着嵌入式系统的广泛应用,功耗问题是近几年来人们在嵌入式系统的设计中普遍关注的难点与热点。系统的低功耗设计,并非是某一个方面、某一个角度的解决方案,而应当从系统级的设计考虑功耗的节省,是一个硬件设计与软件控制相互结合的协调过程。
本文将依次从系统硬件设计、系统软件设计、利用μC/OS-II给出的内核扩展接口和产品应用特点这四个方面系统地讨论低功耗系统设计。
3.2 硬件低功耗设计
3.2.1 低功耗设计的器件
选择低功耗的电子器件可以从根本上降低整个硬件系统的功耗。嵌入式处理器是嵌入式系统的硬件核心,消耗大量的功率,因此设计时应选用低功耗的处理器;另外,选择低功耗的通信收发器(对于通信应用系统)、低功耗的外围电路。
本文中使用的微控制器是夏普公司的LH79520。LH79520有五种工作模式,分别是:运行模式、休眠模式、睡眠模式、停止模式1、停止模式2。处于不同的工作模式下,微控制器消耗的功率不同,处于运行模式的微控制器消耗的功率最多,处于停止模式2的微控制器消耗的功率最少。
3.2.2 低功耗电路
目前的半导体工艺主要有TTL工艺和CMOS工艺,CMOS工艺具有很低的功耗,在电路设计上尽量选用,使用CMLS系列电路时,其不用的输入端不要悬空,因为悬空的输入端可能存在的感应信号造成高低电平的转换,转换器件的功耗很大,尽量采用输出为高的原则。同时尽量使用集成度高的器件,减少电路中使用的元件的个数,从而减少整机的功耗。
3.2.3 分区/分时供电技术
一个嵌入式系统的所有组成部分并非时刻在工作,基于此,可采用分时/分区供电技术。原理是利用“开关”控制电源供电单元,在某一部分电路处于休眠状态时,关闭其供电电源,仅保留工作部分的电源。
本文使用的硬件平台,使用了TI公司的直流电源转换芯片TPS5430,给其他辅助板和主控板上的外设提供电源。
3.2.4 降低处理器的时钟频率
处理器的工作频率和功耗的关系很大,频率越高,功耗越大。可以动态改变处理器的时钟以降低系统的总功耗。微控制器空闲时降低时钟频率;处于工作状态时,提高时钟频率,全速运行处理事务。
本文使用的硬件平台的控制板所使用的时钟,使用了外部晶振和锁相环技术,可以在很宽的范围内调整系统时钟。
3.3 软件部分的设计
至今,还没有一个严格的标准来判断一个软件的低功耗特性,但是,设计者仍需尽量将应用的低功耗特性反映在软件中,以避免那些“看不见”的功耗损失。
3.3.1 中断与查询
一个程序使用中断方式还是查询方式对于一些简单的应用并不那么重要,但在其低功耗特性上却相去甚远。使用中断方式,微控制器可以什么都不做,甚至可以进入等待模式或停止模式;而查询方式下,微控制器必须不停地访问I/O寄存器,这会带来很多额外的功耗。
本文是通过中断通信方式与片上的两个串口资源进行通信,而非采用查询的方式,减少了串口占用处理器的工作时间,有效地降低了系统的功耗。
3.3.2 宏的使用
读RAM会比读Flash带来更大的功耗,正是因为如此,低功耗性能突出的ARM微控制器在设计上仅允许一次子程序调用。因为微控制器进入子程序时,会首先将当前微控制器寄存器推入堆栈(RAM),在离开时又将微控制器寄存器弹出堆栈,这样至少带来两次对RAM的操作。因此,考虑用宏定义来代替子程序调用。调用一个子程序还是一个宏在程序写法上并没有什么不同,但宏会在编译时展开,微控制器只是顺序执行指令,避免了调用子程序。这实际上是一种以空间换时间的思想。这样做,不仪提高了程序的执行效率,同时可以减少系统的功耗。
3.3.3 减少微控制器的运算量
将一些运算的结果预先算好,放在Flash中,用查表的方法替代实时的计算,减少微控制器的运算工作量,可以有效地降低微控制器的功耗;不可避免的实时计算,算到精度够了就结束,避免“过度”的计算;尽量使用短的数据类型,在精度允许的情况下,使用简单函数代替复杂函数作近似,也可以减少功耗。