關(guān)于ADS下bootloader之MMU的深入研究
這是一個(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,真是誤人子弟啊。
評(píng)論