ARM中MMU的作用
生活随笔
收集整理的這篇文章主要介紹了
ARM中MMU的作用
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
?
| ⑴.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)生頁面錯誤中斷。 MMU的兩個主要功能是: 1.將虛地址轉(zhuǎn)換成物理地址。 2.控制存儲器存取允許。MMU關(guān)掉時,虛地址直接輸出到物理地址總線。 在實踐中,使用MMU解決了如下幾個問題: ①使用DRAM作為大容量存儲器時,如果DRAM的物理地址不連續(xù),這將給程序的編寫調(diào)試造成極大不便,而適當配置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)以及是否允許存取等信息。 例如:目標板上的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)的虛擬地址。 |
總結(jié)
以上是生活随笔為你收集整理的ARM中MMU的作用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 嵌入式Linux之我行——ARM MMU
- 下一篇: ARM的CACHE原理(转)