新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 關于ADS下bootloader之MMU的深入研究

關于ADS下bootloader之MMU的深入研究

作者: 時間:2016-12-02 來源:網(wǎng)絡 收藏








這是一個MMU的虛擬地址向物理地址映射的函數(shù)。通過上邊的調(diào)用可以看到物理地址和虛擬地址的地址是相同的,那為什么還要開MMU呢,不是多此一舉嗎,Dcache的開啟必須在MMU開啟后才能開啟,Icache不受MMU影響。開啟Cache對系統(tǒng)性能會有很大提升。所以,哈哈。這里_MMUTT_STARTADDRESS是轉(zhuǎn)換表的基址,因為沒有使用復雜的操作系統(tǒng),所以只使用了一級頁表,每個頁表項對應的是一個1MB的段。pTT=(U32 *)_MMUTT_STARTADDRESS+(vaddrStart>>20);相當于獲得相應的頁表項??匆幌孪聢D就會明白。nSec=(vaddrEnd>>20)-(vaddrStart>>20);這句是計算有幾個段。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)用的匯編代碼,這個是飛凌的boot,網(wǎng)上好多人說沒開MMU,真是誤人子弟啊。

上一頁 1 2 下一頁

關鍵詞: ADSbootloaderMM

評論


技術專區(qū)

關閉