嵌入式系統(tǒng)電源管理軟件比較(下)
嵌入式Linux
本文引用地址:http://cafeforensic.com/article/80015.htm嵌入式Linux電源管理結(jié)構(gòu)
Linux標(biāo)準(zhǔn)內(nèi)核標(biāo)準(zhǔn)電源管理有ACPI、APM等機制。這些機制依賴于PC機的BIOS功能實現(xiàn)。嵌入式系統(tǒng)一般都沒有實現(xiàn)BIOS支持,對其能耗管理機制需要進行其他定義。消費類電子產(chǎn)品聯(lián)盟—CELF對能耗管理作了定義,其框架如圖4所示。
圖4 CELF電源管理規(guī)范
CELF的能耗管理框架分為內(nèi)核層和用戶層。內(nèi)核層又劃分為體系結(jié)構(gòu)無關(guān)層和體系結(jié)構(gòu)相關(guān)層。體系結(jié)構(gòu)相關(guān)層主要提供可管理硬件支持,例如處理器電壓和運行頻率調(diào)節(jié),各種總線運行頻率管理,設(shè)備的關(guān)斷管理等。內(nèi)核體系結(jié)構(gòu)無關(guān)層在體系結(jié)構(gòu)相關(guān)層的基礎(chǔ)上為用戶層提供APIs,進行各種能耗管理功能的支持。它包含一個能耗管理(PM)引擎,根據(jù)系統(tǒng)任務(wù)負(fù)載選擇系統(tǒng)運行狀態(tài);提供能耗管理的掛起和恢復(fù)方法;提供VST技術(shù),通過估計下次準(zhǔn)確喚醒時間來確保在進入深度睡眠時,不被原來固定時間產(chǎn)生的定時器中斷喚醒;還包含了各種外部設(shè)備關(guān)閉/開啟的操作邏輯。
用戶通過編制具有一定智能的管理策略駐留程序,利用系統(tǒng)提供的能耗管理機制,進行有效的系統(tǒng)能耗管理。
此外,在某些實現(xiàn)中,也可以將ACPI中的BIOS調(diào)用進行映射,在內(nèi)核用軟件實現(xiàn)回調(diào)函數(shù),用以支持沒有BIOS的電源管理。
嵌入式Linux內(nèi)核電源管理實現(xiàn)分析
2.6內(nèi)核提供了一個電源管理框架,在其基礎(chǔ)之上容易實現(xiàn)各種電源管理規(guī)范,例如ACPI和APM規(guī)范。2.6內(nèi)核中的設(shè)備驅(qū)動模型(Linux Driver Model,LDM)是內(nèi)核對電源管理基礎(chǔ)支持。Kobject基本結(jié)構(gòu)嵌入到描述設(shè)備模型的組件的bus、devices、 drivers結(jié)構(gòu)中。這些容器就是通過kobject連接起來形成樹狀結(jié)構(gòu)。每個對象的屬性(attribute)以文件形式輸出到kobject對應(yīng)的sysfs目錄下。通過這種文件系統(tǒng)接口,可以對平臺進行有效的電源管理。
就嵌入式系統(tǒng)而言,電源管理可以分為靜態(tài)電源管理,動態(tài)電源管理,設(shè)備電源管理等三個方面。
·靜態(tài)電源管理
Linux內(nèi)核支持ON, Standby, Suspend, 和Hibernate四種電源狀態(tài)。Standby指“帶電掛起”,通過將CPU置于halt狀態(tài),將設(shè)備置于D1狀態(tài)來達到節(jié)能的目的(ACPI規(guī)范中按能耗從高到低分D0~D3)。節(jié)能效果不明顯,但是響應(yīng)延遲最小。Suspend就是掛起到RAM。在該狀態(tài)下,所有設(shè)備被置于D3狀態(tài),整個系統(tǒng),除主存處于節(jié)電的自刷新模式(self-refresh)外,全部關(guān)閉電源。響應(yīng)延遲比Standby大。Hibernate 是通過將系統(tǒng)狀態(tài)保存到非易揮發(fā)性存儲中(通常是磁盤),關(guān)閉整個系統(tǒng)的電源。延遲時間最長,但比一次完整啟動來得短。通常情況下嵌入式設(shè)備都沒有支持這種方式。
通過sysfs文件系統(tǒng)接口觸發(fā)系統(tǒng)級電源狀態(tài)轉(zhuǎn)化。轉(zhuǎn)換管理是通過注冊好的驅(qū)動來進行。例如,prepare函數(shù)確認(rèn)系統(tǒng)能夠進入所請求的狀態(tài),并且進行相應(yīng)的準(zhǔn)備工作。例如通過禁止搶占和“冷凍”所有進程來準(zhǔn)備進入所請求的電源狀態(tài)。Save函數(shù)枚舉所有注冊有電源管理能力的設(shè)備,保存系統(tǒng)和處理器的低層狀態(tài)。接著PM核心禁止了中斷,關(guān)閉外部設(shè)備電源,調(diào)用Sleep函數(shù)根據(jù)掛起級別進入睡眠狀態(tài)。在嵌入式設(shè)備掛起過程中可以通過寫入某些特殊的非易失性處理器寄存器來記錄掛起的原因和掛起時的代碼執(zhí)行地址。系統(tǒng)上電后引導(dǎo)程序先執(zhí)行,從特殊寄存器中判斷系統(tǒng)是否從深度睡眠(Hibernation)中恢復(fù)。如果是,則負(fù)責(zé)從非易揮發(fā)性存儲介質(zhì)中恢復(fù)所有的硬件上下文。如果不是,系統(tǒng)負(fù)責(zé)從sleep()函數(shù)處返回。給所有設(shè)備上電,恢復(fù)中斷。Restore函數(shù)被用來恢復(fù)系統(tǒng)的低層調(diào)用,恢復(fù)設(shè)備上下文。Cleanup函數(shù)從sleep狀態(tài)恢復(fù)必須進行的清尾工作,例如搶占重新被允許,系統(tǒng)恢復(fù)正常執(zhí)行。當(dāng)一次完整的轉(zhuǎn)換完成后,CPU執(zhí)行權(quán)還給之前執(zhí)行的進程。
·動態(tài)電源管理
(1)動態(tài)電源管理原理
如圖5所示,系統(tǒng)無任務(wù)時進入空閑,可被中斷喚醒,處理完后重新進入空閑或者回到任務(wù)態(tài)。如果系統(tǒng)被掛起到RAM中,進入深度睡眠??梢躁P(guān)閉除了中斷控制器和喚醒源之外的所有設(shè)備,實現(xiàn)最大限度地省電。根據(jù)運行時不同的任務(wù)負(fù)載,系統(tǒng)應(yīng)該有對應(yīng)的不同電源級別。如圖示中的任務(wù)、任務(wù)-、任務(wù)+等代表電源需求的狀態(tài)。在完成任務(wù)的同時,進行最大化的節(jié)能。
圖5 操作狀態(tài)間的轉(zhuǎn)換
(2)動態(tài)電源管理設(shè)計
在Linux架構(gòu)下實現(xiàn)動態(tài)電源管理,需要(1)用戶層的管理策略;(2)內(nèi)核模塊需要為應(yīng)用層提供的接口;(3)硬件無關(guān)的通用電源管理邏輯控制框架;(4)管理特定硬件的平臺相關(guān)電源控制層。
用戶層策略通過sysfs文件系統(tǒng)接口(或proc文件系統(tǒng)接口)以及系統(tǒng)調(diào)用接口(APIs)來進行電源管理。內(nèi)核硬件無關(guān)層提供電源管理邏輯控制,針對任務(wù)負(fù)載情況選擇反映當(dāng)前任務(wù)電源狀態(tài)的電源操作點(相關(guān)可控的硬件參數(shù))。內(nèi)核硬件相關(guān)層主要對應(yīng)系統(tǒng)的各種總線和設(shè)備時鐘電源參數(shù)管理,并管理多種設(shè)備的參數(shù)約束。
·設(shè)備驅(qū)動電源管理
在某些設(shè)備閑置時可以被主動關(guān)閉,從而節(jié)電。在2.6內(nèi)核中需要實現(xiàn)總線以及設(shè)備的電源管理支持,在驅(qū)動中需要實現(xiàn)設(shè)備驅(qū)動的suspend/resume函數(shù)。
關(guān)閉一個設(shè)備,其驅(qū)動的suspend方法需要兩個不同的調(diào)用,一個用來保存狀,另外一個用來關(guān)閉設(shè)備電源。相反,resume方法需要一個調(diào)用用來給設(shè)備供電,另一個調(diào)用來恢復(fù)設(shè)備的狀態(tài)。在關(guān)閉一個總線設(shè)備時必須關(guān)閉所有的下一級子設(shè)備。相反地,重新使能總線設(shè)備時,必須先使能根設(shè)備,然后再使能子設(shè)備。
·用戶層電源管理策略
嵌入式系統(tǒng)如何做到有效的平臺級能耗管理需要在內(nèi)核提供的機制上實現(xiàn)一個智能化的管理軟件,監(jiān)控系統(tǒng)電源狀態(tài),處理相應(yīng)電源事件,執(zhí)行針對特定應(yīng)用制定的管理策略?,F(xiàn)有的Linux ACPI和APM的后臺駐留進程,可以供嵌入式系統(tǒng)實現(xiàn)參考。商業(yè)的嵌入式linux 公司MontaVista 在其Moblinux 4.0以后的版本也提供一個用戶態(tài)的電源管理策略和界面。
嵌入式操作系統(tǒng)電源管理實現(xiàn)比較
嵌入式操作系統(tǒng)的電源管理功能實現(xiàn)結(jié)構(gòu)中,主要可以分為核心層、接口層、應(yīng)用策略管理層。核心層需要提供一個體系結(jié)構(gòu)無關(guān)的電源管理框架,感知系統(tǒng)負(fù)載,進行系統(tǒng)電源狀態(tài)管理。核心層還需要一個體系結(jié)構(gòu)相關(guān)層,提供硬件相關(guān)的電源狀態(tài)管理,例如進行電壓/頻率調(diào)節(jié)及相應(yīng)的約束管理。核心層還需要提供一個用戶編程接口,用戶層通過編程來利用系統(tǒng)提供的電源管理機制。并且根據(jù)不同的應(yīng)用需求編制智能化的管理策略。
在電源管理功能上大致可以分為(1)系統(tǒng)級電源管理,(2)動態(tài)電源管理,(3)設(shè)備電源管理等三類。操作系統(tǒng)檢查任務(wù)負(fù)載情況,如果沒有需要運行的任務(wù),則一般進入空閑等節(jié)能狀態(tài),等待喚醒??梢栽诳臻e一段時間后進入深度睡眠,掛起到RAM中或者硬盤上。在運行任務(wù)期間,操作系統(tǒng)還可以利用硬件提供的電源管理功能動態(tài)調(diào)節(jié)芯片運行電壓和頻率,對系統(tǒng)進行更加細(xì)致的電源管理。操作系統(tǒng)還應(yīng)該能夠管理閑置的設(shè)備,關(guān)閉設(shè)備并提供恢復(fù)手段。
上面我們分析的三種典型的嵌入式操作系統(tǒng)在電源管理方面是各有特色;TinyOS 簡練小巧有基本的內(nèi)核態(tài)和系統(tǒng)級的電源管理功能,但是相對比較簡單;WindowsCE電源管理模塊結(jié)構(gòu)清楚,特別有提供了應(yīng)用程序的接口,但是到目前看到的為止Windows CE/Mobile 開放給用戶的電源管理功能還待提升;Linux 是開源代碼,具有豐富的硬件電源管理支持,策略和動態(tài)的電源管理功能,但是相當(dāng)實現(xiàn)的零散和分散,應(yīng)用軟件的接口不清晰和標(biāo)準(zhǔn),需要用戶作的工作比較多。
總結(jié)和展望
消費類電子如近年流行的智能手機、GPS、移動電視都迫切需要高效的電源管理,傳感網(wǎng)節(jié)點需要電源管理,以便大規(guī)模部署,全球變暖等國際性的問題也對電子產(chǎn)業(yè)節(jié)能和環(huán)保提出了更高的要求?,F(xiàn)有的能源管理技術(shù)中還有許多問題有待于研究和解決,例如,(1)設(shè)計更加節(jié)能的芯片,減少系統(tǒng)的靜態(tài)功耗,半導(dǎo)體制造工藝的改進,在芯片級別進行更好性能監(jiān)測,通過設(shè)計優(yōu)良的負(fù)載預(yù)測算法,在系統(tǒng)運行中對能耗級別進行更加精細(xì)調(diào)節(jié)。(2)在系統(tǒng)軟件的設(shè)計上需要規(guī)范定義一個適合應(yīng)用體系的框架結(jié)構(gòu),比如Intel 發(fā)起的PPM(power police mangment) 和APM(application power management)就是一個基于Linux 的開源項目,它推動著一個系統(tǒng)級和應(yīng)用相關(guān)的電源管理軟件系統(tǒng)。(3)在網(wǎng)絡(luò)化的系統(tǒng)中,如何進行網(wǎng)絡(luò)化能耗管理,在通訊過程中達到能耗最小化,例如研究能耗感知的路由算法,選擇一個最節(jié)能路徑,避免不必要的喚醒與睡眠。(4)電源管理的QoS,一個旨在更好的管理硬件系統(tǒng),以達到性能和功耗平衡的系統(tǒng)。比如CPU的空閑管理,能耗高的Wi-Fi和其他網(wǎng)絡(luò)設(shè)備管理等。(5)電源管理的測試和分析工具??傊?,電源管理技術(shù)是一個結(jié)合微電子、集成電路、嵌入式系統(tǒng)和軟件的綜合學(xué)科,是一個正在快速發(fā)展的研究課題。它對電子產(chǎn)品的設(shè)計具有關(guān)鍵性影響,一個電源管理設(shè)計的好產(chǎn)品可以幫助產(chǎn)品在市場競爭中脫穎而出,克敵制勝。
參考文獻:
1. J. cott Gardner,ARM Cortex-M3 挑戰(zhàn)8位微控制器經(jīng)濟,Information Quarterly,Number 6, Spring 2007
2. 趙永超,Cortex-M3處理器在超低功耗應(yīng)用的實現(xiàn)策略,ARM Technical Symposiums, 2007
3. ARM Limited. ARM1176JZF Development Technical Reference
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)linux相關(guān)文章:linux教程
評論