新聞中心

ARM9 MMU映射問題三

作者: 時(shí)間:2016-11-28 來源:網(wǎng)絡(luò) 收藏
對“MMU映射地址一”里面的程序

本文引用地址:http://butianyuan.cn/article/201611/322697.htm

unsigned long *mmu_tlb_base = (unsigned long *)0x30000000;

virtuladdr = 0xA0000000;
physicaladdr = 0x56000000;

*(mmu_tlb_base + (virtuladdr >> 20)) = (physicaladdr & 0xFFF00000) |

MMU_SECDESC;
我自己理解為:virtuladdr 為虛擬空間各段基地址,virtuladdr >> 20為段描述符的各段的位置,即第幾個(gè)段,(physicaladdr & 0xFFF00000)為物理空間各段的位置,也即第幾個(gè)段,則上面程序意思為把物理空間各段基地址放進(jìn)虛擬空間的各段基地址,即索引。。。。

但是有個(gè)問題,跟0x30000000有什么關(guān)系呢?

因?yàn)樯厦娴某绦蚴且岩脖矸旁赟DRAM里,并且是從0x30000000處開始放起;第二就是為什么只有virtuladdr>>20,而沒有完整的virtual地址?因?yàn)榈刂肥?M對齊,即后20位全為零,所以只看高12位就行,所以只有virtuladdr>>20也能起點(diǎn)作用;

那么我有個(gè)問題,就是把也表放在那了,那它是什么時(shí)候去用他們呢,怎么用的他們呢,好像跟前兩篇博客講的不太一樣?

哦,一樣,因?yàn)榻ⅲㄒ患?jí))頁表(地址在0x30000000)后,首先要告訴MMU頁表位于0x30000000處;

第二,當(dāng)CPU發(fā)出一個(gè)虛擬地址時(shí),要被MMU分成兩部分,第一部分就是段基址,第二部分是地址偏移量,然后MMU去頁表地址找頁表,然后自動(dòng)通過一系列轉(zhuǎn)換規(guī)則,來找到對應(yīng)物理地址。



關(guān)鍵詞: ARM9MMU映

評論


技術(shù)專區(qū)

關(guān)閉