ADS下bootloader之MMU研究
這是一個MMU的虛擬地址向物理地址映射的函數(shù)。通過上邊的調(diào)用可以看到物理地址和虛擬地址的地址是相同的,那為什么還要開MMU呢,不是多此一舉嗎,Dcache的開啟必須在MMU開啟后才能開啟,Icache不受MMU影響。開啟Cache對系統(tǒng)性能會有很大提升。所以,哈哈。這里_MMUTT_STARTADDRESS是轉(zhuǎn)換表的基址,因為沒有使用復(fù)雜的操作系統(tǒng),所以只使用了一級頁表,每個頁表項對應(yīng)的是一個1MB的段。pTT=(U32 *)_MMUTT_STARTADDRESS+(vaddrStart>>20);相當(dāng)于獲得相應(yīng)的頁表項??匆幌孪聢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,真是誤人子弟啊。本文引用地址:http://www.ex-cimer.com/article/150787.htm
評論