在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,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首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > ARM異常向量表初始化

            ARM異常向量表初始化

            作者: 時間:2016-11-10 來源:網(wǎng)絡(luò) 收藏
            中斷向量表的程序設(shè)計如下:

            CODE32
            AREA Startup,CODE,READONLY
            ; /* 異常向量表 */
            Vectors
            LDR PC,ResetAddr;把ResetAdde地址上的存儲器的內(nèi)容裝載到PC上
            LDR PC, UndefinedAddr
            LDR PC, SWI_Addr
            LDR PC, PrefetchAddr
            LDR PC, DataAbortAddr
            DCD 0
            LDR PC, IRQ_Addr
            LDR PC, FIQ_Addr

            本文引用地址:http://www.biyoush.com/article/201611/317202.htm

            ResetAddr DCD ResetInit;為ResetAddr分配以ResetInit地址值,
            UndefinedAddr DCD Undefined
            SWI_Addr DCD SoftwareInterrupt
            PrefetchAddr DCD PrefetchAbort
            DataAbortAddr DCD DataAbort
            Nouse DCD 0
            IRQ_Addr DCD IRQ_Exception
            FIQ_Addr DCD FIQ_Handler

            此時ResetAddr實質(zhì)上只作為一個指針(指向ResetInit),沒有分配空間,

            ResetAddr地址的存儲器上裝載的是ResetInit的地址。

            ResetInit
            BL InitStack ; 初始化堆棧
            BL TargetBusInit ; 總線系統(tǒng)初始化 (函數(shù)中不允許堆棧操作)
            BLTargetResetInit; 針對目標(biāo)板的系統(tǒng)初始化

            以ResetInit為例,存儲器空間分配如下所示:

            注意中斷向量表要存放在代碼段startup的開始處(Entry開始),而程序被鏈接時,該startup代碼段被鏈接在整個程序的入口地址。

            =========================

            1. undef exception handler

            當(dāng)前指令,如果CPU不支持,它會自動將該指令交給Co-processor.(如:MMU, FPU)處理。

            如果Co-processor也無法識別這條指令,則產(chǎn)生異常.

            2. SWI handler

            當(dāng)執(zhí)行SWI指令時,產(chǎn)生這種中斷.

            3. Data abort

            由數(shù)據(jù)異常觸發(fā).

            通常有3種指令引發(fā)數(shù)據(jù)異常, 這些指令都是訪存操作.(都是由MMU引入后才可能會發(fā)生的情況)

            LDR / STR

            SWAP

            LDM / STM

            MMU的失效類型,又分為5種:

            存儲訪問失效

            地址對齊失效

            地址變換失效

            域控制器失效

            訪問控制權(quán)限失效

            因此當(dāng)異常發(fā)生后,需要通過訪問CP15來獲知異常產(chǎn)生的具體原因和情況。

            4. Pretetch Abort

            對于ARM處理器來說,由于其內(nèi)部使用了哈佛結(jié)構(gòu)---獨立的數(shù)據(jù)的指令總線.

            因此,在數(shù)據(jù)/指令的讀取過程中產(chǎn)生的異常也就很自然地可以區(qū)分開來

            本質(zhì)上而言,這些異常都是同屬于存儲訪問失敗產(chǎn)生的異常,因此這些異常都由MMU相關(guān),在ARM手冊中DataAbort和PrefetchAbort都

            稱為Memory abort。

            Prefetch也就是在預(yù)取指令的動作后產(chǎn)生的,當(dāng)處理器運行到這個無效的指令時(這個無效與undefined exception中的不可識別不同,

            是指不存在或是無法得到)就觸發(fā)該異常。



            關(guān)鍵詞: ARM異常向量表初始

            評論


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

            關(guān)閉