《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 解決方案 > 微控制器的功耗調試:找出能量泄漏,降低嵌入式系統功耗

微控制器的功耗調試:找出能量泄漏,降低嵌入式系統功耗

2011-06-29

  功耗" title="功耗">功耗調試技術使軟件工程師得以了解嵌入式系統的軟件對系統功耗的影響。通過建立源代碼和功耗之間的聯系,使得測試和調整系統功耗成為可能,即所謂功耗調試。傳統上,降低功耗僅是硬件工程師的設計目標;然而在實際運行的系統中,功耗不僅取決于硬件的設計,而且還與硬件如何被使用有關,而后者則是由系統軟件來控制的。

<a class=

圖1:IAR Systems的C-SPY調試器" title="調試器">調試器能夠在不同的視圖中顯示靜態和動態的功耗數據。

  功耗調試技術基于對功耗進行采樣,并建立每個采樣數據與程序的指令序列(以及源代碼)之間的關聯。其中的難點之一在于實現高精度的采樣。理想情況下,對功耗的采樣頻率應該與系統時鐘相同,但系統中的電容性元件會降低此類測量的可靠性。從軟件工程師的角度來看,更感興趣的是功耗與源代碼以及程序運行期間的各種事件之間的聯系,而非個別的指令,因此所需的采樣分辨率將大大低于對每個指令進行采樣的頻率。

  對功耗的測量由調試工具完成。例如,IAR Embedded Workbench所支持的調試工具是IAR J-Link Ultra。它能夠測量芯片的供電電源經過一個串聯小電阻之后的壓降,見圖2。該壓降是使用差分放大器進行測量,并通過模數轉換器進行采樣的。 

IAR J-Link Ultra能夠測量芯片的供電電源經過一個串聯小電阻之后的壓降

圖2:IAR J-Link Ultra能夠測量芯片的供電電源經過一個串聯小電阻之后的壓降。

  要提高功耗調試的精確性,關鍵在于建立指令跟蹤與功耗采樣之間的良好關聯。最佳的關聯僅當能夠進行完全的指令跟蹤時才能實現,但其缺點在于并非所有芯片都能支持這一功能;即便支持,也通常需要特殊的調試工具。

  要在較低的精確性下達到較好的關聯度,可以使用一些現代片上調試架構所支持的PC采樣功能。該功能周期性地對PC進行采樣,并給出每個采樣的時間戳。與此同時,調試工具使用模數轉換器對芯片的功耗進行采樣。通過比對功耗采樣值和PC采樣值的時間戳,調試器就能夠在同一根時間軸上顯示功耗數據以及中斷紀錄、變量監控等圖形,并且將功耗數據與源代碼關聯起來,見圖3。 

PC和功耗采樣校正

圖3:PC和功耗采樣校正。

  一般來說,功耗優化與速度優化是非常相似的。一個任務運行得越快,低功耗模式持續的時間就能越長。因此,將處理器的空閑時間最大化可以降低系統的功耗。

  想要找出系統中不必要的能耗以及在何處能夠降低這些能耗是有難度的。通常它們并非源代碼中顯而易見地暴露出來的缺陷,而更多地存在于對硬件使用方式的調整之中。

  等待設備的狀態

  一個導致不必要能耗的常見錯誤是使用輪詢來等待某個外設狀態的改變。下面的例子中,代碼一直不中斷地運行,直到狀態變量變為預期的值。

  while (USBD_GetState() < USBD_STATE_CONFIGURED);

  while ((BASE_PMC->MC_SR & MC_MCKRDY) != PMC_MCKRDY);

  另一種類似的代碼是在for或while循環中實現軟件延時,例如:

   i = 10000; // SW Delay

  do i--;  

  while (i != 0);

  這段代碼使得CPU一直忙于執行除了計時之外沒有任何作用的指令。

  在上述這些情況中,可以通過改寫代碼來降低功耗。延時最好是通過硬件定時器來實現。CPU在設置好定時器中斷之后就可以進入低功耗模式直到被中斷喚醒。同樣,對外設狀態的輪詢若有可能也應該通過中斷來解決,或者使用定時器中斷從而使得CPU在兩次輪詢之間可以進入休眠。

  DMA" title="DMA">DMA vs polled I/O  

  傳統上,DMA被用于提高傳輸速度。在某些架構中,CPU即使在DMA傳輸過程中也可以進入休眠模式。功耗調試使得開發者能夠試驗并通過調試器看到與傳統由CPU驅動的傳輸方式相比,DMA技術所帶來的效果。  

  低功耗模式  

  很多嵌入式應用都把大多數時間花費在等待某些事件發生。如果處理器在空閑時仍然全速運行,電池的壽命將在幾乎未作任何事情的情況下被消耗。所以在很多應用中,處理器僅在總計很少的時間里才被激活。通過將處理器在空閑時間里置于低功耗模式,電池的壽命將得到數量級的延長。

  一個好的方式是使用RTOS和面向任務的設計。可以定義一個最低優先級,僅當沒有任何其他任務需要運行時才會被運行的任務。這個空閑任務將是實現功耗管理的理想場所。在實踐中,當空閑任務每次被激活時,都將處理器(或其部份)置于(可能的)多種低功耗模式之一。

  CPU頻率理論上,CMOS MCU的功耗可由以下公式得出: P = f x U^2 x k 上式中的f是時鐘頻率,U是供電電壓,k是數。功耗調試使得開發者能夠驗證功耗與時鐘頻率之間的關系。運行在50MHz且幾乎不休眠的系統,當運行在100MHz時將在休眠模式下消耗約50%的時間。調試器中的功耗數據使得開發者能夠檢驗所期望的行為,以及當如果存在與時鐘頻率的非線性關系時,選擇功耗最低的工作頻率。

 

  中斷處理   

  圖4顯示了一個事件驅動系統的功耗示意圖,其在t0時處于非激活模式,消耗的電流為I0。在t1時系統被激活且電流上升為I1,對應于系統在激活模式下且有一個外設被使用時的功耗。在t2時,程序的運行被一個更高優先級的中斷所掛起。已經被激活的外設沒有被關閉,雖然高優先級的線程中并未用到它們。更多的外設被新的線程所激活,導致電流在t2和t3之間升高為I2。在t3時,控制權重又回到低優先級的線程。

