技術難點分析
⑴.mmu的使用
mmu是存儲器管理單元的縮寫,是用來管理虛擬內存系統的器件。mmu通常是cpu的一部分,本身有少量存儲空間存放從虛擬地址到物理地址的匹配表。此表稱作tlb(轉換旁置緩沖區)。所有數據請求都送往mmu,由mmu決定數據是在ram內還是在大容量存儲器設備內。如果數據不在存儲空間內,mmu將產生頁面錯誤中斷。
mmu的兩個主要功能是:
將虛地址轉換成物理地址。
控制存儲器存取允許。mmu關掉時,虛地址直接輸出到物理地址總線。
在實踐中,使用mmu解決了如下幾個問題:
①使用dram作為大容量存儲器時,如果dram的行列是非平方的,會導致該dram的物理地址不連續,這將給程序的編寫調試造成極大不便,而適當配置mmu可將其轉換成虛擬地址連續的空間。
②arm內核的中斷向量表要求放在0地址, 對于rom在0地址的情況,無法調試中斷服務程序,所以在調試階段有必要將可讀寫的存儲器空間映射到0地址。
③系統的某些地址段是不允許被訪問的,否則會產生不可預料的后果,為了避免這類錯誤,可以通過mmu匹配表的設置將這些地址段設為用戶不可存取類型。
啟動程序中生成的匹配表中包含地址映射,存儲頁大小(1m,64k,或4k)以及是否允許存取等信息。
例如:目標板上的16兆dram的物理地址區間為0xc000,0000~0xc07f,ffff;0xc100,0000~0xc17f,ffff;16兆rom的虛擬地址區間為:0x0000,0000~0x00ff,ffff。匹配表配置如下:
可以看到左邊是連續的虛擬地址空間,右邊是不連續的物理地址空間,而且將dram映射到了0地址區間。 mmu通過虛擬地址和頁面表位置信息,按照轉換邏輯獲得對應物理地址,輸出到地址總線上。
應注意到的是使能mmu后,程序繼續運行,但是對于程序員來說程序計數器的指針已經改變,指向了rom所對應的虛擬地址。
⑵目標文件的分布裝載分析
首先創建一個文本文件,稱為分布裝載描述文件。它為應用程序的各部分裝載區間和執行區間。
舉例如下:
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”,編譯鏈接后,將產生一個分布裝載文件。
鏈接器同時產生一組符號,給出每個分布描述文件中命名的區間的長度,裝載地址和執行地址。由于鏈接器和c庫都沒有將代碼從它的裝載區間拷貝到執行區間,或創建一個零初始化區域的功能,所以要由應用程序員利用這組符號產生的信息完成這項工作,這是在呼叫c程序之前必須完成的,舉例如下:
ldr r0, = |load$$dram$$base|
ldr r1, = |image$$dram$$base|
cmp r0, r1 ; 檢查裝載地址和執行地址是否相同
beq do_zi_init ; 相同,則不拷貝該區間,初始化零數據區
mov r2, r1 ; 不相同,將裝載區拷貝到執行區
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 ; 調用零初始化子程序
結束語:
本文介紹的啟動程序已經在以cirrus logic公司的ep7211和ateml公司的at91m40400開發的系統上運行并測試通過。今后可以在這一基礎上添加串行通信模塊和flash操作模塊,開發系統監控程序,從而實現應用程序的在線升級。
下一篇:ARM硬件設計筆記
免責聲明
- 凡本網注明"來源:智能制造網"的所有作品,版權均屬于智能制造網,轉載請必須注明智能制造網,http://www.xashilian.com。違反者本網將追究相關法律責任。
- 企業發布的公司新聞、技術文章、資料下載等內容,如涉及侵權、違規遭投訴的,一律由發布企業自行承擔責任,本網有權刪除內容并追溯責任。
- 本網轉載并注明自其它來源的作品,目的在于傳遞更多信息,并不代表本網贊同其觀點或證實其內容的真實性,不承擔此類作品侵權行為的直接責任及連帶責任。其他媒體、網站或個人從本網轉載時,必須保留本網注明的作品來源,并自負版權等法律責任。
- 如涉及作品內容、版權等問題,請在作品發表之日起一周內與本網聯系,否則視為放棄相關權利。
2025長三角國際智能儀表/線纜產業博覽會
展會城市:滁州市展會時間:2025-11-11