a一级爱做片免费观看欧美,久久国产一区二区,日本一二三区免费,久草视频手机在线观看

新聞中心

EEPW首頁 > 電源與新能源 > 設計應用 > 在μC/OS—II上實現動態電壓調節技術

在μC/OS—II上實現動態電壓調節技術

作者: 時間:2009-05-13 來源:網絡 收藏

  引 言

  現代社會中,便攜式系統(如手機和個人媒體播放器)正在演變成綜合性多媒體和通信系統。新的應用程序,如游戲、數字電視、高速Internet,已經成為終端用戶產品中的一項普通功能。然而,復雜的功能需要功能強大的處理器,如智能手機中已集成了模擬基帶、數字基帶、圖像處理器和CPU等多個分處理器,但這些分處理器并不是任何時刻都是滿負載運轉的,它們在很多時候都處于閑置狀態。因此,對于依靠電池供電的便攜式設備,如何根據系統的工作狀態調整各個處理器的功耗水平從而節省電能便成了一個普遍關注的問題。

  μC/OS—II作為一個源碼公開的嵌入式實時操作系統,可以支持64個任務,同時支持信號量、消息隊列、郵箱等多種常用的進程間通信方式。該操作系統用ANSI C語言書寫,程序可讀性強,性好,可裁減,并已在通信、電子、自動化等領域的嵌入式設備中獲得了廣泛的應用,但是它的內核并不支持(Dynamic Voltage Scaling)管理。本文在遵循可、可裁減的前提下,對其進行了改進,使其可以支持動態的離散電壓管理,保證μC/OS—II在新要求下的應用,使嵌入式設備的電量能夠得到充分的使用。

  1 在μC/OS—II上應用的理論基礎

  1.1 應用的硬件基礎

  動態電壓調節技術(DVS)是這樣一種技術:在保證系統任務完成的情況下,使處理器運行在盡可能低的電壓上。它的基本思想是,當系統需要完成大量計算任務時,提高處理器的電壓以增加其處理速度;而當系統任務較少或處于空閑狀態時,降低處理器的電壓,這樣既可以保證系統任務的按時完成,同時又可降低處理器的能量消耗。該節能技術的理論依據來自于對處理器功耗的定義:

公式

  其中:E為處理器的功耗,V為處理器的電壓,fclk為處理器的頻率,lLcak為漏電流;α和C為常數,分別表示門電路的電能轉換效率和門電路在整個設備中所占的比例;tTask表示系統中任務的個數。根據式(1)可知,通過降低處理器的電壓和頻率,可以減少處理器對電能的消耗。由于在實際應用中,程序能夠直接控制的是處理器的頻率,處理器的電壓會根據處理器頻率的變化自動變化。一般來說,處理器的電壓會隨著頻率的降低而降低,因此,動態電壓技術實際上是對頻率的調整。本文中如不作特別聲明,調整頻率即意味調整電壓。

  1. 2 DVS應用的軟件基礎

  由于μC/OS—II是一個基于優先級的搶占式任務調度內核,為了保證低優先級任務能夠得到處理器的執行,本文假定系統中用戶定義的所有任務都遵循如下的結構:

程序

  假設系統里有兩個任務:一個任務的執行時間為0.5 s,周期為10 s;另一個任務的執行時間為1 s,周期為5 s。這兩個任務的調度過程如圖l所示,這時系統中存在大量的松弛時間。

兩個任務的調度過程

  如果在程序運行過程中降低處理器的頻率,處理器的運行電壓也會因此變低。當處理器的頻率變化為最高頻率的1/4時,其任務調度過程如圖2所示。

任務調度過程

  由圖2可以知道,當處理器的頻率變化為正常的1/4時,系統任務仍然可以正常運行。這時,處理器的電壓下降了,根據式(1),處理器的功耗也降低了。

  從上面的分析可以看出,正是由于μC/OS—II采用了基于優先級搶占的調度策略,每個任務執行一段時間之后,都會主動放棄CPU的使用,從而使低優先級的任務能夠得到執行。同時,由于任務放棄CPU進行延時操作,任務間會因此而產生松弛時間,而DVS功能就是利用這段松弛時問,降低處理器的執行速度而完成任務的。本文研究的重點就是改進μC/OS—II,使它能夠根據系統中任務運行產生的松弛時間的情況,自動設置處理器的頻率,降低電壓,從而降低處理器的功耗。

  2 DVS系統模型

  2.1 DVS任務調度模型

  由1.2可知,當系統中任務之間存在松弛時間的時候,降低處理器的頻率可以縮短任務之間的松弛時間,同時由于頻率下降導致電壓下降,進而可以減少處理器的能量開銷。然而,什么時候進行DVS的調度,處理器最低運行在哪個頻率上都需要進一步分析,為此,需要了解每個任務的相關信息。本文用一個五元組表示一個任務,τi=(Si,PTi,ETi,LETi,NPTi)。其中,Si表示第i個任務的狀態,是就緒還是阻塞;PTi表示第i個任務的執行周期;ETi表示第i個任務的執行時間,LETi表示第i個任務在當前周期內完成剩余指令所需要的時間;NPTi表示第i個任務距離下一個周期任務所需的時間。

  根據上述定義,系統處理器的利用率Uτ可以表示為:

公式

  當且僅當Uτ1時任務集可調度,任務間存在松弛時間。這是啟用DVS功能的前提。

  2.2 判斷是否需要進行DVS調度

  為了計算松弛時間存在時處理器最低可以運行在哪個頻率上,引入“變壓因子”這個概念。假設DVS模塊被調用時所有就緒任務需要的執行時間為TAllReady,距離下一個等待任務恢復的時間為TleastWaiting,那么定義變壓因子FlexibleRatio為:

公式

  當FlexibleRatio>1時,表示當前就緒的任務可以在下一個任務從等待中恢復之前執行完畢,這時可以適當降低CPU的電壓和頻率,減慢任務的執行速度;當FlexibleRatio1時,表示當前就緒的任務在下一個任務恢復之前都不能執行完畢,所以這個時候可以提高CPU的電壓和頻率,使當前就緒的任務盡快執行完畢,從而使下一個恢復的任務可以得到盡快的執行;當FlexibleRatio=1時,不需要調整電壓和頻率。

  2.3 計算可運行的最低頻率

  處理器的頻率廠是和完成任務需要的時間T成正比的。它們之間遵循如下關系:

公式

  假設當前處理器的運行頻率為fcur,完成已經就緒任務需要的時間為Tcur,使任務集可調度的最低頻率為fnew,以及在新的頻率下完成就緒任務的時間為Tnew,則它們有如下關系:

公式

  即在某一時刻,滿足系統任務可調度的情況下,處理器頻率最低可以運行在FlexibleRatio·fcur。

  3 DVS在μC/OS—II上的詳細實現

  3.1 DVS在μC/OS—II上實現的整體結構

  根據第2節的分析,一個完整的DVS模塊應包括兩大部分:一部分是更新DVS任務控制信息,另外一部分是可調度的最低頻率的計算。其中,第二個部分又可以分為兩個層次,即最低頻率的計算和頻率的硬件設置部分,這樣分層之后有助于改進后μC/OS—II的。DVS功能在μC/0S—II的實現總體結構如圖3所示,下面詳細描述各個部分的實現過程。


上一頁 1 2 下一頁

關鍵詞: μC/OS—II DVS 移植

評論


相關推薦

技術專區

關閉