WINCE 設(shè)備驅(qū)動中實(shí)現(xiàn)電源管理
在WinCE4.0之前電源管理工作是由GWES來實(shí)現(xiàn)的。( GWES:Graphics,Windows and Events Subsystem.圖形,窗口和事件子系統(tǒng).主要負(fù)責(zé)圖形輸出和用戶交互)。但GWES提供的電源管理模塊功能過于粗糙死板:所有子設(shè)備只能有On和Suspend狀態(tài),應(yīng)用程序無法得到任何狀態(tài)轉(zhuǎn)換通知,等等……直到WinCE4.0才引入了電源管理模塊用以替代GWES中的電源管理功能。
電源管理模塊實(shí)體是一個動態(tài)鏈接庫pm.dll來實(shí)現(xiàn)的。電源管理模塊的代碼結(jié)構(gòu)是分層的,MDD+PDD。MDD是抽象公共庫,一般不需要改動,PDD是平臺相關(guān),主要改動都在PDD。針對平臺特性,微軟提供了2種類型PDD示例.一種是default,另外一種是pda版本的,這都可以在源代碼里面找到的。默認(rèn)的情況,使用的是default。如果要使用pda版本的,需要在系統(tǒng)中指定環(huán)境變量SYSGEN_PM_PDA。
default和pda版本的主要區(qū)別在與對系統(tǒng)電源狀態(tài)的定義上面:
default版本定義了4種狀態(tài):On, UserIdle, SystemIdle, Suspend;
PDA版本定義了On, ScreenOff, Unattended, Resume, Suspend。
default版本的簡單描述:UserIdle狀態(tài)是描述用戶在使用但沒有操作,比如閱讀.SystemIdle狀態(tài)描述用戶停止使用,但系統(tǒng)仍然工作,比如文件傳輸。
PDA版本簡單描述:ScreenOff狀態(tài)描述用戶請求把屏幕背燈關(guān)閉。是用戶主動關(guān)閉的情況,區(qū)別于UserIdle,UserIdle是自動的。Unattended狀態(tài)表示后臺工作,用戶不會對其察覺的情景,比如ActiveSync每5分鐘喚醒系統(tǒng)同步,然后繼續(xù)suspend; Resume狀態(tài)描述喚醒后情景,比如喚醒后在指定時間內(nèi)決定轉(zhuǎn)到哪個狀態(tài),否則繼續(xù)suspend。
上面說的是系統(tǒng)也就是CPU所處于的幾種狀態(tài),下面來說說外部設(shè)備的狀態(tài)。在微軟里,設(shè)備的電源狀態(tài)被定義了如下幾種:D0,D1,D2,D3,D4,分別代表Full on,Low on, Standby, Sleep, Off這5個狀態(tài)。
上面主要是介紹了兩個狀態(tài),一個是CPU的,一個是設(shè)備的。下面我們再來說說電源管理模塊。電源管理模塊也就是pm.dll的功能可以從兩
個方面來理解:一個是對設(shè)備驅(qū)動,一個是對應(yīng)用程序。也就是說設(shè)備驅(qū)動可以通過電源管理模塊來管理改設(shè)備的電源狀態(tài),應(yīng)用程序也可以通關(guān)電源管理模塊來實(shí)現(xiàn)一定的功能,它們都有各自的API函數(shù)。
下面我們就來看看對與設(shè)備驅(qū)動的電源管理的實(shí)現(xiàn)。
通過上面我們已經(jīng)知道設(shè)備可以有D0-D4五種狀態(tài),那么實(shí)現(xiàn)了電源管理的設(shè)備驅(qū)動就可以智能的管理該設(shè)備的電源狀態(tài)也可以理解為工作狀態(tài)。電源管理模塊對設(shè)備驅(qū)動提出了一個規(guī)范和架構(gòu),滿足規(guī)范的驅(qū)動納入電源管理.對于流驅(qū)動控制的設(shè)備,要支持電源管理要滿足的條件,簡單來說有:
1.聲明自己是支持電源管理的(就是在注冊表里有相應(yīng)的Iclass值)。
"IClass" = "{A32942B7-920C-486b-B0E6-92A702A99B35}" ; GUID for generic power-managed devices
2.驅(qū)動中實(shí)現(xiàn)電源管理模塊所要求的IOCTL
3.驅(qū)動加載時候要匯報所支持的電源狀態(tài)和相關(guān)特征.
4.***_PowerDown和***_PowerUp接口接收系統(tǒng)休眠和喚醒通知.
電源管理器通過IOCTL代碼來和驅(qū)動通信。通常情況下,當(dāng)一個驅(qū)動程序聲明為支持電源管理時,驅(qū)動只需要在DeviceIoControl中實(shí)現(xiàn)電源的管理即可。下面是電源管理器用來與驅(qū)動通信的IOCTL代碼:
IOCTL_POWER_CAPABILITIES:代表電源管理器請求設(shè)備驅(qū)動返回設(shè)備支持的電源狀態(tài)及相關(guān)特征;
IOCTL_POWER_SET:請求驅(qū)動更新設(shè)備的電源狀態(tài);
IOCTL_POWER_QUERY:電源管理器詢問設(shè)備是否準(zhǔn)備好進(jìn)行狀態(tài)切換;
IOCTL_POWER_GET:請求驅(qū)動返回當(dāng)前設(shè)備的電源狀態(tài);
IOCTL_REGISTER_POWER_RELATIONSHIP:通知父設(shè)備注冊所有它所控制的設(shè)備。
其中IOCTL_POWER_CAPABILITIES和IOCTL_POWER_SET是支持電源管理的設(shè)備驅(qū)動必須實(shí)現(xiàn)的。
一個實(shí)現(xiàn)電源管理的驅(qū)動:
\WINCE600\PLATFORM\COMMON\SRC\SOC\COMMON_FSL_V\BACKLIGHT\DRIVER\backlight.cpp
在設(shè)備自我管理電源的情況下,設(shè)備應(yīng)該通過DevicePowerNotify函數(shù)請求系統(tǒng)改變它們的電源狀態(tài),這個時候電源管理模塊就用調(diào)用相應(yīng)的IOCTL來實(shí)現(xiàn)電源狀態(tài)的管理。就是驅(qū)動調(diào)用了該驅(qū)動中的部分函數(shù)。
此外,設(shè)計(jì)驅(qū)動還應(yīng)該了解:設(shè)備不一定具備所有5種狀態(tài),但至少可以工作在D0;電源管理模塊可能會要求設(shè)備進(jìn)入任何設(shè)備電源狀態(tài),并不僅僅是設(shè)備所匯報自己支持的那幾個;如果被要求進(jìn)入不支持的狀態(tài),應(yīng)該進(jìn)入另一個它所支持的更高功耗的狀態(tài);當(dāng)前狀態(tài)不需要重復(fù)設(shè)置;設(shè)備電源狀態(tài)不一定和系統(tǒng)的電源狀態(tài)同步。