91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

當(dāng)ARM異常中斷發(fā)生時(shí)的處理措施

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

掃碼添加小助手

加入工程師交流群

當(dāng)ARM異常中斷發(fā)生時(shí),系統(tǒng)執(zhí)行完當(dāng)前指令后,將跳轉(zhuǎn)到相應(yīng)的異常中斷處理程序處執(zhí)行。當(dāng)異常中斷處理程序執(zhí)行完成后,程序返回到發(fā)生中斷指令的下條指令處執(zhí) 行。在進(jìn)入異常中斷處理程序時(shí),要保存被中斷程序的執(zhí)行現(xiàn)場(chǎng),從異常中斷處理程序退出時(shí),要恢復(fù)被中斷程序的執(zhí)行現(xiàn)場(chǎng)。

1、引起異常的原因 對(duì)于ARM核,可以且只能識(shí)別7種處理器異常,每種異常都對(duì)應(yīng)一種ARM處理器模式,當(dāng)發(fā)生異常時(shí),ARM處理器就切換到相應(yīng)的異常模式,并調(diào)用異常處理 程序進(jìn)行處理。

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

(2)、外部產(chǎn)生的中斷 復(fù)位、FIQ、IRQ。

2、ARM中異常中斷的種類

(1)、復(fù)位(RESET)

a、當(dāng)處理器復(fù)位引腳有效時(shí),系統(tǒng)產(chǎn)生復(fù)位異常中斷,程序跳轉(zhuǎn)到復(fù)位異常中斷處理程序處執(zhí)行,包括系統(tǒng)加電和系統(tǒng)復(fù)位。

b、通過(guò)設(shè)置PC跳轉(zhuǎn)到復(fù)位中斷向量處執(zhí)行稱為軟復(fù)位。

(2)、未定義的指令 當(dāng)ARM處理器或者是系統(tǒng)中的協(xié)處理器認(rèn)為當(dāng)前指令未定義時(shí),產(chǎn)生未定義的指令異常中斷,可以通過(guò)改異常中斷機(jī)制仿真浮點(diǎn)向量運(yùn)算。

