0 卖盘信息
BOM询价
您现在的位置: 首页 > 技术方案 >计算机及配件 > 基于WinCE驱动程序的电源管理研究与设计

基于WinCE驱动程序的电源管理研究与设计

来源: 维库电子网
2021-10-27
类别:计算机及配件
eye 4
文章创建人 拍明

原标题:基于WinCE驱动程序的电源管理研究与设计

  摘要: 为了降低嵌入式终端系统的功耗、延长系统的待机时间和电池的使用寿命, 设计了一种 基于Windows CE 操作系统 的嵌入式终端背光驱动的电源管理系统; 分析了 WinCE 下的流接口驱动程序模型和电源管理架构, 研究了背光驱动程序的电源管理策略, 包括设备电源状态和系统电源状态的变化以及 IOCTL 操作码的使用; , 通过在注册表中设置指定时间的超时值, 完成了显示设备的背光驱动的设计, 合理的节省了移动设备的电能, 满足了系统对背光的控制需求。

  0 引言

  W inCE 的两种模型是本机的设备驱动程序和流接口的驱动 程对于通常的嵌入式电子设备, 尤其是不能长久地连接交流电源的嵌入式电子设备, 降低显示设备的耗电一直是电源管理的主要任务。目前, 有许多类型的显示设备, 但现代大多数产品都选用反射式薄膜晶体管 ( TFT ) 显示加背光灯作为显示设备。虽然在光线充足的情况下可以看清屏幕上的内容, 但是考虑到阅读的舒适度, 还是需要把背光灯打开。 基于 W indow s CE 的嵌入式系统终端通 常以电池供电。因此, 背光驱动电源管理的作用显得尤为关键。如何减少目标系统的不必要的耗电, 延长其待机时间, 就成了 W indow s CE 操作系统电源管理设计与开发的一个重要内容。

  本文从WinCE 的流接口设备驱动程序出发, 详细介绍了基于 Window s CE 操作系统电源管理策 略和基本原理, 并且在WinCE 背光驱动中实现了电源管理的设计与开发。

  1 Window CE 驱动程序架构

  目前,WinCE 提供了四种设备模型, 其中两种是专门用于 WinCE 的模型,另外两种模型来自其他操作系统。基于WinCE 的两种模型是本机的设备驱动程序和流接口的驱动程序。两种外部模型用于通用串行总线(USB) 和网络驱动器接口标准(NDIS) 驱动程序。其中流接口驱动程序是为连接到基于WinCE 平台的外围设备而设计的, 这些外围设备包括SD 卡、摄像头、打印机等,其驱动模型如图1 所示。本文基于S3C2440A 的ARM9 开发板上LCD 显示屏的背光控制流接口驱动程序, 详细分析WinCE 下背光驱动的电源管理开发实现流程。

图1    Windows CE 流接口驱动模型

图1    Window s CE 流接口驱动模型

  从图1 可以看出, 外围设备由设备驱动程序管理, 用户应用程序通过调用文件系统从而实现对外部物理设备的访问, 流接口驱动程序通过把外围设备表示为文件系统的一个特殊文件, 而使得应用程序在使用外围设备时就像打开、关闭一个文件一样简单。

  2    Window CE 电源管理

  2.1    电源管理架构和电源管理器

  电源管理的总体结构如图2 所示。电源管理器直接或者间接地与应用程序和驱动程序交互。电源管理器与驱动程序主要通过驱动程序接口进行交互, 与应用程序通过API 和提醒接口进行交互。其中, 电源管理器专门负责管理设备电源状态, 从而提高操作系统的整体电源效率, 并且与不支持电源管理的驱动程序相兼容。电源管理器在操作系统中的软件实体是动态链接库pm. dll, 它由设备管理器device. dll 加载到Windows CE 的内核进程中运行。

图2    电源管理架构示意图

