- UID
- 1023166
- 性别
- 男
- 来自
- 燕山大学
|
随着嵌入式系统应用的日益广泛,如何实现嵌入式系统的低功耗开发已经成为嵌入式应用发展的关键技术之一,是近几年来人们在嵌入式系统的设计中普遍关注的难点与热点。嵌入式系统正被广泛应用于移动性较强的产品中去,而这些产品不是一直有充足的电源供应,往往需要电池来供电,因此,设计人员需要从每一个细节来考虑降低系统的功率消耗,从各个方面去实现降低系统的功耗。同时功耗对终端设备的成本及体积大小有显著影响。
本文结合FM电台手持式测试仪这一实例,从系统硬件设计、系统软件设计、利用内核扩展接口和产品应用特点这四个方面深入地讨论了基于μC/OS-II嵌入式系统丌发中低功耗系统的设计。
1、嵌入式系统概述
1.1 嵌入式系统的定义
根据IEEE(国际电气和电子工程师协会)的定义:嵌入式系统是用于控制、监视或者辅助操作机器和设备的装置。
1.2 嵌入式操作系统
从20世纪80年代开始,市场上出现各种各样的商用嵌入式操作系统,主要有VxWorks、Psos、Neculeus、QNX、Linux、Windows CE等。
本文使用的μC/OS-II是一个典型的实时操作系统。它的特点可以以概括为以下几个方面:公开源代码,代码结构清晰、明了,注释详细,组织有条理,可移植性好,可裁剪,可固化。内核属于抢占式。
2、研究主题的平台简介
2.1 本文硬件平台是基于FM电台手持式测试仪的一套开发平台。
FM电台手持式测试仪由主控板、信号源板、测量板组成,其结构框图见图1。
主控板包括嵌入式微控制器(SHARPLH79520)、存储芯片(NAND FLASH)、CPLD(用于总线扩展)、并口转串口芯片(ST16C16554)、直流电源转换芯片(TI公司TPS5430)、实时时钟芯片等。主控板主要用于控制信号源板的操作和测量板的操作。信号源板主要用于调制射频信号、发送调制信号和音频信号,以及接收电台发出的信号、解调射频信号等。测量板主要用于测量射频频率、射频功率、射频电平、音频频率、音频电平、失真等电台参数。
2.2 研究目标
本文主要研究嵌入式操作系统μC/OS-II在FM电台手持式测试仪中的应用,从硬件、软件、操作系统和产品应用特点这四个层面上,讨论如何降低系统的功耗。FM电台手持式测试仪的体系结构如图2。
3、低功耗系统的设计
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的操作。因此,考虑用宏定义来代替子程序调用。调用一个子程序还是一个宏在程序写法上并没有什么不同,但宏会在编译时展开,微控制器只是顺序执行指令,避免了调用子程序。这实际上是一种以空间换时间的思想。这样做,不仪提高了程序的执行效率,同时可以减少系统的功耗。 |
|