μCOS-II实时操作系统在μ′nSPTM中的低功耗研究

发布者:灵感发电站最新更新时间:2010-02-22 来源: 现代电子技术关键字:低功耗  实时时钟  μCOS-Ⅱ 手机看文章 扫描二维码
随时随地手机看文章

0 引 言

    在当今普遍使用的手持式移动设备中,如何降低嵌入式系统的功耗、延长电池使用的时间等问题一直是困扰开发人员的一个难题。大量的功耗不仅导致移动设备的待机时间缩短,还会导致芯片热量增加,降低可靠性,而且也会增加散热系统的成本。待机时间问题虽然可以通过提高电池容量解决,但实际情况是嵌入式系统的功耗增长超过电池技术的发展,因此单纯依靠电池技术的发展是不可能在短期内解决现在正遇到的功耗问题。

    CMOS逻辑电路被认为是现今最通用的大规模集成电路技术,因为CMOS可以高度集成,并具有低功耗、输入电流小等特性,而且从理论上,理想的CMOS电路的静态功耗可以认为是零,是一种“理想”的逻辑器件。但实际的CMOS器件依然需要消耗功率,而且频率越高,消耗的动态功耗越高。虽然芯片的封装、使用散热片和风扇能够散掉芯片和系统所产生的热量,然而随着芯片和系统尺寸持续地增加,要提供充分的散热就必须付出更多的代价,而且系统的尺寸也会增加,散热系统的机械部分也会降低系统的可靠性。

    嵌入式系统由硬件和软件共同组成,因此降低嵌入式系统功耗的方法也有硬件方法和软件方法。本文以移植到凌阳16位处理器μ′nSPTM上的嵌入式实时操作系统μCOS-Ⅱ为例,使用凌阳公司提供的SPCE061A开发板,讨论如何利用μCOS-Ⅱ给出的内核扩展接口,实现一个低功耗的嵌入式系统。

1 嵌入式系统的功耗

    嵌入式系统的平均功耗和电池容量共同决定待机时间,平均功耗越小、电池容量越大则待机时间越长。而嵌入式系统的功耗可以分为静态功耗和动态功耗,静态功耗是由CMOS电路的漏电流形成,现在的技术已经使漏电流减少到尽可能小,因此静态功耗一般占总功耗的比例很小;动态功耗是由CMOS电路的分布电容充放电形成,该功耗占总功耗的比例很大,因此也是主要的研究对象。动态功耗的大小可由式PD=CL×VDD2×f表示,CL是CMOS电路的分布电容,与芯片尺寸和工艺有关;VDD是电源电压;f是系统的工作频率,降低工作频率有助于降低系统功耗,但会使系统工作速度下降。

    由上述分析可知,降低嵌入式系统的功耗主要有两种途径。第一种是动态频率调节(DFS),它可以改变不同电压域上的时钟频率。虽然这种方法可以消除空闲等待的时间,但是却不能减少能量的消耗。比如将一个任务以通常情况的一半频率来运行,意味着完成这个任务要通常的两倍时间。DFS有用的地方在于,它可以降低峰值功耗。第二种方式是动态地电压和频率调节(DVFS)。DVFS是建立在DFS基础之上的,它既要降低频率,又要降低电压。由于电压对动态功耗二次方的关系,DVFS确实能将能量的消耗节省下来。为此ARM公司的Faisal M.Goriawalla先生提出IEM(智能能量管理)方案,该方案采用步进策略、前瞻策略或平均数策略等算法调节系统的频率和电压,对于最终产品来说,则可以节省15%~20%的能量消耗(来源于ARM公司OEM合作伙伴的数据)。

