基于ARM的嵌入式系統(tǒng)程序開發(fā)要點
2.堆棧的分配
在圖-3 中,橫坐標上還有一種情況,就是 16 位的存儲器寬度,但是堆??臻g是 32 位的。這種情況下無論 ARM 還是 Thumb,其性能表現(xiàn)都比單純的 16 位存儲器系統(tǒng)情況下要好。這是因為 ARM 和 Thumb 其指令集雖然分 32 位和 16位,但是堆棧全部是采用32 位的。因此在 16 位堆棧和 32 位堆棧的不同環(huán)境下,其性能當然都會相差很多。這種差別還跟具體的應用程序密切相關(guān),如果一個程
序堆棧的使用頻率相當高,則這種性能差異很大;反之則要小一些。
在基于 ARM 的系統(tǒng)中,堆棧不僅僅被用來進行諸如函數(shù)調(diào)用、中斷響應等時候的現(xiàn)場保護,還是程序局部變量和函數(shù)參數(shù)傳遞(如果大于4個)的存儲空間。所以出于系統(tǒng)整體性能考慮,要給堆棧分配相對訪問速度最快、數(shù)據(jù)寬度最大的存儲器空間。
一個嵌入式系統(tǒng)通常存在多種多樣的存儲器類型。設(shè)計的時候一定要先清楚每一種存儲器的訪問速度,地址分配和數(shù)據(jù)線寬度。然后根據(jù)不同程序和目標模塊對存儲器的不同要求進行合理分配,以期達到最佳配置狀態(tài)。
3.ROM 還是 RAM 在 0 地址處?
顯然當系統(tǒng)剛啟動的時候,0 地址處肯定是某種類型的 ROM,里面存儲了系統(tǒng)的啟動代碼。 但是很多靈活的系統(tǒng)設(shè)計中, 0 地址處的存儲器類型是可映射的。也就是說,可以通過軟件的方法,把別的存儲器(主要是快速的 RAM)分配以0 起始的地址。
這種做法的最主要目的之一是提高系統(tǒng)對中斷的反應速度。因為每一個中斷發(fā)生的時候,ARM 都需要從 0 地址處的中斷向量表開始其中斷響應流程,顯然把中斷向量表放在 RAM 里,比放在 ROM 里有更快的訪問速度。因此,如果系統(tǒng)提供了這一類的地址重映射功能,軟件設(shè)計者一定要加以利用。
下面是一個典型的經(jīng)過 0 地址重映射之后的存儲空間分布圖,注意盡可能把速度要求最高的部分放置在系統(tǒng)里面訪問速度最快、帶寬最寬的 RAM 里面。
圖-4 系統(tǒng)存儲器分布的實例
4.存儲器地址重映射(memory remap)
存儲器地址重映射是當前很多先進控制器所具有的功能。在上一節(jié)中已經(jīng)提到了 0 地址處存儲器重映射的例子,簡而言之,地址重映射就是可以通過軟件配置來改變一塊存儲器物理地址的一種機制或方法。
當一段程序?qū)\行自己的存儲器進行重映射的時候,需要特別注意保證程序執(zhí)行流程在重映射前后的承接關(guān)系。下面是一種典型的存儲器地址重映射情況:
圖-5 存儲器重映射舉例 1
系統(tǒng)上電后的缺省狀態(tài)是 0地址上放有 ROM,這塊 ROM 有兩個地址:從0起始和從0x10000 起始,里面存儲了初始化代碼。當進行地址 remap以后,從 0起始的地址被定向到了 RAM 上,ROM 則只保留有唯一的從 0x10000 起始的地址了。
如果存儲在 ROM 里的 Reset_Handler 一直在0 – 0x4000的地址上運行,則當執(zhí)行完remap以后,下面的指令將從RAM 里預取,必然會導致程序執(zhí)行流程的中斷。根據(jù)系統(tǒng)特點,可以用下面的辦法來解決這個問題:
(1) 上電后系統(tǒng)從 0 地址開始自動執(zhí)行,設(shè)計跳轉(zhuǎn)指令在 remap 發(fā)生前使 PC指針指向0x10000 開始的 ROM 地址中去,因為不同地址
指向的是同一塊ROM,所以程序能夠順利執(zhí)行。
(2) 這時候 0 - 0x4000的地址空間空閑, 不被程序引用, 執(zhí)行remap后把 RAM引進。因為程序一直在 0x10000 起始的 ROM 空間里
運行,remap 對運行流程沒有任何影響。
(3) 通過在 ROM 里運行的程序,對 RAM 進行相應的代碼和數(shù)據(jù)拷貝,完成應用程序運行的初始化。
評論