国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

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

STM32嵌入式開發 ? 來源:STM32嵌入式開發 ? 2020-08-27 14:21 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

2、ARM中異常中斷的種類

(1)、復位(RESET)

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

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

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

(3)、軟件中斷 這是一個由用戶定義的中斷指令(SWI)??捎糜谟脩裟J较碌某绦蛘{用特權操作指令。在實時操作系統中可以通過該機制實現系統功能調用。

(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

    文章

    20250

    瀏覽量

    252201
  • ARM
    ARM
    +關注

    關注

    135

    文章

    9552

    瀏覽量

    391825
  • 存儲器
    +關注

    關注

    39

    文章

    7738

    瀏覽量

    171650

原文標題:ARM異常中斷的原因及處理措施

文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    RK806中斷處理流程深度解析:從架構到調試實戰

    RK806 作為瑞芯微主流 PMIC(電源管理芯片),其中斷機制是實現“電源鍵響應、電壓異常保護、休眠喚醒、 watchdog 超時處理” 等核心功能的基礎。Linux 驅動基于regmap_irq框架設計,屏蔽了底層寄存器操作
    的頭像 發表于 02-05 13:46 ?912次閱讀
    RK806<b class='flag-5'>中斷</b><b class='flag-5'>處理</b>流程深度解析:從架構到調試實戰

    Cortex-M3工作模式及異常

    一、工作模式 線程模式和手柄模式。 處理器處在線程狀態下時,既可以使用特權級,也可以使用用戶級;另一方面, handler模式總是特權級的。在復位后,處理器進入線程模式+特權級。 二、異常
    發表于 01-20 08:24

    CW32F030中斷解析

    中斷 1 概述 ARM? Cortex?-M0+ 內核的嵌套向量中斷控制器 (NVIC),用于管理中斷異常。NVIC 和
    發表于 01-12 08:41

    RISC-V異常中斷機制全解析

    RISC-V 作為開源、模塊化的精簡指令集架構,其異常中斷機制是保障系統可靠運行、響應外部事件與處理內部錯誤的核心支撐。
    的頭像 發表于 12-28 14:41 ?1435次閱讀
    RISC-V<b class='flag-5'>異常中斷</b>機制全解析

    深入剖析ARM64異常處理:開發者必須掌握的底層核心邏輯

    與軟件的協同操作邏輯,都是開發者必備的核心能力。今天我們就深度拆解ARM64異常處理機制,同時聊聊 開發者為何必須關注這一技術點 。 一、異常發生
    的頭像 發表于 12-24 07:05 ?1103次閱讀
    深入剖析<b class='flag-5'>ARM</b>64<b class='flag-5'>異常</b><b class='flag-5'>處理</b>:開發者必須掌握的底層核心邏輯

    使用setjmp及longjmp函數處理異常

    ,例如在發生錯誤或異常時,直接跳轉到錯誤處理或資源釋放的代碼,而不需要逐層返回。setjmp和longjmp函數定義在setjmp.h頭文件中,其語法為: int setjmp(jmp_buf
    發表于 12-11 08:00

    C++程序異常處理機制

    運行代碼進行分離,使得程序更加模塊化;另一方面,C++的異常處理可以不需要異常處理異常發生時的
    發表于 12-02 07:12

    芯源MCU中斷相關寄存器

    5.5.1 NVIC 中斷使能和禁止使能 ARM? Cortex-M0+ 處理器支持最多32 個外部中斷源,分別對應中斷使能設置寄存器NIV
    發表于 11-27 07:23

    線路保護光纖通道異常處理方法

    通道異常的 常見原因、處理步驟及預防措施 ,幫助運維人員快速定位問題,提升故障處理效率。 廣州郵科光纖線路保護系統 一、光纖通道異常的常見表
    的頭像 發表于 11-17 10:01 ?1104次閱讀
    線路保護光纖通道<b class='flag-5'>異常</b><b class='flag-5'>處理</b>方法

    IAR下全志T113-S3 ARM Cortex-A7開啟FPU后異常怎么解決?

    花了幾天移植rt-thread到IAR,目前測試線程正常運行,但是想嘗試開啟FPU,開啟了宏定義 RT_USING_FPU后啟動后出現異常,程序運行后進入 Undef_Handler 異常中斷
    發表于 10-14 06:18

    如果在FMC執行“程序”或“擦除”時發生中斷事件,是否會處理中斷事件?

    如果在FMC執行“程序”或“擦除”時發生中斷事件,是否會處理中斷事件?
    發表于 08-27 08:01

    UART數據傳輸過程中發生RLS(接收線狀態)中斷時,如何處理PEF、FEF和BIF標志?

    UART數據傳輸過程中發生RLS(接收線狀態)中斷時,如何處理PEF、FEF和BIF標志
    發表于 08-22 07:25

    如果在FMC執行“程序”或“擦除”時發生中斷事件,是否會處理中斷事件呢?

    如果在FMC執行“程序”或“擦除”時發生中斷事件,是否會處理中斷事件?
    發表于 08-22 06:58

    STM32IDE如何設定代碼到ITCM中運行?

    摸索到了如何將變量定義到某個地址,但是不清楚如何讓代碼在指定RAM中運行。按照設定變量的方式設定代碼,程序直接進入了異常中斷{:16:}。
    發表于 06-24 06:45

    33250A信號發生器通訊異常?維修案例分享

    近期某客戶送修一臺安捷倫33250A安捷倫信號發生器,報修故障是通訊異常,隨后工程師進行拆機檢測,發現與客戶報修故障一致。
    的頭像 發表于 04-27 17:50 ?721次閱讀
    33250A信號<b class='flag-5'>發生</b>器通訊<b class='flag-5'>異常</b>?維修案例分享