图2    电源管理架构示意图

  使用电源管理器, 设备接收作为I/ O 控制代码(IOCT L)形式的电源状态变化的通知。使用IOCT L 管理电源可以区分设备的电源状态与整个操作系统的电源状态。这样, 当操作系统正在运行时, 一些设备可以关闭自己的电源, 而当操作系统挂起时, 另外一些设备可以保持原有状态。

  2.2    Windows CE设备电源状态和系统电源状态

  电源管理器期望所有被管理的设备都支持一个或者多个设备电源状态, 设备必须向电源管理器它们的电源消耗特征, 设备电源状态通常需要在性能与电量消耗之间进行折中。

  电源状态包括系统电源状态和设备电源状态。设备管理器在由OEM 定义的系统电源状态的范围内管理设备电源状态, 系统电源状态对设备电源状态施加了一个上界。

  Window s CE 的设备电源状态是操作系统的静态的预定义电源状态。外设的驱动程序从电源管理器处接收改变设备电源状态的请求, 将它转换成外设可以支持的电源状态, 并且负责实现在物理外设上的电源状态改变。

  Window s CE 提供5 种预定义的设备电源状态。它们在注册表中也有相对应的键。如果以Dn 代表D0~ D4, 则n 的数字越小的电源状态等级下外设的耗电量越大, 如表1 所列。

  表1    设备电源状态

表1    设备电源状态

  Window s CE 操作系统的系统电源状态与设备电源状态性质完全不同, 它不是静态定义的, 而是由OEM 用户根据需要自定义。OEM 用户通过配置系统注册表定义系统的电源状态,系统电源状态的名称被定义成注册表项的名字。图3 描述了Window s CE 支持4 种典型的系统电源状态的转换。

图3 系统电源状态的转换

图3 系统电源状态的转换

  3 背光驱动的电源管理

  3.1  LCD 背光的电源管理策略

  背光驱动启动一个监视工作线程, 不停的等待3 个事件:

  3.1.1  BackLightChang eEv ent

  等待注册表中时钟的更新, 在注册表的时钟更新之后总是将背光灯打开。

  dw Resul t = WaitForMul tipleObject s( NUM _EVENT S, & g_evtSignal[ 0] , FALSE, dw Tim eout ) ;

  if ( WAIT _OBJECT_0 = = dw Res ult ) {

  BL_ReadRegist ry( & g_BLInf o) ;

  BL_On( TRUE) ;

  }

  3.1.2  Pow erChangedEv ent

  供电电源发生变化, 例如插入了电源, 监视线程会获得了这个事件。如果使用电源, 可以使用m _ dw ACTimeout 值作为超时值, 否则, 使用m _ dw Batter yT imeout 值作为超时值。

  if ( dw Result = = WAIT_OBJECT _0+ BL_POWERE VT) {

  if ( IsACOn( ) ) {

  dw Timeout = g_BLInf o. m_dw ACTim eout * 1000;

  }

  else {

  dw Timeout = g_BLInf o. m_dw Bat t eryT imeout * 1000;

  }

  }

  3.1.3  Pow erM anag er/ ActivityTimer / UserActivity

  等待用户输入事件,如果用户有按键动作,则无论电源插上与否背光驱动都打开,否则,等待超时事件的发生, 将背光驱动关闭。

  if ( dw Result = = WAIT_OBJECT _0+ 1 | | dwResult = = WAIT _OBJECT _0 + BL_BUT TONEVT )

  {

  if ( IsACOn( ) ) {

  if ( g_BLIn fo. m_bAC Au t o) {

  BL_On( TRUE) ; }

  }

  else {

  if ( g_BLIn fo. m_bBat t eryAut o) {

  BL_On( TRUE) ; }

  }

  }

  else if ( dw Result = = WAIT_T IMEOUT ) {

  BL_On( FALSE) ;

  }

  注册表的超时值决定了背光灯的工作时间。在注册表中进行如下超时值的设置:

  [ H KEY_CURRE NT_USER/ Cont rolPanel / Backlight ]

  "AC Timeout "= dword: 3c / / 十六进制, 十进制为60

  "Bat t eryT imeout "= dw ord: 1e / / 十六进制, 十进制为30

  3.2  创建支持电源管理的背光驱动

  要想获得电源管理的功能支持, 首先要使电源管理器可以识别背光驱动程序。为此, 背光驱动需要向设备管理器声明一个特殊的代表电源管理的设备类型的GUID.具体操作是在Active 注册表键的IClass 表项中增加一个GUID.在Platform.reg 文件中添加如下:

  "IClass "= "{ A32942B7- 920C- 486b - B0E6 - 92A702A99B35} "; Pow er- manageable generi c

  3.3  在背光驱动中添加对I/O 控制代码( IOCTL) 的支持

  在背光驱动被通知为支持电源管理的驱动后, 只需处理来自电源管理器的DeviceIoControl 调用。电源管理器使用如表2所示的IOCTL 代码与背光灯进行通信。

  表2 电源管理的IOCTL 操作码

