當(dāng)前位置:首頁 > 單片機 > 單片機
[導(dǎo)讀]S3C2440是三星公司基于ARM920T設(shè)計的一款處理器,在開發(fā)基于S3C2440的系統(tǒng)的過程中,如何讓系統(tǒng)快速穩(wěn)定地啟動是一個重要問題。嵌入式系統(tǒng)的資源有限,程序通常都是固化在 ROM 中運行。但在實際應(yīng)用中,為提高系統(tǒng)的

S3C2440是三星公司基于ARM920T設(shè)計的一款處理器,在開發(fā)基于S3C2440的系統(tǒng)的過程中,如何讓系統(tǒng)快速穩(wěn)定地啟動是一個重要問題。嵌入式系統(tǒng)的資源有限,程序通常都是固化在 ROM 中運行。但在實際應(yīng)用中,為提高系統(tǒng)的實時性,加快代碼的執(zhí)行速度,系統(tǒng)啟動后程序往往要被搬移到 RAM 中,因為 RAM 的存取速度要比 ROM 快得多,這樣大大提升系統(tǒng)的性能。啟動程序要完成的任務(wù)包括:硬件初始化,系統(tǒng)存儲系統(tǒng)的配置,復(fù)制二級中斷向量表。

啟動程序過程

系統(tǒng)硬件初始化
系統(tǒng)上電或復(fù)位后,程序從位于地址 0x0 的 Reset Exception Vector 處開始執(zhí)行,因此需要在這里放置 Bootloader 的第一條指令: b ResetHandler ,跳轉(zhuǎn)到標(biāo)號為 ResetHandler 處進行第一階段的硬件初始化,主要內(nèi)容為:關(guān)看門狗定時器,關(guān)中斷,初始化 PLL 和時鐘,初始化存儲器系統(tǒng)。執(zhí)行完以上程序后,系統(tǒng)進行堆棧和存儲器的初始化。系統(tǒng)堆棧初始化取決于用戶使用了哪些中斷,以及系統(tǒng)需要處理哪些錯誤類型。 一般情況下,管理者堆棧必須設(shè)置,如果使用了 IRQ 中斷,則 IRQ 堆棧也必須設(shè)置。如果系統(tǒng)使用了外設(shè),則需要設(shè)置相關(guān)的寄存器,以確定其刷新頻率、總線寬度等信息。

代碼段復(fù)制到 RAM 中運行
因為嵌入式系統(tǒng)的代碼通常都是固化在 ROM 或者 Flash 中,上電后開始運行。由于 ROM 和 Flash 的讀取速度相對較慢,這樣無疑會降低代碼的執(zhí)行速度和系統(tǒng)的運行效率。為此,需要把系統(tǒng)的代碼復(fù)制到 RAM 中運行。使用 SDT 鏈接器 ARMLink 產(chǎn)生的定位信息,把 RO 的有效代碼和數(shù)據(jù)段到 RAM 中。 ARMLink 將編譯后的程序鏈接成 ELF 文件。映像文件內(nèi)部共有三種輸出段: RO 段、 RW 段和 ZI 段。這三種輸出段分別包含了只讀代碼及包含在代碼段中的少量數(shù)據(jù)、可讀寫的數(shù)據(jù)、初始化為 0 的數(shù)據(jù), ARMLink 同時還產(chǎn)生了這三種輸出段的起始和終止定位信息: Image$$RO$$Base 、 Image$$RO$$Limit 、 Image$$RW$$Base 、 Image$$Limit 、 Image$$Linit 和 Image$$ZI$$Limit ??梢栽诔绦蛑惺褂眠@些定位信息。將 ROM 中的代碼和數(shù)據(jù)搬移到 RAM 中,具體程序如下。
LDR r0, =|Image$$RO$$Base| /*RO 段起始地址 */
LDR r1, =|Image$$RO$$Limit| /*RO 段結(jié)束地址 */
LDR r2, =|Image$$RW$$Base|
LDR r3, =|Image$$RW$$Limit|
/* 分別求出需要映像的代碼和數(shù)據(jù)的長度并累加,放到寄存器 R1 中 */
SUB r1, r1, r0
SUB r3, r3, r2
ADD r1, r1, r3
/* 將需要映象的代碼和數(shù)據(jù)復(fù)制到 RAM 中去 */
0 /* 標(biāo)示符 */
LDR r3, [r0], #4
STR r3, [r2], #4
SUBS r1, r1, #4
BNE %B0 /* 如果沒有復(fù)制完,跳轉(zhuǎn)到 0 標(biāo)示符處的匯編語句,繼續(xù)復(fù)制,參見 ARM 指令幫助手冊 */