2 实时操作系统μCOS-Ⅱ和凌阳处理器μ′nSPTM简介

    μCOS-Ⅱ是一个简单、高效的嵌入式实时操作系统内核,具有可抢占的实时多任务调度系统功能。μCOS-Ⅱ提供很多系统服务,例如邮箱、消息队列、信号量、块大小固定的内存的申请与释放、时间相关函数等。μCOS-Ⅱ2.5版本支持64个任务,每个任务一个特定的优先级。优先级越高,数字越小。系统占用了8个任务,保留优先级为0,1,2,3,OS LOWEST_PRIO-3,OS_LOWEST_PRIO_2,OS_LOWEST_PRIO_1,OS_LOWEST_PRIO_0。

    凌阳16位处理器μ′nSPTM被广泛应用在家用电器控制器、仪器仪表、工业控制、娱乐和语音控制等场合。在功耗控制方面,μ′nSPTM采用CMOS制造工艺,同时增加了软件激发的弱振方式、空闲方式和掉电方式,极大地降低了其功耗。可以通过对P SystemClock的设置进行选择CPU的时钟可以在O.32~49.152 MHz范围内可编程调节。当系统处于备用状态下(时钟处于停止状态),耗电仅为2μA@3.6 V。μ′nSPTM处理器满足μCOS-Ⅱ实时操作系统移植的条件。

    凌阳16位处理器μ′nSPTM的时钟有多种选择。系统采用32 768 Hz的实时时钟,实时时钟经过PLL倍频电路以后,产生系统时钟频率FOSC,FOSC再经过分频得到CPU时钟频率。其工作原理如图1所示。

    由图1可知:μ′nSPTM的时钟有多种选择,从O.32~49.152 MHz范围内可编程调节,另外还可以关闭32 768 Hz实时时钟进入睡眠状态。在3.6 V电源电压下,处理器的工作电流见表1。

3 μCOS-Ⅱ实现低功耗的原理

    μCOS-Ⅱ总是运行进入就绪状态的优先级最高的任务。一旦优先级高的任务进入就绪态,就可以将CPU从低优先级任务中抢过来。在μCOS-Ⅱ初始化时,会建立一个优先级最低的任务——空闲任务,在没有任务进入就绪态的时候,空闲任务就会开始运行。空闲任务会调用一个函数——OSTaskIdleHook()。这是留给用户使用的内核扩展接口。空闲任务实际上并没有什么事情可做,只是一个等待中断的无限循环。因此用户可以利用OSTaskIdleHook(),降低或者关闭系统时钟,使CPU进入低功耗模式。在实际的测试中,可修改文件OS_CPU_A.ASM,添加控制实时时钟的例程,然后在应用程序或函数OSTaskIdleHook()中调用,这样更便于程序阅读。

  在本文中采用的具体方法有两种:

    方案一:系统在空闲状态下关闭实时时钟,进入低功耗状态。但这种方法会使操作系统停止运行而无法进行任务调度,故需要定时器周期性地唤醒CPU。CPU被唤醒之后重新判断是否有任务处于就绪态,如果有就执行该任务;如果没有则再次进入空闲状态并关闭实时时钟进入低功耗状态。其工作时序见图2。其中用户任务工作在高功耗状态,空闲任务则关闭实时时钟,处于低功耗状态。

    方案二:系统在空闲状态下不关闭实时时钟,而是进入最低的工作频率,此时处理器处于低功耗工作状态,操作系统仍然可以进行任务调度。当有用户任务时,由用户任务先把实时时钟频率升高,然后再运行用户代码。其工作时序见图3。其中每次进入用户任务之前,先将实时时钟频率升高,用户任务运行结束进入空闲状态时,再将实时时钟频率降低。

    测试和方案对比:

    首先在处理器μ′nSPTM处理器上移植μCOS-Ⅱ实时操作系统。运行正常后测试用的用户任务是以1 Hz的频率点亮LED指示灯。表2是测试数据(外电源电压4.82 V,稳压后处理器电压3.3 V)。

    测试结论:

    虽然以整机电流进行测试不能完全反映处理器的工作情况,但从以上数据可以知道,采用两种方案确实可以降低系统功耗,而且方案一的效果更好,但需要占用一个定时器,在测试中发现当任务增加后功耗很快达到方案二水平,且有时不能正常唤醒;方案二很稳定,而且不需要定时器,用户可以根据任务的运算量设定不同的时钟频率,如需要大的运算任务,可在进入用户任务之前将时钟频率设置为较高值,反之设置为较低值。以上采用的方法只是动态地改变系统的频率,没有动态地改变电压水平,因此在降低嵌入式系统功耗方面依然有进一步的潜力。但动态改变电压水平需要更多硬件支持,在目前广泛使用的中低端处理器中,通过扩展实时操作系统内核动态地改变系统的频率对降低嵌入式系统功耗是大有裨益的。

