<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 關(guān)于ARM核異常與中斷處理機制研究

          關(guān)于ARM核異常與中斷處理機制研究

          作者: 時間:2011-04-10 來源:網(wǎng)絡(luò) 收藏

          一.及其對應(yīng)的模式

          本文引用地址:http://www.ex-cimer.com/article/150862.htm

            當(dāng)一個發(fā)生時,器總是切換到狀態(tài)(即非Thumb狀態(tài))。Thumb指令集沒有包含進行時需要的一些指令,因此在異常時,還是要使用ARM指令。

            

          ARM處理器框圖

            每種異常都導(dǎo)致內(nèi)核進入一種特定的模式。此外,可以通過修改cpsr,進入任何ARM處理器模式。用戶和系統(tǒng)模式是僅有的可不通過相應(yīng)異常進入的2中模式。

            當(dāng)一個異常導(dǎo)致模式的改變時,內(nèi)核自動的:

            把cpsr保存到相應(yīng)異常模式下的spsr

            把pc保存到相應(yīng)模式下的lr

            設(shè)置cpsr為相應(yīng)異常模式

            設(shè)置pc為相應(yīng)異常處理程序的入口地址

            二.向量表

            異常發(fā)生時,ARM跳轉(zhuǎn)地址組成的表。

            

          向量表

            三.異常優(yōu)先級

            復(fù)位異常是優(yōu)先級最高的異常,一旦復(fù)位異常產(chǎn)生,總是會發(fā)生復(fù)位異常。注意:當(dāng)一條不屬于ARM或Thumb指令集的指令到達流水線的執(zhí)行階段時,若此時沒有其它異常發(fā)生,就會產(chǎn)生未定義指令異常。ARM處理器會“詢問”協(xié)處理器,看它能否將其作為一條協(xié)處理器指令來處理。由于協(xié)處理器在流水線之后,所以指令確認可以在內(nèi)核的執(zhí)行階段進行。如果這條指令不屬于任何一個協(xié)處理器,則會產(chǎn)生未定義指令異常。

            

          異常優(yōu)先級

            四.

            延時是指:從外部請求信號發(fā)出到取出對應(yīng)的中斷服務(wù)程序(ISR)的第一條指令,這期間的間隔時間。

            

          中斷延時

            五.中斷源及其識別方法

            S3C2440A有60個中斷源,IRQ有兩種中斷識別方法:向量中斷和非向量中斷。FIQ只有非向量中斷。在IRQ各個中斷源中的某一個中斷源的中斷請求被響應(yīng)時,CPU轉(zhuǎn)至0x18處自動加載一條轉(zhuǎn)移指令轉(zhuǎn)至相應(yīng)中斷源的固定中斷向量處。IRQ各個中斷源的向量地址是固定的,每個占用一個字單元。IRQ各個中斷源若采用非向量中斷,任意一個中斷源發(fā)出中斷請求,都認為發(fā)生了IRQ中斷請求,并自動轉(zhuǎn)入IRQ中斷服務(wù)程序執(zhí)行。IRQ中斷服務(wù)程序主要功能是將軟件設(shè)定的中斷向量表中相應(yīng)的中斷源服務(wù)程序入口地址送給PC,并轉(zhuǎn)其執(zhí)行。在非向量中斷模式下,一般在IRQ處放置一條轉(zhuǎn)移指令:B IsrIRQ 。其中,IsrIRQ為所有IRQ中斷服務(wù)程序的總?cè)肟诘刂罚彩欠窍蛄恐袛嗄J降闹袛嘣磁袆e及散轉(zhuǎn)程序。

            

          IRQ中斷服務(wù)程序
          上一頁 1 2 下一頁

          評論


          相關(guān)推薦

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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();