顯示了一個事件驅動系統的功耗示意圖

圖4:顯示了一個事件驅動系統的功耗示意圖。

  該系統的功能可以非常出色,并且能夠在運行速度和代碼尺寸兩方面進行優化。然而在功耗方面,還有更多的優化可以實現。圖中黃色的區域表示如果在t2和t3之間關閉不需要的外設,或者對調這兩個線程的優先級,所能夠節省的能量。

  使用功耗調試,能夠更容易地發現當中斷發生時功耗的額外上升,并將其標識為異常。

  查找有沖突的硬件初始化  

  為了避免輸入端浮動,在通常的設計中會將未使用的MCU I/O管腳接地。如果軟件錯誤地將某個接地管腳配置為輸出邏輯“1”,高達25mA的電流會流向該管腳。這種非期望的高電流在功耗采樣圖形上很容易觀測到;同時還可以通過觀察系統啟動過程中的圖形來查找相關的初始化錯誤代碼。

  模擬干擾也可能對功耗調試產生影響。模數混合電路板有其自身的特性。板級的布局和走線對于抑制模擬噪聲、保證對低電平模擬信號的精確采樣十分重要。良好的混合信號電路需要對硬件進行仔細的考量和認真的設計。

  總結

  功耗調試使得嵌入式系統的開發者能夠深入了解他們的應用,并發現程序的代碼對功耗有何影響。基于這些信息,可以通過調整和優化源代碼以最大限度地降低功耗。使用這種方法,工程師們能夠確保他們的設計已經盡可能地節省能量,而又不會對系統性能產生不利的影響。

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品视频一| 国产精品久久久免费| 在线中文字幕一区| 亚洲人成在线观看| 久久精品国产v日韩v亚洲| 亚洲自啪免费| 亚洲午夜精品在线| 99精品国产热久久91蜜凸| 亚洲人体大胆视频| 亚洲欧洲另类| 亚洲国产欧美一区二区三区丁香婷| 国产一区在线看| 韩国福利一区| 精品91久久久久| 尤物精品国产第一福利三区| 伊人久久成人| 亚洲国产精品久久久久婷婷884| 伊人久久婷婷| 亚洲高清123| 亚洲精品欧美激情| 亚洲免费观看高清在线观看| 亚洲卡通欧美制服中文| 99成人免费视频| 亚洲一二三级电影| 亚洲欧美日韩电影| 午夜欧美不卡精品aaaaa| 欧美一区二区三区四区在线观看| 午夜精品一区二区三区在线视| 亚洲综合社区| 欧美一级视频| 91久久久久久| 夜夜爽www精品| 亚洲免费影院| 久久久精品久久久久| 美国十次了思思久久精品导航| 欧美精品麻豆| 国产精品久久久久久av福利软件| 国产伦精品一区二区三区照片91 | 蜜桃伊人久久| 欧美精品福利| 国产精品日本一区二区| 国内成人在线| 亚洲乱码久久| 亚洲欧美综合| 亚洲精品中文字| 亚洲综合三区| 久久久噜噜噜久久久| 欧美成人蜜桃| 国产精品视频不卡| 在线成人性视频| 一区二区三区|亚洲午夜| 午夜精品久久久久久久久久久 | 一区二区三区高清在线观看| 亚洲欧美国产日韩天堂区| 久久久久久午夜| 欧美精品一区在线| 国产精品一区二区久久久久| 红桃视频亚洲| 一区二区三区精密机械公司 | 亚洲第一视频网站| 亚洲网友自拍| 久久久久久久综合| 欧美三区在线视频| 国产综合久久| 中文av一区二区| 亚洲日本无吗高清不卡| 亚洲欧美日韩精品久久奇米色影视| 久久精品国产一区二区电影 | 欧美在线啊v| 欧美人与禽猛交乱配视频| 国产伦精品一区二区三| 亚洲日本免费电影| 欧美一级理论性理论a| 在线午夜精品自拍| 久久夜色精品亚洲噜噜国产mv| 欧美日韩在线一区二区三区| 国内外成人免费激情在线视频网站| 亚洲精品亚洲人成人网| 亚洲综合二区| 一区二区三区成人| 榴莲视频成人在线观看| 国产老肥熟一区二区三区| 亚洲日本aⅴ片在线观看香蕉| 欧美影片第一页| 亚洲一区高清| 欧美日韩成人一区二区三区| 亚洲精品日韩在线观看| 亚洲三级观看| 久久伊人免费视频| 国产日韩欧美电影在线观看| 99这里只有久久精品视频| 亚洲欧洲在线一区| 久久久久国产一区二区三区| 国产精品狼人久久影院观看方式| 亚洲毛片在线观看.| 亚洲精品国产品国语在线app| 久久精品中文字幕一区| 国产精品男gay被猛男狂揉视频| 最新亚洲一区| 亚洲精品1234| 久久夜精品va视频免费观看| 国产精品夜夜夜| 中文欧美日韩| 一区二区三区欧美亚洲| 欧美国产国产综合| 亚洲第一级黄色片| 亚洲高清不卡在线| 久久久久久自在自线| 国产欧美精品久久| 亚洲欧美激情一区二区| 亚洲砖区区免费| 国产精品video| 9久草视频在线视频精品| 99亚洲一区二区| 欧美精品成人在线| 亚洲国产一区二区三区青草影视| 亚洲高清自拍| 久久久亚洲人| 激情综合激情| 亚洲黄一区二区三区| 老司机aⅴ在线精品导航| 激情亚洲网站| 亚洲欧洲在线一区| 欧美精品成人一区二区在线观看| 亚洲国产另类久久久精品极度| 亚洲国产一区二区视频| 美女久久一区| 亚洲片区在线| 这里只有精品在线播放| 欧美三日本三级少妇三2023| 99re66热这里只有精品3直播| 99精品国产99久久久久久福利| 欧美日本国产视频| 妖精成人www高清在线观看| 亚洲香蕉在线观看| 国产精品蜜臀在线观看| 亚洲一区在线免费| 校园激情久久| 国产一区在线看| 最新国产乱人伦偷精品免费网站| 欧美高清在线一区| 99re热这里只有精品视频| 亚洲欧美久久久久一区二区三区| 国产精品久久久久7777婷婷| 亚洲欧美日韩成人| 久久久久久久久蜜桃| 国产精品免费看久久久香蕉| 亚洲淫片在线视频| 亚洲性感激情| 国产午夜亚洲精品不卡| 欧美一级视频精品观看| 奶水喷射视频一区| 日韩一区二区精品| 欧美一区二区三区在线看| 国产自产在线视频一区| 亚洲人成免费| 国产精品成人v| 欧美影院一区| 欧美国产综合视频| 日韩网站免费观看| 亚洲第一级黄色片| 欧美精品在线视频观看| 在线亚洲国产精品网站| 久久九九热re6这里有精品| 在线观看av一区| 亚洲特级片在线| 国产日韩在线一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了| 欧美高清视频在线| 欧美一级久久| 国产精品揄拍500视频| 99精品视频免费观看视频| 亚洲精品1区2区| 欧美影片第一页| 国产自产v一区二区三区c| 亚洲日本va午夜在线影院| 久久精品日韩| 欧美日韩大片一区二区三区| 亚洲精品视频免费| 日韩午夜三级在线| 欧美激情视频一区二区三区在线播放| 国产精品乱子久久久久| 亚洲精品视频免费观看| 最新国产成人av网站网址麻豆| 午夜在线精品偷拍| 免费成人av在线看| 国产精品美女xx| 亚洲欧美国产va在线影院| 亚洲一二三区在线观看| 欧美精品激情blacked18| 国产欧美视频一区二区三区| 夜夜嗨av一区二区三区免费区| 亚洲一区二区动漫| 午夜亚洲精品| 亚洲欧美成人一区二区三区| 国产精品久久久久久久浪潮网站 | 亚洲国产一区二区a毛片| 免费亚洲电影| 在线精品国精品国产尤物884a| 一区二区三区视频观看|