建立二級中斷向量表
在 ARM 系統(tǒng)中,中斷向量表位于 0X0 開始的地址處,意味著無論運行什么樣的上層軟件,一旦發(fā)生中斷,程序就得到 Flash 存儲器中的中斷向量表里去,降低系統(tǒng)的運行效率。因此在 RAM 中建立自己的二級中斷向量表,當(dāng)中斷發(fā)生后,程序直接從 RAM 中取中斷向量進入中斷子程序。尤其是在中斷頻繁發(fā)生的系統(tǒng)里,這種方法可以大大提高系統(tǒng)的運行效率,具體的實現(xiàn)代碼如下。
b ResetHandler
b HandlerUndef /* 未定義模式句柄 */
b HandlerSWI /*SWI 中斷句柄 */
b HandlerPabort /*PAbort 中斷句柄 */
b HandlerDabort /*Dabort 中斷句柄 */
b. /* 保留 */
b HandlerIRQ /*IRQ 中斷句柄 */
b HandlerFIQ /*FIQ 中斷句柄 */
HandlerFIQ HANDLER HandleFIQ
HandlerIRQ HANDLER HandleIRQ
HandlerUndef HANDLER HandleUndef
HandlerSWI HANDLER HandleSWI
HandlerDabort HANDLER HandleDabort
HandlerPabort HANDLER HandlePabort
其中 HANDLER 是一個宏,用于查找中斷處理程序的入口地址。這些地址存放在由 HandleXXX 指向的表項中,該表定位在 RAM 高端,基地址為 _ISR_STARTADDRESS 。
^ _ISR_STARTADDRESS
HandleReset # 4
HandleUndef # 4
HandleSWI # 4
HandlePabort # 4
HandleDabort # 4
HandleReserved # 4
HandleIRQ # 4
HandleFIQ # 4

MMU 的應(yīng)用
MMU 是存儲器管理單元的縮寫,是用來管理虛擬內(nèi)存系統(tǒng)的器件。 MMU 通常是 CPU 的一部分,本身有少量存儲空間存放從虛擬地址到物理地址的匹配表,此表稱作 TLB( 轉(zhuǎn)換旁置緩沖區(qū) ) 。所有數(shù)據(jù)請求都送往 MMU ,由 MMU 決定數(shù)據(jù)是在 RAM 內(nèi)還是在大容量外部存儲器設(shè)備內(nèi)。如果數(shù)據(jù)不在存儲空間內(nèi), MMU 將產(chǎn)生頁面錯誤中斷。 MMU 存儲器系統(tǒng)的結(jié)構(gòu)允許對存儲器系統(tǒng)的精細(xì)控制,大部分的控制細(xì)節(jié)由存在存儲器中的轉(zhuǎn)換表提供。這些表的入口定義了從 1KB ~ 1MB 的各種存儲器區(qū)域的屬性。 MMU 完成的兩個主要功能是:將虛地址轉(zhuǎn)換成物理地址,控制存儲器存取允許。 MMU 關(guān)掉時,虛地址直接輸出到物理地址總線。
經(jīng)過以上的分析可以發(fā)現(xiàn),系統(tǒng)啟動程序主要是完成了硬件的初始化,以及克服 Flash 或 ROM 讀取速度慢的弱點,提高指令和數(shù)據(jù)的讀取速度,實現(xiàn)系統(tǒng)的高速運行,并且通過 MMU 的應(yīng)用,減少RAM 的使用,降低系統(tǒng)成本。


本站聲明: 本文章由作者或相關(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)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

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

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(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 半導(dǎo)體

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ù)學(xué)會聯(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)閉