(3)、軟件中斷 這是一個(gè)由用戶定義的中斷指令(SWI)??捎糜谟脩裟J较碌某绦蛘{(diào)用特權(quán)操作指令。在實(shí)時(shí)操作系統(tǒng)中可以通過(guò)該機(jī)制實(shí)現(xiàn)系統(tǒng)功能調(diào)用。

(4)、指令與取終止(Prefech Abort) 如果處理器預(yù)取的指令的地址不存在,或者該地址不允許當(dāng)前指令訪問(wèn),當(dāng)被預(yù)取的指令執(zhí)行時(shí),處理器產(chǎn)生指令預(yù)取終止異常中斷。

(5)、數(shù)據(jù)訪問(wèn)終止(DATAABORT) 如果數(shù)據(jù)訪問(wèn)指令的目標(biāo)地址不存在,或者該地址不允許當(dāng)前指令訪問(wèn),處理器產(chǎn)生數(shù)據(jù)訪問(wèn)終止異常中斷。

(6)、外部中斷請(qǐng)求(IRQ) 當(dāng)處理器的外部中斷請(qǐng)求引腳有效,而且CPSR的寄存器的I控制位被清除時(shí),處理器產(chǎn)生外部中斷請(qǐng)求異常中斷。系統(tǒng)中個(gè)外設(shè)通過(guò)該異常中斷請(qǐng)求處理服務(wù)。

(7)、快速中斷請(qǐng)求(FIQ) 當(dāng)處理器的外部快速中斷請(qǐng)求引腳有效,而且CPSR的F控制位被清除時(shí),處理器產(chǎn)生外部中斷請(qǐng)求異常中斷。

3、異常的響應(yīng)過(guò)程 除了復(fù)位異常外,當(dāng)異常發(fā)生時(shí),ARM處理器盡可能完成當(dāng)前指令(除了復(fù)位異常)后,再去處理異常。并執(zhí)行如下動(dòng)作:

(1)、將引起異常指令的下一條指令的地址保存到新模式的R14中,若異常是從ARM狀態(tài)進(jìn)入,LR寄存器中保存的是下一條指令的地址(當(dāng)前PC+4或 PC+8,與異常的類型有關(guān));若異常是從Thumb狀態(tài)進(jìn)入,則在LR寄存器中保存當(dāng)前PC的偏移量,這樣,異常處理程序就不需要確定異常是從何種狀態(tài) 進(jìn)入的。例如:在軟件中斷異常SWI,指令MOV PC,R14_svc總是返回到下一條指令,不管SWI是在ARM狀態(tài)執(zhí)行,還是在Thumb狀 態(tài)執(zhí)行。

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

(3)、設(shè)置CPSR相應(yīng)的位進(jìn)入相應(yīng)的中斷模式。

(4)、通過(guò)設(shè)置CPSR的第7位來(lái)禁止IRQ。如果異常為快速中斷和復(fù)位。則還要設(shè)置CPSR的第6位來(lái)禁止快速中斷。

(5)、給PC強(qiáng)制賦向量地址值。上面的異常處理操作都是由ARM核硬件邏輯自動(dòng)完成的,程序計(jì)數(shù)器PC總是跳轉(zhuǎn)到相應(yīng)的固定地址。如果異常發(fā)生時(shí),處理器處于Thumb狀態(tài),則當(dāng)異常向量地址加載入PC時(shí),處理器自動(dòng)切換到ARM狀態(tài),則異常處理返回時(shí),自動(dòng)切換到Thumb狀態(tài)。

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

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

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

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    20256

    瀏覽量

    252455
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    135

    文章

    9554

    瀏覽量

    392072
  • 存儲(chǔ)器
    +關(guān)注

    關(guān)注

    39

    文章

    7739

    瀏覽量

    171711

原文標(biāo)題:ARM異常中斷的原因及處理措施

文章出處:【微信號(hào):c-stm32,微信公眾號(hào):STM32嵌入式開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    RK806中斷處理流程深度解析:從架構(gòu)到調(diào)試實(shí)戰(zhàn)

    RK806 作為瑞芯微主流 PMIC(電源管理芯片),其中斷機(jī)制是實(shí)現(xiàn)“電源鍵響應(yīng)、電壓異常保護(hù)、休眠喚醒、 watchdog 超時(shí)處理” 等核心功能的基礎(chǔ)。Linux 驅(qū)動(dòng)基于regmap_irq框架設(shè)計(jì),屏蔽了底層寄存器操作
    的頭像 發(fā)表于 02-05 13:46 ?1036次閱讀
    RK806<b class='flag-5'>中斷</b><b class='flag-5'>處理</b>流程深度解析:從架構(gòu)到調(diào)試實(shí)戰(zhàn)

    Cortex-M3工作模式及異常

    一、工作模式 線程模式和手柄模式。 當(dāng)處理器處在線程狀態(tài)下時(shí),既可以使用特權(quán)級(jí),也可以使用用戶級(jí);另一方面, handler模式總是特權(quán)級(jí)的。在復(fù)位后,處理器進(jìn)入線程模式+特權(quán)級(jí)。 二、異常
    發(fā)表于 01-20 08:24

    CW32F030中斷解析

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

    RISC-V異常中斷機(jī)制全解析

    RISC-V 作為開源、模塊化的精簡(jiǎn)指令集架構(gòu),其異常中斷機(jī)制是保障系統(tǒng)可靠運(yùn)行、響應(yīng)外部事件與處理內(nèi)部錯(cuò)誤的核心支撐。
    的頭像 發(fā)表于 12-28 14:41 ?1476次閱讀
    RISC-V<b class='flag-5'>異常中斷</b>機(jī)制全解析

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

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

    使用setjmp及l(fā)ongjmp函數(shù)處理異常

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

    C++程序異常處理機(jī)制

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

    芯源MCU中斷相關(guān)寄存器

    5.5.1 NVIC 中斷使能和禁止使能 ARM? Cortex-M0+ 處理器支持最多32 個(gè)外部中斷源,分別對(duì)應(yīng)中斷使能設(shè)置寄存器NIV
    發(fā)表于 11-27 07:23

    線路保護(hù)光纖通道異常處理方法

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

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

    花了幾天移植rt-thread到IAR,目前測(cè)試線程正常運(yùn)行,但是想嘗試開啟FPU,開啟了宏定義 RT_USING_FPU后啟動(dòng)后出現(xiàn)異常,程序運(yùn)行后進(jìn)入 Undef_Handler 異常中斷
    發(fā)表于 10-14 06:18

    如果在FMC執(zhí)行“程序”或“擦除”時(shí)發(fā)生中斷事件,是否會(huì)處理中斷事件?

    如果在FMC執(zhí)行“程序”或“擦除”時(shí)發(fā)生中斷事件,是否會(huì)處理中斷事件?
    發(fā)表于 08-27 08:01

    當(dāng)UART數(shù)據(jù)傳輸過(guò)程中發(fā)生RLS(接收線狀態(tài))中斷時(shí),如何處理PEF、FEF和BIF標(biāo)志?

    當(dāng)UART數(shù)據(jù)傳輸過(guò)程中發(fā)生RLS(接收線狀態(tài))中斷時(shí),如何處理PEF、FEF和BIF標(biāo)志
    發(fā)表于 08-22 07:25

    如果在FMC執(zhí)行“程序”或“擦除”時(shí)發(fā)生中斷事件,是否會(huì)處理中斷事件呢?

    如果在FMC執(zhí)行“程序”或“擦除”時(shí)發(fā)生中斷事件,是否會(huì)處理中斷事件?
    發(fā)表于 08-22 06:58

    STM32IDE如何設(shè)定代碼到ITCM中運(yùn)行?

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

    33250A信號(hào)發(fā)生器通訊異常?維修案例分享

    近期某客戶送修一臺(tái)安捷倫33250A安捷倫信號(hào)發(fā)生器,報(bào)修故障是通訊異常,隨后工程師進(jìn)行拆機(jī)檢測(cè),發(fā)現(xiàn)與客戶報(bào)修故障一致。
    的頭像 發(fā)表于 04-27 17:50 ?733次閱讀
    33250A信號(hào)<b class='flag-5'>發(fā)生</b>器通訊<b class='flag-5'>異常</b>?維修案例分享