表2 电源管理的IOCTL 操作码

  其中IOCTL _ POWER _ CAPABILITIES 是支持任何一个支持电源管理的流接口驱动程序所必须实现的。

  3.4 IOCTL 代码的实现

  在驱动程序被加载到系统中的初始阶段, 背光驱动首先将设备电源状态置于D0 状态, 然后电源管理器通过IOCTL _POWER _ CAPABILITIES 操作码调用它的IOControl 函数。

  在向设备发出查询时, 背光驱动详细的该设备的电源管理能力, 以便将自己纳入到系统的电源管理策略中去。如果本次的查询电源管理支持能力的操作失败, 则电源管理器将会认为该设备驱动程序不支持其他4 个电源管理IOCTL 操作码。具体代码如下:

  cas e IOCT L_POWER_CAPABILIT IES :

  {

  PPOWER_CAPABILIT IES ppc;

  if ( ! pdw ActualOu t | | ! pBufOut | | ( dw LenOut < sizeof

  ( POWE R_CAPABILITIES) ) )

  {

  RetVal = FALSE ;

  dw Er r = ERROR_INVALID_PARAMET ER;

  break;

  }

  ppc = ( PPOWER_C APABILITIES ) pBufOut ;

  m ems et ( ppc, 0, sizeof ( POWER_CAPABILIT IE S) ) ;

  ppc- > DeviceDx = 0x11; / / 支持D0, D4 两种设备电源状态

  ppc- > Pow er[ D0] = 25000; / / 25 m = 25000 uA

  * pdw ActualOut = siz eof (POWE R_CAPABILITIES) ;

  } break;

  在初始阶段完成后, 电源管理器可以根据电源管理策略调用IOCTL _ POWER _ SET 调整设备的电源状态。在实现对IOCTL _ POWER _ SET 支持时, 开发背光驱动需要注意的是设备并不一定具备所有五种设备电源状态, 但至少工作在D0状态和D4 状态。

  3.5 休眠和唤醒的处理

  电源休眠唤醒是延长系统电源工作时间的一项重要技术。在系统进入休眠状态时, 驱动程序应该关闭设备的电源, 即使该设备由于应用程序的请求不处于D4 状态。背光驱动通过BAK _ Pow erDown 和BAK _ PowerUp 接收系统休眠和唤醒的通知, 这些通知在内核调用OEMPowerOff 之前发出, 并处于中断上下文中。

  4 背光驱动测试

  将背光驱动打包进内核镜像文件, 到开发平台, 打开系统显示属性, 在使用电池电源供电的情况下, 如果用户在30s 之内没有活动, 那么LCD 的背光灯将进入空闲状态; 在使用外部电源供电的情况下, 如果用户在1 分钟内没有活动,那么LCD 的背光灯也将进入空闲状态。

  5 结论

  本文设计了一种基于Window s CE 操作系统的嵌入式终端背光驱动的电源管理系统。在分析流接口驱动和WinCE 操作系统电源管理的基础上, 结合电源管理的IOCT L 操作码, 完成了背光驱动电源管理系统的设计, 并给出了背光驱动程序电源管理部分实现的关键性代码。经过测试, 背光驱动程序可以有效地控制LCD 背光灯的电力消耗, 也能够与整个系统的电源状态协调一致, 系统对背光的控制满足设计需求。, 本文对WinCE 操作系统下背光驱动电源管理策略的研究, 对设计其他同类嵌入式终端产品驱动程序的电源管理系统也具有重要的指导意义和参考价值。


责任编辑:

【免责声明】

1、本文内容、数据、图表等来源于网络引用或其他公开资料,版权归属原作者、原发表出处。若版权所有方对本文的引用持有异议,请联系拍明芯城(marketing@iczoom.com),本方将及时处理。

2、本文的引用仅供读者交流学习使用,不涉及商业目的。

3、本文内容仅代表作者观点,拍明芯城不对内容的准确性、可靠性或完整性提供明示或暗示的保证。读者阅读本文后做出的决定或行为,是基于自主意愿和独立判断做出的,请读者明确相关结果。

4、如需转载本方拥有版权的文章,请联系拍明芯城(marketing@iczoom.com)注明“转载原因”。未经允许私自转载拍明芯城将保留追究其法律责任的权利。

拍明芯城拥有对此声明的最终解释权。

相关资讯