4 结 语

    在嵌入式系统设计中,由于普遍存在CPU高速运行功能和有限任务处理要求的巨大差异,会形成系统在时间与空间上巨大的无效操作。如果能够根据系统的工作状态自动地进行功耗管理,使系统工作于系统状态相适应的功耗模式,故能极大地降低系统功耗,延长电池待机时间。这些工作对嵌入式开发有重大的意义。

关键字:低功耗  实时时钟  μCOS-Ⅱ 引用地址:μCOS-II实时操作系统在μ′nSPTM中的低功耗研究

上一篇:VxWorks下的多重定时器设计
下一篇:基于μC/OS-II的智能窗系统设计

推荐阅读最新更新时间:2024-05-02 21:00

ST让手机和穿戴式设备在室内和封闭空间内拥有优异导航性能
一体化电子罗盘芯片集成磁传感器创新技术,创立测量精确度标杆和优异的温度稳定性 实现高精度行人航位推算,提升健身跟踪/记录和室内导航应用的使用体验 集成高性能MEMS加速度计,比现有解决方案节省能源和空间 中国,2016年5月5日 横跨多重电子应用领域、全球领先的半导体供应商意法半导体(STMicroelectronics,简称ST;纽约证券交易所代码:STM)推出其最新的电子罗盘,让智能手机、智能手表、健身跟踪器以及其它穿戴式设备具有更好的导航和健身运动成绩记录功能,即使在卫星导航无法正常工作的情况下,仍能实现出色的定位功能。 健身跟踪手机应用、智能手表和手环在跟踪记录健身运动情况时需要连续的位置数
[物联网]
ST让手机和穿戴式设备在室内和封闭空间内拥有优异导航性能
意法半导体(ST)新款LoRa™开发工具
中国,2016年9月19日 横跨多重电子应用领域、全球领先的半导体供应商意法半导体(STMicroelectronics,简称ST;纽约证券交易所代码:STM)推出一套价格亲民的基于意法半导体STM32微控制器生态系统的开发工具,设计工程师利用新开发套件能够开发有LoRa 无线低功耗广域物联网(LPWAN, Low-Power Wide Area Network)联网功能的物联网(IoT)设备原型。 新开发套件P-NUCLEO-LRWAN1由两块板子组成:超低功耗的STM32L073 Nucleo (NUCLEO-L073RZ) 微控制器开发板和基于Semtech 公司的SX1272 LoRa收发器的射频扩展板
[物联网]
意法半导体(ST)新款LoRa™开发工具
ST高压转换器让智能家居和工业用电源实现超低功耗
中国,2016年7月27日 横跨多重电子应用领域、全球领先的半导体供应商意法半导体(STMicroelectronics,简称ST;纽约证券交易所代码:STM)近日推出一款高压功率转换器VIPER01,设计人员利用这款芯片能够研制超功耗、设计简单且高成本效益的5V输出电压开关电源(SMPS)。为家电、楼宇自动化、电机控制、 工业自动化和消费电子产品的低功耗电源专门设计,新产品VIPER01可直接使用整流电源,集成PWM (Pulse-Width Modulation,脉宽调制)电流式控制800V耐雪崩功率MOSFET和多种保护电路。考虑到该硬件的物联网属性 需要长时间联接互联网或局域网,这款功率转换器芯片还提供辅助电源选项,为物联
[物联网]
ST高压转换器让智能家居和工业用电源实现超<font color='red'>低功耗</font>
使用Dialog超低功耗Wi-Fi平台简化智能家居网络
智能家居的愿景是帮你把生活变得简单,比如帮你烹饪食物、购买食材、自动清洁、早上打开窗帘轻轻唤醒你等等,但现实离这样还有很大差距。 如今的智能家居应用采用了各种各样的协议,对于不懂技术的消费者来说,是很难理解这些协议的。你可以去商店购买任何手机或笔记本电脑,它们肯定都可以连接到Wi-Fi网络,但要购买智能家居设备时,你必须先确保它与你现有的设备可以结合使用。智能家居的问题在于物联网协议的碎片化。高带宽应用采用Wi-Fi和以太网。低功耗设备采用Zigbee和Z-wave。Zigbee还有多个版本,不同版本之间互不兼容。Z-wave是一种专有协议,将用户和设备制造商锁定到一个供应商。 要使用这些协议构建智能家居,你需要有一个昂贵
[嵌入式]
使用Dialog超<font color='red'>低功耗</font>Wi-Fi平台简化智能家居网络
NXP蓝牙5低功耗SoC贸泽开售
专注于引入新品并提供海量库存的电子元器件分销商贸泽电子 (Mouser Electronics) 即日起开售NXP® Semiconductors的QN9090和QN9030片上系统 (SoC)。这两款智能互联解决方案具有强大的CPU和先进的低功耗模式,能够支持蓝牙5低功耗连接和可选的NFC NTAG功能。 贸泽供应的QN9090和QN9030器件由Arm® Cortex®-M4处理器提供支持,运行频率为48 MHz。这两款SoC具有高达640 KB的板载闪存和152 KB SRAM,为复杂应用和安全无线 (OTA) 更新提供所需的存储空间和灵活性。 QN9090T和QN9030T集成了NFC NTAG
[物联网]
NXP蓝牙5<font color='red'>低功耗</font>SoC贸泽开售
STM32L0低功耗设计3: Stop模式下的真实功耗
在12V输入端测量电流时,电流变化比较大,不能确认语句执行的有效性,所以在3.3V稳压前端接入电流表,以测量真实电流功耗。 main函数中的程序,如下,程序一执行就进入Stop模式。 int main(void){ Target.EnterStopMode(); while(1) { }} EnterStopMode函数里面做的事情,也很简单,如下: void CTarget::EnterStopMode(void){HAL_PWREx_EnableUltraLowPower();HAL_PWREx_EnableFastWakeUp();__HAL_RCC_WAKEUPSTOP_CLK_CONFIG(RCC_STOP
[单片机]
STM32小白入门(第15天)-------低功耗
一、低功耗模式 1、概述 2. 身边应用的例子 A. 电脑 A. 小米手环 二、睡眠模式 三、停止模式 关于PWR_EnterSTOPMode的参数PWR_MainRegulator_ON与PWR_LowPowerRegulator_ON的区别: #define PWR_MainRegulator_ON ((uint32_t)0x00000000) #define PWR_LowPowerRegulator_ON PWR_CR
[单片机]
STM32小白入门(第15天)-------<font color='red'>低功耗</font>
低功耗精密信号链应用最重要的时序因素有哪些?(上篇)
低功耗精密信号链应用最重要的时序因素有哪些?(上篇) 摘要 本文将介绍低功耗系统在降低功耗的同时保持精度所涉及的时序因素和解决方案,以满足测量和监控应用的要求。文中分析了模拟前端时序、ADC时序和数字接口时序,并给出了分析控制评估(ACE)时序工具的示例,这些工具旨在帮助系统设计人员和软件工程师可视化对测量时序的影响或设置。上篇概述了两种主要类型的ADC,主要关注Σ-Δ架构。下篇将介绍与SAR ADC架构相关的考虑因素。 引言 “时间至关重要”的俗语可以应用于任何领域,但当应用于现实世界信号的采样时,却是工程学科的支柱。当尝试降低功耗、实现时序目标并满足性能要求时,必须考虑测量信号链选择何种ADC架构类型:Σ-Δ还
[模拟电子]
<font color='red'>低功耗</font>精密信号链应用最重要的时序因素有哪些?(上篇)
小广播
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved