精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

ARM異常中斷的原因及處理措施

姚小熊27 ? 來源:電路城論壇 ? 作者:王浩然 ? 2020-06-17 10:05 ? 次閱讀

ARM異常中斷發生時,系統執行完當前指令后,將跳轉到相應的異常中斷處理程序處執行。當異常中斷處理程序執行完成后,程序返回到發生中斷指令的下條指令處執 行。在進入異常中斷處理程序時,要保存被中斷程序的執行現場,從異常中斷處理程序退出時,要恢復被中斷程序的執行現場。

1、引起異常的原因 對于ARM核,可以且只能識別7種處理器異常,每種異常都對應一種ARM處理器模式,當發生異常時,ARM處理器就切換到相應的異常模式,并調用異常處理 程序進行處理。

(1)、指令執行引起的異常 軟件中斷、未定義指令(包括所要求的協處理器不存在是的協處理器指令)、預取址中止(存儲器故障)、數據中止。

(2)、外部產生的中斷 復位、FIQ、IRQ。

2、ARM中異常中斷的種類

(1)、復位(RESET)

a、當處理器復位引腳有效時,系統產生復位異常中斷,程序跳轉到復位異常中斷處理程序處執行,包括系統加電和系統復位。

b、通過設置PC跳轉到復位中斷向量處執行稱為軟復位。

(2)、未定義的指令 當ARM處理器或者是系統中的協處理器認為當前指令未定義時,產生未定義的指令異常中斷,可以通過改異常中斷機制仿真浮點向量運算。

(3)、軟件中斷 這是一個由用戶定義的中斷指令(SWI)。可用于用戶模式下的程序調用特權操作指令。在實時操作系統中可以通過該機制實現系統功能調用。

(4)、指令與取終止(Prefech Abort) 如果處理器預取的指令的地址不存在,或者該地址不允許當前指令訪問,當被預取的指令執行時,處理器產生指令預取終止異常中斷。

(5)、數據訪問終止(DATAABORT) 如果數據訪問指令的目標地址不存在,或者該地址不允許當前指令訪問,處理器產生數據訪問終止異常中斷。

(6)、外部中斷請求(IRQ) 當處理器的外部中斷請求引腳有效,而且CPSR的寄存器的I控制位被清除時,處理器產生外部中斷請求異常中斷。系統中個外設通過該異常中斷請求處理服務。

(7)、快速中斷請求(FIQ) 當處理器的外部快速中斷請求引腳有效,而且CPSR的F控制位被清除時,處理器產生外部中斷請求異常中斷。

3、異常的響應過程 除了復位異常外,當異常發生時,ARM處理器盡可能完成當前指令(除了復位異常)后,再去處理異常。并執行如下動作: (1)、將引起異常指令的下一條指令的地址保存到新模式的R14中,若異常是從ARM狀態進入,LR寄存器中保存的是下一條指令的地址(當前PC+4或 PC+8,與異常的類型有關);若異常是從Thumb狀態進入,則在LR寄存器中保存當前PC的偏移量,這樣,異常處理程序就不需要確定異常是從何種狀態 進入的。例如:在軟件中斷異常SWI,指令MOV PC,R14_svc總是返回到下一條指令,不管SWI是在ARM狀態執行,還是在Thumb狀 態執行。

(2)、將CPSR的內容保存到要執行異常中斷模式的SPSR中。

(3)、設置CPSR相應的位進入相應的中斷模式。

(4)、通過設置CPSR的第7位來禁止IRQ。如果異常為快速中斷和復位。則還要設置CPSR的第6位來禁止快速中斷。

(5)、給PC強制賦向量地址值。 上面的異常處理操作都是由ARM核硬件邏輯自動完成的,程序計數器PC總是跳轉到相應的固定地址。 如果異常發生時,處理器處于Thumb狀態,則當異常向量地址加載入PC時,處理器自動切換到ARM狀態,則異常處理返回時,自動切換到Thumb狀態。

4、異常中斷處理返回 異常處理完畢之后,ARM微處理器會執行以下幾步操作從異常返回:

(1)、將所有修改過的用戶寄存器從處理程序的保護棧中恢復。

(2)、將SPSR復制回CPSR中,將連接寄存器LR的值減去相應的偏移量后送到PC中。

(3)、若在進入異常處理時設置了中斷禁止位,要在此清除。 復位異常處理程序不需要返回。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19159

    瀏覽量

    229114
  • ARM
    ARM
    +關注

    關注

    134

    文章

    9045

    瀏覽量

    366806
收藏 人收藏

    評論

    相關推薦

    ARM異常中斷返回的幾種情況

    [學習引導]ARM異常中斷返回的幾種情況 異常中斷返回的幾種情況: 重要基礎知識:R15(PC)總是指向“正在取指”的指令,而不是指向“正在執行”的指令或正在“譯碼”的指令。一般來說,人們習慣性
    發表于 03-31 16:09

    ARM異常中斷返回的幾種情況

    ARM異常中斷返回的幾種情況異常中斷返回的幾種情況: 重要基礎知識:R15(PC)總是指向“正在取指”的指令,而不是指向“正在執行”的指令或正在“譯碼”的指令。一般來說,人們習慣性約定將“正在執行
    發表于 07-22 11:32

    ARM異常中斷處理流程分析

    現場,在從異常中斷處理程序退出時,要恢復被中斷的程序的執行現場。本文討論ARM體系中的異常中斷機制。AR
    發表于 08-28 08:09

    教你一種ARM處理異常中斷的方法

    的值已經更新,它指向當前指令后面第3條指令(對于ARM指令,它指向當前指令地址加12字節的位置;對于Thumb指令,它指向當前指令地址加6字節的位置),當FIQ/IRQ異常中斷產生時,處理器將值
    發表于 08-18 15:26

    ARM體系中的異常中斷及其應用

    ARM體系中的異常中斷及其應用
    發表于 09-22 16:51 ?4次下載
    <b class='flag-5'>ARM</b>體系中的<b class='flag-5'>異常中斷</b>及其應用

    ARM處理器編程模型之異常中斷處理分析

    3.4 異常中斷處理 異常中斷是用戶程序中最基本的一種執行流程和形態。這部分主要對ARM架構下的異常中
    發表于 10-18 13:29 ?1次下載

    Thumb指令集之異常中斷產生指令解析

    11.7 異常中斷產生指令(斷點指令) Thumb異常中斷產生指令與ARM指令集下的異常中斷指令十分相似。同ARM指令集相同,Thumb指令
    發表于 10-19 09:32 ?0次下載
    Thumb指令集之<b class='flag-5'>異常中斷</b>產生指令解析

    ARM S3C4510B系統的異常中斷機制解析

    本文介紹A了RM S3C4510B系統 的 異常中斷 機制,包括異常中斷的分類,響應與返回;中斷處理程序的安裝與調用;SWI,IRQ中斷的實
    發表于 02-03 05:32 ?1769次閱讀
    <b class='flag-5'>ARM</b> S3C4510B系統的<b class='flag-5'>異常中斷</b>機制解析

    ARM異常中斷的集中情況進行總結,并給出了一些解決方法

    ARM單片機是大多數新手選擇的入門切入點,但由于知識的不足,在設計過程中新手們經常會遇到這樣或那樣的問題,ARM異常中斷返回就是這樣一種令人頭疼的問題。在ARM的使用問題中
    的頭像 發表于 02-08 09:29 ?6498次閱讀
    對<b class='flag-5'>ARM</b><b class='flag-5'>異常中斷</b>的集中情況進行總結,并給出了一些解決方法

    ARM異常中斷問題詳情分析總結

    ARM異常中斷的類型問題分析總結 一、ARM異常中斷的類型: 異常中斷名稱 含義 復位(Reset) 當
    發表于 04-05 10:51 ?1292次閱讀

    ARM異常中斷發生時的處理措施

    外部中斷請求(IRQ) 當處理器的外部中斷請求引腳有效,而且CPSR的寄存器的I控制位被清除時,處理器產生外部中斷請求異常中斷。系統中個外設
    的頭像 發表于 08-27 14:21 ?2584次閱讀

    ARM處理器對異常中斷的響應過程

    異常中斷發生時,程序將當前執行指令的下一條指令的地址存入新的異常模式的鏈接寄存器LR中(R14_),以便程序在異常處理完后,能正確返回原程序。
    發表于 10-18 17:25 ?817次閱讀

    arm處理器有哪些中斷源?arm處理器對異常中斷的響應過程

    arm處理器有哪些中斷源?arm處理器對異常中斷的響應過程?
    的頭像 發表于 10-19 16:35 ?1392次閱讀

    ARM中的異常中斷是如何實現進入中斷程序的?如何進入呢?

    ARM中的異常中斷是如何實現進入中斷程序的?如何進入呢? 在計算機系統中,異常中斷是兩個常見的概念。 在
    的頭像 發表于 10-19 16:36 ?970次閱讀

    ARM處理器的異常中斷響應過程

    ARM處理器的異常中斷響應是嵌入式系統設計中一個至關重要的環節,它確保了系統在面對內部或外部事件時能夠穩定、可靠地運行。
    的頭像 發表于 09-10 11:18 ?758次閱讀