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

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM中MMU地址轉(zhuǎn)換理解

          ARM中MMU地址轉(zhuǎn)換理解

          作者: 時(shí)間:2016-11-09 來源:網(wǎng)絡(luò) 收藏
          MMU的作用就是負(fù)責(zé)虛擬地址(virtual address)轉(zhuǎn)化成物理地址(physical address)。 32位的CPU的虛擬地址空間達(dá)到4GB,在一級(jí)頁表中使用4096個(gè)描述符來表示這4GB的空間,每個(gè)描述符代表1M的虛擬地址,要么存儲(chǔ)了它的對(duì)應(yīng)物理地址的起始地址,要么存儲(chǔ)了下一級(jí)頁表的地址。使用MVA[31:20]來索引一級(jí)頁表(4096個(gè)描述符)

          由協(xié)處理器CP15中的寄存器C2(高18位,即[31:14]為轉(zhuǎn)換表基地址,低14位為0)為一級(jí)轉(zhuǎn)換表基地址,指向2^14=16KB整除的存儲(chǔ)器即16K對(duì)齊,這個(gè)存儲(chǔ)區(qū)稱為一級(jí)轉(zhuǎn)換表;MVA的高12位,即位[31:20]作為一級(jí)轉(zhuǎn)換表的地址索引,因此一級(jí)轉(zhuǎn)換表具有2^12=4096項(xiàng),每一項(xiàng)的地址為32位,最高的18位[31:14]為寄存器C2的高18位,中間12位為MVA的高12位[31:20],最低2位為0b00。每一項(xiàng)的內(nèi)容稱為一個(gè)描述符,在段(Section)下,一級(jí)描述符的高12位為,大小為1MB的段基地址,段內(nèi)地址(偏移地址)為MVA的低20位,即段內(nèi)每個(gè)存儲(chǔ)器的地址是這樣組成:高12位為一級(jí)描述符的高12位,低20位MVA的低20位。這樣,借助于寄存器C2和一級(jí)描述符,將一個(gè)MVA轉(zhuǎn)換成一個(gè)PA。(在這里一定要注意:MVA的高12位是用來索引4096個(gè)項(xiàng)的,然后使用項(xiàng)的內(nèi)容(即描述符)的高12位為段的高12位,類似于指針里面存放地址,4096項(xiàng)類似指針,描述符類似指針里面的內(nèi)容)

          本文引用地址:http://www.ex-cimer.com/article/201611/317859.htm

          虛擬地址(注意:是一個(gè)確定的地址,不是一個(gè)空間)被MMU分成2個(gè)部分,第一部分是4096頁號(hào)索引(descriptor index)即用選擇4096(2^12)個(gè)號(hào)中的某個(gè)頁號(hào),比喻description index為768,頁號(hào)768中保存的是物理地址的某個(gè)頁框的起始地址(0x300),第二部分則是相對(duì)于section base(0x300)為起始地址空間為1M的偏移量(offset)(如下圖)例如: 假設(shè)現(xiàn)在執(zhí)行指令MOV REG, 0x30100013,虛擬地址的二進(jìn)制碼為00110000 00010000 00000000 00010011,前12位是Descriptor Index = 2^9+2^8+1 = 769,找到769項(xiàng)對(duì)應(yīng)的內(nèi)容0x301,偏移量為0000 00000000 00010011=13,那么段地址為0x3000000D。

          下面是s3c2410內(nèi)存映射后的一個(gè)示意圖:



          關(guān)鍵詞: ARMMMU地址轉(zhuǎn)

          評(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); })();