在便携式应用中,低功耗是产品能否独树一帜的关键所在,其决定着产品的尺寸大小与 *** 作时间。举例来说,如果您在跨越大洋的飞行时选择便携式DVD播放器作为消遣,那么电池寿命将会成为您的首选标准之一。在本文中,我们将集中讨论许多更为常用的基于软件的技术。首先,我们从讲解某些可用于嵌入式系统的电源管理技术开始,并谈谈其在实时应用中会遇到的诸多难题。电源效率既由硬件设计与组件选择决定,同时也由基于软件的运行时电源管理技术决定。本文后半部分将集中展示如何将技术子集成到用于数字信号处理器(DSP)的实时 *** 作系统(RTOS)中,从而使应用开发人员选择出可满足其应用要求的专用技术。我们将以德州仪器公司(TI)的(TI) DSP/BIOS *** 作系统为作为实例,显示运行时电源管理软件技术的实施方法。 运行时电源管理技术
尽管我们讨论的是某些可扩大标准多线程读取 *** 作系统(OS)的特定电源管理技术,但应当强调指出的是,采用抢先式(preempTIve)的多线程读取OS本身常常能够实现显著的电源节约。不利用OS的实时应用常常要求应用周期性探询接口以检测事件。从电源角度看,这样的效率是相当低的。使用OS可使应用能够利用中断驱动模式,其中程序就会在需要的时候开始执行,以响应外部事件。此外,当基于OS的应用没有可做的事情时,其就会进入空闲线程,这时则可启动低功率 *** 作模式,以减少功耗。
但是, *** 作系统除了能简单地为DSP内核启用空闲模式之外,其还需要提供复杂得多的电源管理支持。在实践中,大量功率被周边设备所消耗,可能是片上器件,也可能是外部设备,此外存储器也会消耗大量功率。任何电源管理方法都应当具备管理外设功耗的支持,这是至关重要的。此外,电压与功耗之间的平方关系意味着,更高效的方法是在要求较低电压的较低时钟速率上执行代码,而不是先以最高的时钟速率执行而后再转为空闲。我们将概括讲解在 *** 作系统中实施电源管理支持的众多机遇:
系统上电行为:
处理器及其片上外设一般均以最高时钟速率全面上电启动。不可避免的是,有些资源的供电启动还尚不需要,或者根本就不会在应用过程中用到。举例而言,MP3播放器就很少使用其USB端口与PC进行通信。在启动时, *** 作系统必须为应用提供一种调节系统的机制,从而关闭不必要的电源消耗器件或使之处于空闲状态。
空闲模式:
CMOS电路中的有效功耗只有在当电路进行时钟计时的情况下才发生。通过关闭不需要的时钟,可以消除不必要的有效功耗。在等待外部事件时,大多数DSP都融入了暂时终止CPU有效功耗的机制。CPU时钟的"闲置"通常由"停止"或"闲置"指令触发,其在应用或 *** 作系统闲置时进行调用。一些DSP进行多个时钟域分区,可以使这些域分别处于空闲状态,以中止未使用模块中的有效功耗。例如,在TI的TMS320C5510 DSP中,可以有选择性地使6个时钟域闲置,其中包括CPU、高速缓存、DMA、外设时钟、时钟生成器,以及外部存储器接口。
除了支持闲置DSP及其片上外设之外, *** 作系统还必须提供用于闲置外部周边设备的机制。例如,一些编码译码器具备可以被激活的内置低功率模式。我们面临的一个挑战是类似看门狗定时器这样的外设。通常情况下,看门狗定时器应根据预定义的时间间隔提供服务,以避免其激活。这样,减缓或中止处理的电源管理技术就可能无意中导致应用故障。因此,该OS应当使应用在睡眠模式期间禁用此类外设。
断电:
尽管空闲模式消除了有效功耗,但静态功耗即便在电路不进行切换的情况下也会出现,这主要是由于逆向偏压泄漏(reverse-bias leakage)造成的。如果系统包括的某个模块不必随时供电,那么我们就可以通过让 *** 作系统仅在需要时才为子系统上电,从而减少功耗。到目前为止,嵌入式系统开发商对最小化静态功耗投入的工作极少,因为CMOS电路的静态功耗非常低。但是,新型、具有更高性能的晶体管使电流泄漏显著增加,这就要求我们对可降低静态功耗及更复杂的睡眠模式给予新的关注。
电压与频率缩放(frequency scaling)有效功耗与切换频率成线性比例,但与电源电压成平方比。以较低的频率运行应用与在全时钟频率上运行该应用并转入闲置相比,谈不上节约了多少功率。但是,如果频率与平台上可用的更低 *** 作电压兼容的话,那么我们就可能通过降低电压来实现显著的节约,这正是由于上述平方关系的缘故。这也使人们就如何通过电压缩放来节约功率进行了大量的学术研究。
尽管电压缩放是一种潜在的、非常诱人的、降低功耗的方法,但在现实世界的应用中我们对其加以利用时应当小心。这是由于我们需要完全了解该系统是否仍能满足它的实时最后期限。降低电压(进而降低CPU频率)将改变给定任务的执行时间,从而有可能导致人物错过实时最后期限。即便新频率与最后期限兼容,但如果开关频率及电压的等待时间太长,还是会出现问题。影响等待时间的因素包括如下:
* 对稳压器进行再编程所需时间
* DSP能否在电压更改期间继续执行其他任何代码
需要对外设进行再编程,如串行端口或外部存储器接口,与接收不同始终来源的周边外设相接。例如,CPU 时钟速率降低可能要求减少访问外部存储器的等待状态数量。
对用于生成 *** 作系统时钟报时信号的计时器进行再编程的可能性,将影响 *** 作系统时基的绝对正确性。
尽管电压缩放实际等待时间会根据所选DSP以及需要再编程外设的数量而不同,但在许多系统中,等待时间仅为几百微秒甚至几毫秒。在许多实时应用中,这将使电压缩放不切实际。尽管存在上述弱点,但仅在某些可事先预见的模式下,那些需要完全处理功率的应用,还是有可能利用电压缩放的。例如,便携式音乐播放机可利用DSP进行MP3译码及用户接口要求的一般控制处理。如果仅MP3译码要求完全时钟速率,那么DSP便可在执行用户接口功能时降低其电压,而仅在音乐数据开始流向DSP时才以完全功率工作。
在DSP RTOS中实施电源管理
上述电源管理技术的一个子集已包括在DSP的RTOS中。为了更好地说明如何将电源管理构建到RTOS中,我们将更详细地对实施进行总体讨论。
正如我们在前面讨论中看到的那样,特定系统减小功耗的方法主要取决于应用的性质以及DSP和周边外设提供的选项。因此,关键的设计目标就是高效性及灵活性。尽管下面所描述的实施是就特定RTOS而言的,但其概念可简单地运用其它 *** 作系统,甚至用于无 *** 作系统的应用环境。
电源管理器(PWRM)的要求
首款电源管理器实施的关键要求如下:
* 电源管理动作是应用触发而不是 *** 作系统触发的。更改DSP *** 作模式或功能的主要决策由应用作出,并由PWRM调用推动执行。但 *** 作系统可以(也应当)自动采取行动以节电,只要该行动不影响应用即可。例如,PWRM应当在CPU闲置时自动闲置CPU时钟。
* 电源管理动作由应用的控制部分触发,但应当对大部分应用代码均为透明的。例如,具有极高价值的、优化的DSP算法不必重写便可在管理的电源环境中工作。
* 电源管理器必须支持电压与频率(V/F)缩放,还必须充分利用芯片闲置与睡眠模式。
* 电源管理器必须协调整个应用过程中的电源事件处理(如应用代码、驱动器以及 *** 作系统本身),并在特定事件发生时向已注册要求获得通知的客户发出通知。
* 电源管理特性必须在任何线程环境中可用,还必须对特定客户的多个实例可用(如一个编码译码器驱动器的多个实例)。
* 在向客户发出电源事件通知时,电源管理器必须支持事件处理的延迟完成,并在等待延迟客户的完成信号同时通知其他客户。
* 电源管理器必须对具有不同功能的不同平台是可扩展的和便携性的。
电源管理模块(PWRM)
称作PWRM的电源管理器作为DSP/BIOS的一个附属模块被添加,如图1所示。
从概念上说,电源管理器与内核并行;其并非系统中的另一项任务,而是作为一系列在应用控制线程以及器件驱动器环境中执行的API而存在的。无需进行内核修改便可合并到PWRM中;但在CPU时钟与 *** 作系统计时器时钟相联结的平台上,DSP/BIOS时钟模块(CLK)要进行补充例行程序,以使其根据频率缩放事件调整 *** 作系统时钟(作为PWRM的客户)。PWRM写入并读取时钟空闲配置寄存器,并通过控制CPU时钟速率及稳压电路的针对不同平台的功率扩展库(PSL)直接与DSP硬件相连接。PSL将PWRM及应用的其他部分与频率及电压控制硬件的低级实施细节相隔离。
电源管理器的作用在于管理DSP/BIOS应用中所有与电源相关的事项,既有应用开发人员静态配置的,也有在运行时动态调用的:
电源管理 *** 作的静态配置。PWRM支持DSP/BIOS配置工具为一些电源管理 *** 作提供设计时选项。例如,开发人员可配置闲置功能,插入DSP/BIOS闲置环路中,以自动闲置DSP缓存及CPU;或配置节电功能,在导入时自动调用,以便闲置不必要的外设或子系统。
电源管理API:
PWRM提供了API,使开发人员能够闲置特定的时钟域,以调用定制睡眠模式,并动态更改DSP CPU的 *** 作电压及频率。凭借新型API系列,应用还可指定是否应将电压与频率同时缩放,是否可在电压降低转换过程中继续执行,以及V/F设置点属性及等待时间的查询。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)