色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 關(guān)于ADS下bootloader之MMU的深入研究

          關(guān)于ADS下bootloader之MMU的深入研究

          作者: 時(shí)間:2016-12-02 來(lái)源:網(wǎng)絡(luò) 收藏








          這是一個(gè)MMU的虛擬地址向物理地址映射的函數(shù)。通過(guò)上邊的調(diào)用可以看到物理地址和虛擬地址的地址是相同的,那為什么還要開(kāi)MMU呢,不是多此一舉嗎,Dcache的開(kāi)啟必須在MMU開(kāi)啟后才能開(kāi)啟,Icache不受MMU影響。開(kāi)啟Cache對(duì)系統(tǒng)性能會(huì)有很大提升。所以,哈哈。這里_MMUTT_STARTADDRESS是轉(zhuǎn)換表的基址,因?yàn)闆](méi)有使用復(fù)雜的操作系統(tǒng),所以只使用了一級(jí)頁(yè)表,每個(gè)頁(yè)表項(xiàng)對(duì)應(yīng)的是一個(gè)1MB的段。pTT=(U32 *)_MMUTT_STARTADDRESS+(vaddrStart>>20);相當(dāng)于獲得相應(yīng)的頁(yè)表項(xiàng)。看一下下圖就會(huì)明白。nSec=(vaddrEnd>>20)-(vaddrStart>>20);這句是計(jì)算有幾個(gè)段。for(i=0;i<=nSec;i++)*pTT++=attr |(((paddrStart>>20)+i)<<20);分別映射每段。Attr是域。


          void MMU_SetMTT(int vaddrStart,int vaddrEnd,int paddrStart,int attr)
          {
          volatile U32 *pTT;
          volatile int i,nSec;
          pTT=(U32 *)_MMUTT_STARTADDRESS+(vaddrStart>>20);
          nSec=(vaddrEnd>>20)-(vaddrStart>>20);
          for(i=0;i<=nSec;i++)*pTT++=attr |(((paddrStart>>20)+i)<<20);
          }










          這里就不列出那些被調(diào)用的匯編代碼,這個(gè)是飛凌的boot,網(wǎng)上好多人說(shuō)沒(méi)開(kāi)MMU,真是誤人子弟啊。

          上一頁(yè) 1 2 下一頁(yè)

          關(guān)鍵詞: ADSbootloaderMM

          評(píng)論


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

          關(guān)閉