ARM9 MMU映射問(wèn)題三
*(mmu_tlb_base + (virtuladdr >> 20)) = (physicaladdr & 0xFFF00000) |
我自己理解為:
但是有個(gè)問(wèn)題,跟0x30000000有什么關(guān)系呢?
因?yàn)樯厦娴某绦蚴且岩脖矸旁赟DRAM里,并且是從0x30000000處開始放起;第二就是為什么只有virtuladdr>>20,而沒有完整的virtual地址?因?yàn)榈刂肥?M對(duì)齊,即后20位全為零,所以只看高12位就行,所以只有virtuladdr>>20也能起點(diǎn)作用;
那么我有個(gè)問(wèn)題,就是把也表放在那了,那它是什么時(shí)候去用他們呢,怎么用的他們呢,好像跟前兩篇博客講的不太一樣?
哦,一樣,因?yàn)榻ⅲㄒ患?jí))頁(yè)表(地址在0x30000000)后,首先要告訴MMU頁(yè)表位于0x30000000處;
第二,當(dāng)CPU發(fā)出一個(gè)虛擬地址時(shí),要被MMU分成兩部分,第一部分就是段基址,第二部分是地址偏移量,然后MMU去頁(yè)表地址找頁(yè)表,然后自動(dòng)通過(guò)一系列轉(zhuǎn)換規(guī)則,來(lái)找到對(duì)應(yīng)物理地址。
評(píng)論