ARM9 MMU映射問題三
*(mmu_tlb_base + (virtuladdr >> 20)) = (physicaladdr & 0xFFF00000) |
我自己理解為:
但是有個問題,跟0x30000000有什么關(guān)系呢?
因為上面的程序是要把也表放在SDRAM里,并且是從0x30000000處開始放起;第二就是為什么只有virtuladdr>>20,而沒有完整的virtual地址?因為地址是1M對齊,即后20位全為零,所以只看高12位就行,所以只有virtuladdr>>20也能起點作用;
那么我有個問題,就是把也表放在那了,那它是什么時候去用他們呢,怎么用的他們呢,好像跟前兩篇博客講的不太一樣?
哦,一樣,因為建立(一級)頁表(地址在0x30000000)后,首先要告訴MMU頁表位于0x30000000處;
第二,當CPU發(fā)出一個虛擬地址時,要被MMU分成兩部分,第一部分就是段基址,第二部分是地址偏移量,然后MMU去頁表地址找頁表,然后自動通過一系列轉(zhuǎn)換規(guī)則,來找到對應(yīng)物理地址。
評論