<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          ARM9 MMU映射問題三

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

          本文引用地址:http://www.ex-cimer.com/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對(duì)齊,即后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ī)則,來找到對(duì)應(yīng)物理地址。



          關(guān)鍵詞: ARM9MMU映

          評(píng)論


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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();