在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

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

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

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








            這是一個(gè)MMU的虛擬地址向物理地址映射的函數(shù)。通過上邊的調(diào)用可以看到物理地址和虛擬地址的地址是相同的,那為什么還要開MMU呢,不是多此一舉嗎,Dcache的開啟必須在MMU開啟后才能開啟,Icache不受MMU影響。開啟Cache對(duì)系統(tǒng)性能會(huì)有很大提升。所以,哈哈。這里_MMUTT_STARTADDRESS是轉(zhuǎn)換表的基址,因?yàn)闆]有使用復(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)??匆幌孪聢D就會(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)上好多人說沒開MMU,真是誤人子弟啊。

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

            關(guān)鍵詞: ADSbootloaderMM

            評(píng)論


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

            關(guān)閉