新聞中心

EEPW首頁 > 消費電子 > 設(shè)計應(yīng)用 > Linux下Cold Fire 片內(nèi)SRAM的應(yīng)用程序優(yōu)化設(shè)計

Linux下Cold Fire 片內(nèi)SRAM的應(yīng)用程序優(yōu)化設(shè)計

作者: 時間:2009-12-14 來源:網(wǎng)絡(luò) 收藏

3.3 配置實時數(shù)據(jù)和函數(shù)到中執(zhí)行
把用戶空間的實時數(shù)據(jù)和函數(shù)放置到中執(zhí)行,由于處理器可以直接從中存取數(shù)據(jù)和指令,減少了處理器存取數(shù)據(jù)和指令的周期,提高了程序的執(zhí)行效率。首先,放置實時數(shù)據(jù)到處理器片內(nèi)SRAM中。通過S_malloc和S_free函數(shù)來實現(xiàn):S_malloc用來申請?zhí)幚砥鲀?nèi)存空間,S_free用來對這一申請的空間進行釋放。為了靈活使用定義的S_malloc和S_free函數(shù),需要定義一個結(jié)構(gòu)體和地址指針:


然后,通過動態(tài)內(nèi)存分配方式可以把MP3解碼程序中的實時數(shù)據(jù)放入處理器內(nèi)存中執(zhí)行。加載函數(shù)到SRAM中與加載實時數(shù)據(jù)不同,需要通過指針和枚舉變量來實現(xiàn)。首先通過一個宏定義設(shè)置每個函數(shù)大小為4 KB,并使用枚舉變量為函數(shù)分配處理器片內(nèi)SRAM執(zhí)行的起始地址。

SRAMFUNC2=SRAM_BIG_FUNC1+BIG_FUNC_SIZE,…};
在定義完函數(shù)運行時加載的存儲地址之后,把MP3解碼程序中的MPEGSUB_synthesis和imdct_1等函數(shù)通過字符串拷貝的方式復(fù)制到處理器片內(nèi)SRAM中執(zhí)行,經(jīng)過編譯、鏈接這些函數(shù)在執(zhí)行時將會加載到相應(yīng)的SRAM單元塊中。這樣就減少了處理器執(zhí)行解碼函數(shù)所需的時間,提高了程序的執(zhí)行效率。


4 性能測試與分析
為了驗證基于處理器片內(nèi)SRAM的方案,我們在MCF5329EVB開發(fā)板上對經(jīng)該方案過的MP3解碼器進行了驗證和測試。
首先,進行功能測試,應(yīng)用MPEG組織推薦的測試碼流(128 kb/s,44.1 kHz)。選用一段test.mp3,分別用標準浮點解碼器和本文解碼器進行本地解碼測試,并對其解碼波形進行比較分析。從圖4的波形比較可以看到,經(jīng)過本方案的解碼器解碼波形與標準浮點解碼器基本無差別。經(jīng)人耳測試,無法辨別出兩者解碼輸出的差別。所以,從功能上講本文設(shè)計的基于片內(nèi)SRAM的優(yōu)化方案是可行的。

其次,進行性能測試。在測試平臺上分別對優(yōu)化前后解碼器的MIPS消耗數(shù)和空間消耗量進行比較分析,如表2所列。

優(yōu)化前,解碼器MIPS消耗數(shù)為68 MIPS@240MHz;優(yōu)化后,解碼器MIPS消耗數(shù)為39.2 MIPS@240 MHz。在硬件條件允許的情況下,消耗的內(nèi)存雖然有一定的增加,但是經(jīng)過本文方案優(yōu)化后,解碼效率得到了很大的提高。

結(jié) 語
本文提出了在嵌入式操作系統(tǒng)下基于處理器片內(nèi)SRAM的優(yōu)化設(shè)計方案。以MP3解碼器為例,通過從配置驅(qū)動程序、實時數(shù)據(jù)和函數(shù)到處理器片內(nèi)SRAM中執(zhí)行來對解碼器進行優(yōu)化設(shè)計,并在5329開發(fā)平臺上成功實現(xiàn)該方案。優(yōu)化后的MP3播放器不僅解碼效率高,而且音質(zhì)好,完全可以在中低端處理器上實現(xiàn)實時播放,使低性能CPU處理復(fù)雜成為可能。該方案有效地提高了應(yīng)用程序的執(zhí)行效率,降低了功耗,對嵌入式應(yīng)用產(chǎn)品開發(fā)有著重要參考價值。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

上一頁 1 2 3 下一頁

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