當前位置:首頁 > 嵌入式 > 嵌入式教程
[導讀]高效率嵌入式程序開發(fā)技巧

摘  要:嵌入式系統(tǒng)對應(yīng)用軟件的質(zhì)量要求很高,在嵌入式開發(fā)中須注意對代碼進行優(yōu)化,盡可能地提高代碼效率。雖然C編譯器都提供了一定程度的代碼優(yōu)化,但大部分由編譯器執(zhí)行的優(yōu)化技術(shù)僅涉及執(zhí)行速度和代碼大小的平衡,不可能使程序既快又小,因而必須在編寫程序時采取必要的措施。本文針對高效率嵌入式程序開發(fā)提供了一些編程技巧,對實際系統(tǒng)開發(fā)具有重要作用。
關(guān)鍵詞:編譯器; 程序開發(fā); 代碼優(yōu)化

引言
    在多媒體、通信等計算復雜度高的應(yīng)用中,為了滿足制造費用、功耗、性能以及實時性等諸多限制條件的要求,嵌入式系統(tǒng)程序往往需要特殊設(shè)計。這使得設(shè)計師在設(shè)計面向特定應(yīng)用的嵌入式軟件時,需要有一套切實可行的編程準則。而在實際程序設(shè)計中,工程師尤其需要考慮對變量的使用和循環(huán)程序的處理。

變量使用
    在進行實際程序開發(fā)時,變量的使用至關(guān)重要,其中使用全局變量比向函數(shù)傳遞參數(shù)更加有效,這樣免去了函數(shù)調(diào)用時參數(shù)入棧和出棧的需要。當然,使用全局變量會對程序有一些副作用。變量定義的次序會導致最終映像中數(shù)據(jù)布局的不同,如圖1所示。

740)this.width=740" border="0" />
                     圖1 變量映像次序混亂狀況

    由此可見,在聲明變量時,需要考慮怎樣最佳地控制存儲器布局。最好的方法是在編程的時候,把所有相同類型的變量放在一起定義。

    通常,工程師設(shè)法使用short或char來定義變量以節(jié)省存儲器空間。在函數(shù)的局部變量數(shù)目有限的情況下,編譯器會把局部變量分配給內(nèi)部寄存器,每個變量占用一個寄存器。在這種情況下,使用short和char型變量不但不會節(jié)省空間,反而會帶來其它的副作用。如圖2所示:假定a是任意可能的寄存器,存儲函數(shù)的局部變量。同樣完成加1的操作,32位的int型變量最快,只用一條加法指令。而8位和16位變量,完成加法操作后,還需要在32位的寄存器中進行符號擴展。其中,帶符號的變量,要用邏輯左移和算術(shù)右移兩條指令才能完成符號擴展;無符號的變量,要使用一條邏輯與指令對符號位進行清零。所以,使用32位的int或unsigned int局部變量最有效。某些情況下,函數(shù)從外部存儲器讀入局部變量進行計算,這時候,需要把不是32位的變量轉(zhuǎn)換成32位。至于把8位或16位變量擴展成32位后,隱藏了原來可能溢出異常這個問題,需要進一步仔細考慮。

740)this.width=740" border="0" />
         圖2 不同類型局部變量的加法程序

    在程序中,經(jīng)常會使用switch case語句,每一個由機器語言實現(xiàn)的測試和跳轉(zhuǎn)僅僅是為了決定下一步要做什么,就浪費了處理器時間。為了提高速度,可以把具體的情況按照它們發(fā)生的相對頻率排序。即把最可能發(fā)生的情況放在第一,發(fā)生概率小的情況放在最后,這樣會減少代碼平均執(zhí)行時間。[!--empirenews.page--]

    通常,工程師總是竭力避免使用冗余變量,以精簡程序。一般情況下這樣做是正確的,但是也有例外,如下所示:
int f(void);
int g(void);             
 file://f()和g()不訪問全局變量errs
int errs;            file://全局變量
void test1(void)
{ errs += f();
                errs += g();
}
void test2(void)
{ int localerrs = errs;  
// 定義冗余的局部變量
     localerrs += f();
     localerrs += g();
     errs = localerrs;
}
    在第一種情況test1()里,每次訪問全局變量errs時都要先從相應(yīng)的存儲器下載到寄存器里,經(jīng)f()或g()函數(shù)調(diào)用后再存儲回原來的存儲器里面。在該例子中,一共要進行兩次這樣的下載/存儲操作。而在第二種情況test2()里,局部變量localerrs被分配以寄存器,這樣一來,整個函數(shù)就只需要一次下載/存儲全局變量存儲器了。盡量節(jié)省存儲器訪問的次數(shù),對于提高系統(tǒng)性能非常有用。

循環(huán)程序的處理
    計數(shù)循環(huán)是程序中常用的流程控制結(jié)構(gòu)。在C中,類似下面的for循環(huán)比比皆是:
    for(loop=1;loop<=limit;loop++)

    這種累加計數(shù)的方法符合一般的自然思維習慣,所以比下面的遞減計數(shù)方法使用更多:
    for(loop<=limit;loop!=0; loop--)
    這兩者在邏輯上并沒有效率差異,但是映射到具體的體系結(jié)構(gòu)中,就產(chǎn)生了很大的不同。

    累加法比遞減法多用了一條指令,當循環(huán)次數(shù)比較多的時候,這兩段代碼就會在性能上產(chǎn)生明顯的差異。分析其本質(zhì)原因,在于當進行一個非零常數(shù)比較時,必須用專門的CMP指令來執(zhí)行;而當一個變量與零進行比較時,ARM指令可以直接利用條件執(zhí)行的特性(NE)來進行判斷。很多時候循環(huán)展開由編譯器自動完成,不過應(yīng)注意對中間變量或結(jié)果被更改的循環(huán),編譯程序往往拒絕展開,這時候就需要工程師自己來做展開工作了。

    尤其值得注意的是,在有內(nèi)部指令cache的CPU上(如ARM946ES芯片),因為循環(huán)展開的代碼很大,往往會出現(xiàn)高速緩沖存儲器溢出。這時展開的代碼會頻繁地在CPU的高速緩沖存儲器和內(nèi)存之間來回調(diào)用,又因為高速緩沖存儲器速度很高,所以此時循環(huán)展開反而會變慢。同時,循環(huán)展開會影響矢量運算優(yōu)化。

    ARM處理器核對NZ(零比較轉(zhuǎn)移)有特別的指令處理,速度非???,如果你的循環(huán)對方向不敏感,可以由大向小循環(huán)。需要注意的是,如果指針操作使用了i值,這種方法可能引起指針索引超界的嚴重錯誤(i = MAX+1)。當然你可以通過對i做加減運算來糾正,但是如果這樣就沒有提高效率的作用了。

結(jié)語
    本文對高效率嵌入式ARM程序開發(fā)總結(jié)了一些編程技巧。在實際的嵌入式系統(tǒng)開發(fā)中,可以大大的提高系統(tǒng)的性能,特別是在多媒體和通信等復雜度高的應(yīng)用中,對程序設(shè)計具有指導意義。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