ARM7在嵌入式應(yīng)用中啟動程序技術(shù)難點分析
技術(shù)難點分析 ⑴.mmu的使用 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)生頁面錯誤中斷。 ①使用dram作為大容量存儲器時,如果dram的行列是非平方的,會導(dǎo)致該dram的物理地址不連續(xù),這將給程序的編寫調(diào)試造成極大不便,而適當(dāng)配置mmu可將其轉(zhuǎn)換成虛擬地址連續(xù)的空間。 ②arm內(nèi)核的中斷向量表要求放在0地址, 對于rom在0地址的情況,無法調(diào)試中斷服務(wù)程序,所以在調(diào)試階段有必要將可讀寫的存儲器空間映射到0地址。 ③系統(tǒng)的某些地址段是不允許被訪問的,否則會產(chǎn)生不可預(yù)料的后果,為了避免這類錯誤,可以通過mmu匹配表的設(shè)置將這些地址段設(shè)為用戶不可存取類型。 啟動程序中生成的匹配表中包含地址映射,存儲頁大小(1m,64k,或4k)以及是否允許存取等信息。 例如:目標(biāo)板上的16兆dram的物理地址區(qū)間為0xc000,0000~0xc07f,ffff;0xc100,0000~0xc17f,ffff;16兆rom的虛擬地址區(qū)間為:0x0000,0000~0x00ff,ffff。匹配表配置如下: 可以看到左邊是連續(xù)的虛擬地址空間,右邊是不連續(xù)的物理地址空間,而且將dram映射到了0地址區(qū)間。 mmu通過虛擬地址和頁面表位置信息,按照轉(zhuǎn)換邏輯獲得對應(yīng)物理地址,輸出到地址總線上。 應(yīng)注意到的是使能mmu后,程序繼續(xù)運行,但是對于程序員來說程序計數(shù)器的指針已經(jīng)改變,指向了rom所對應(yīng)的虛擬地址。 ⑵目標(biāo)文件的分布裝載分析 首先創(chuàng)建一個文本文件,稱為分布裝載描述文件。它為應(yīng)用程序的各部分指定裝載區(qū)間和執(zhí)行區(qū)間。 舉例如下: flash 0x01000000 0x011fffff ;2m flash { flash 0x01000000 { boot.o(boot,+first) * (+ro) } dram 0x00000000 { vector.0(vector,+first) int_handler.o (+ro) * (+rw,+zi) } } 在arm鏈接器的命令行里加入“-scov desc-ription-file –scf”或“-scatter desc-ription-file”,編譯鏈接后,將產(chǎn)生一個分布裝載文件。 鏈接器同時產(chǎn)生一組符號,給出每個分布描述文件中命名的區(qū)間的長度,裝載地址和執(zhí)行地址。由于鏈接器和c庫都沒有將代碼從它的裝載區(qū)間拷貝到執(zhí)行區(qū)間,或創(chuàng)建一個零初始化區(qū)域的功能,所以要由應(yīng)用程序員利用這組符號產(chǎn)生的信息完成這項工作,這是在呼叫c程序之前必須完成的,舉例如下: ldr r0, = |load$dram$base| ldr r1, = |image$dram$base| cmp r0, r1 ; 檢查裝載地址和執(zhí)行地址是否相同 beq do_zi_init ; 相同,則不拷貝該區(qū)間,初始化零數(shù)據(jù)區(qū) mov r2, r1 ; 不相同,將裝載區(qū)拷貝到執(zhí)行區(qū) ldr r4, = |image$dram$length| add r2, r2, r4 bl copy do_zi_init ldr r1, = |image$dram$zi$base| mov r2, r1 ldr r4, = |image$dram$zi$length| add r2, r2, r4 mov r3, #0 bl zi_init ; 調(diào)用零初始化子程序 結(jié)束語: 本文介紹的啟動程序已經(jīng)在以cirrus logic公司的ep7211和ateml公司的at91m40400開發(fā)的系統(tǒng)上運行并測試通過。今后可以在這一基礎(chǔ)上添加串行通信模塊和flash操作模塊,開發(fā)系統(tǒng)監(jiān)控程序,從而實現(xiàn)應(yīng)用程序的在線升級。 |