資料介紹
3.4 異常中斷處理
異?;蛑袛嗍怯脩舫绦蛑凶罨镜囊环N執(zhí)行流程和形態(tài)。這部分主要對(duì)ARM架構(gòu)下的異常中斷做詳細(xì)說明。
ARM有7種類型的異常,按優(yōu)先級(jí)從高到低的排列如下:復(fù)位異常(Reset)、數(shù)據(jù)異常(Data Abort)、快速中斷異常(FIQ)、外部中斷異常(IRQ)、預(yù)取異常(Prefetch Abort)、軟件中斷(SWI)和未定義指令異常(Undefined instruction)。
注意在ARM文檔中,使用術(shù)語Exception來描述異常。Exception主要是從處理器被動(dòng)接受異常的角度出發(fā),而Interrupt帶有向處理器主動(dòng)申請(qǐng)的色彩。在本書中,對(duì)“異?!焙汀爸袛唷辈蛔鰢?yán)格區(qū)分,兩者都是指請(qǐng)求處理器打斷正常的程序執(zhí)行流程,進(jìn)入特定程序循環(huán)的一種機(jī)制。
3.4.1 異常種類
ARM體系結(jié)構(gòu)中,存在7種異常處理。當(dāng)異常發(fā)生時(shí),處理器會(huì)把PC設(shè)置為一個(gè)特定的存儲(chǔ)器地址。這一地址放在被稱為向量表(vector table)的特定地址范圍內(nèi)。向量表的入口是一些跳轉(zhuǎn)指令,跳轉(zhuǎn)到專門處理某個(gè)異?;蛑袛嗟淖映绦?。
存儲(chǔ)器映射地址0x00000000是為向量表(一組32位字)保留的。在有些處理器中,向量表可以選擇定位在存儲(chǔ)空間的高地址(從偏移量0xffff0000開始)。一些嵌入式操作系統(tǒng),如Linux和Windows CE就要利用這一特性。
表3.4列出了ARM的7種異常。
表3.4 ARM的7種異常
異 常 類 型處理器模式執(zhí)行低地址執(zhí)行高地址
復(fù)位異常(Reset)特權(quán)模式0x000000000xFFFF0000
未定義指令異常(Undefined interrupt)未定義指令中止模式0x000000040xFFFF0004
軟中斷異常(Software Abort)特權(quán)模式0x000000080xFFFF0008
預(yù)取異常(Prefetch Abort)數(shù)據(jù)訪問中止模式0x0000000C0xFFFF000C
數(shù)據(jù)異常(Data Abort)數(shù)據(jù)訪問中止模式0x000000100xFFFF0010
外部中斷請(qǐng)求IRQ外部中斷請(qǐng)求模式0x000000180xFFFF0018
快速中斷請(qǐng)求FIQ快速中斷請(qǐng)求模式0x0000001C0xFFFF001C
異常處理向量表如圖3.5所示。
當(dāng)異常發(fā)生時(shí),分組寄存器r14和SPSR用于保存處理器狀態(tài),操作偽指令如下。
R14_《exception_mode》 = return link
SPSR_《exception_mode》 = CPSR
CPSR[4∶0] = exception mode number
CPSR[5] = 0 /*進(jìn)入ARM狀態(tài)*/
If 《exception_mode》 = = reset or FIQ then
CPSR[6] = 1 /*屏蔽快速中斷FIQ*/
CPSR[7] = 1 /*屏蔽外部中斷IRQ*/
PC = exception vector address

圖3.5 異常處理向量表
異常返回時(shí),SPSR內(nèi)容恢復(fù)到CPSR,連接寄存器r14的內(nèi)容恢復(fù)到程序計(jì)數(shù)器PC。
1.復(fù)位異常
當(dāng)處理器的復(fù)位引腳有效時(shí),系統(tǒng)產(chǎn)生復(fù)位異常中斷,程序跳轉(zhuǎn)到復(fù)位異常中斷處理程序處執(zhí)行。復(fù)位異常中斷通常用在下面兩種情況下。
· 系統(tǒng)上電。
· 系統(tǒng)復(fù)位。
當(dāng)復(fù)位異常時(shí),系統(tǒng)執(zhí)行下列偽操作。
R14_svc = UNPREDICTABLE value
SPSR_svc = UNPREDICTABLE value
CPSR[4∶0] = 0b10011 /*進(jìn)入特權(quán)模式*/
CPSR[5] = 0 /*處理器進(jìn)入ARM狀態(tài)*/
CPSR[6] = 1 /*禁止快速中斷*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff0000
Else
PC = 0x00000000
復(fù)位異常中斷處理程序?qū)⑦M(jìn)行一些初始化工作,內(nèi)容與具體系統(tǒng)相關(guān)。下面是復(fù)位異常中斷處理程序的主要功能。
· 設(shè)置異常中斷向量表。
· 初始化數(shù)據(jù)棧和寄存器。
· 初始化存儲(chǔ)系統(tǒng),如系統(tǒng)中的MMU等。
· 初始化關(guān)鍵的I/O設(shè)備。
· 使能中斷。
· 處理器切換到合適的模式。
· 初始化C變量,跳轉(zhuǎn)到應(yīng)用程序執(zhí)行。
2.未定義指令異常
當(dāng)ARM處理器執(zhí)行協(xié)處理器指令時(shí),它必須等待一個(gè)外部協(xié)處理器應(yīng)答后,才能真正執(zhí)行這條指令。若協(xié)處理器沒有相應(yīng),則發(fā)生未定義指令異常。
未定義指令異??捎糜谠跊]有物理協(xié)處理器的系統(tǒng)上,對(duì)協(xié)處理器進(jìn)行軟件仿真,或通過軟件仿真實(shí)現(xiàn)指令集擴(kuò)展。例如,在一個(gè)不包含浮點(diǎn)運(yùn)算的系統(tǒng)中,CPU遇到浮點(diǎn)運(yùn)算指令時(shí),將發(fā)生未定義指令異常中斷,在該未定義指令異常中斷的處理程序中可以通過其他指令序列仿真浮點(diǎn)運(yùn)算指令。
仿真功能可以通過下面步驟實(shí)現(xiàn)。
?、?將仿真程序入口地址鏈接到向量表中未定義指令異常中斷入口處(0x00000004或0xffff0004),并保存原來的中斷處理程序。
?、?讀取該未定義指令的bits[27∶24],判斷其是否是一條協(xié)處理器指令。如果bits[27∶24]值為0b1110或0b110x,該指令是一條協(xié)處理器指令;否則,由軟件仿真實(shí)現(xiàn)協(xié)處理器功能,可以同過bits[11∶8]來判斷要仿真的協(xié)處理器功能(類似于SWI異常實(shí)現(xiàn)機(jī)制)。
?、?如果不仿真該未定義指令,程序跳轉(zhuǎn)到原來的未定義指令異常中斷的中斷處理程序執(zhí)行。
當(dāng)未定義異常發(fā)生時(shí),系統(tǒng)執(zhí)行下列的偽操作。
r14_und = address of next instruction after the undefined instruction
SPSR_und = CPSR
CPSR[4∶0] = 0b11011 /*進(jìn)入未定義指令模式*/
CPSR[5] = 0 /*處理器進(jìn)入ARM狀態(tài)*/
/*CPSR[6]保持不變*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff0004
Else
PC = 0x00000004
3.軟中斷SWI
軟中斷異常發(fā)生時(shí),處理器進(jìn)入特權(quán)模式,執(zhí)行一些特權(quán)模式下的操作系統(tǒng)功能。軟中斷異常發(fā)生時(shí),處理器執(zhí)行下列偽操作。
r14_svc = address of next instruction after the SWI instruction
SPSR_und = CPSR
CPSR[4∶0] = 0b10011 /*進(jìn)入特權(quán)模式*/
CPSR[5] = 0 /*處理器進(jìn)入ARM狀態(tài)*/
/*CPSR[6]保持不變*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff0008
Else
PC = 0x00000008
4.預(yù)取指令異常
預(yù)取指令異常使由系統(tǒng)存儲(chǔ)器報(bào)告的。當(dāng)處理器試圖去取一條被標(biāo)記為預(yù)取無效的指令時(shí),發(fā)生預(yù)取異常。
如果系統(tǒng)中不包含MMU時(shí),指令預(yù)取異常中斷處理程序只是簡單地報(bào)告錯(cuò)誤并退出。若包含MMU,引起異常的指令的物理地址被存儲(chǔ)到內(nèi)存中。
預(yù)取異常發(fā)生時(shí),處理器執(zhí)行下列偽操作。
r14_svc = address of the aborted instruction + 4
SPSR_und = CPSR
CPSR[4∶0] = 0b10111 /*進(jìn)入特權(quán)模式*/
CPSR[5] = 0 /*處理器進(jìn)入ARM狀態(tài)*/
/*CPSR[6]保持不變*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff000C
Else
PC = 0x0000000C
異?;蛑袛嗍怯脩舫绦蛑凶罨镜囊环N執(zhí)行流程和形態(tài)。這部分主要對(duì)ARM架構(gòu)下的異常中斷做詳細(xì)說明。
ARM有7種類型的異常,按優(yōu)先級(jí)從高到低的排列如下:復(fù)位異常(Reset)、數(shù)據(jù)異常(Data Abort)、快速中斷異常(FIQ)、外部中斷異常(IRQ)、預(yù)取異常(Prefetch Abort)、軟件中斷(SWI)和未定義指令異常(Undefined instruction)。

3.4.1 異常種類
ARM體系結(jié)構(gòu)中,存在7種異常處理。當(dāng)異常發(fā)生時(shí),處理器會(huì)把PC設(shè)置為一個(gè)特定的存儲(chǔ)器地址。這一地址放在被稱為向量表(vector table)的特定地址范圍內(nèi)。向量表的入口是一些跳轉(zhuǎn)指令,跳轉(zhuǎn)到專門處理某個(gè)異?;蛑袛嗟淖映绦?。
存儲(chǔ)器映射地址0x00000000是為向量表(一組32位字)保留的。在有些處理器中,向量表可以選擇定位在存儲(chǔ)空間的高地址(從偏移量0xffff0000開始)。一些嵌入式操作系統(tǒng),如Linux和Windows CE就要利用這一特性。
表3.4列出了ARM的7種異常。
表3.4 ARM的7種異常
異 常 類 型處理器模式執(zhí)行低地址執(zhí)行高地址
復(fù)位異常(Reset)特權(quán)模式0x000000000xFFFF0000
未定義指令異常(Undefined interrupt)未定義指令中止模式0x000000040xFFFF0004
軟中斷異常(Software Abort)特權(quán)模式0x000000080xFFFF0008
預(yù)取異常(Prefetch Abort)數(shù)據(jù)訪問中止模式0x0000000C0xFFFF000C
數(shù)據(jù)異常(Data Abort)數(shù)據(jù)訪問中止模式0x000000100xFFFF0010
外部中斷請(qǐng)求IRQ外部中斷請(qǐng)求模式0x000000180xFFFF0018
快速中斷請(qǐng)求FIQ快速中斷請(qǐng)求模式0x0000001C0xFFFF001C
異常處理向量表如圖3.5所示。
當(dāng)異常發(fā)生時(shí),分組寄存器r14和SPSR用于保存處理器狀態(tài),操作偽指令如下。
R14_《exception_mode》 = return link
SPSR_《exception_mode》 = CPSR
CPSR[4∶0] = exception mode number
CPSR[5] = 0 /*進(jìn)入ARM狀態(tài)*/
If 《exception_mode》 = = reset or FIQ then
CPSR[6] = 1 /*屏蔽快速中斷FIQ*/
CPSR[7] = 1 /*屏蔽外部中斷IRQ*/
PC = exception vector address

圖3.5 異常處理向量表
異常返回時(shí),SPSR內(nèi)容恢復(fù)到CPSR,連接寄存器r14的內(nèi)容恢復(fù)到程序計(jì)數(shù)器PC。
1.復(fù)位異常
當(dāng)處理器的復(fù)位引腳有效時(shí),系統(tǒng)產(chǎn)生復(fù)位異常中斷,程序跳轉(zhuǎn)到復(fù)位異常中斷處理程序處執(zhí)行。復(fù)位異常中斷通常用在下面兩種情況下。
· 系統(tǒng)上電。
· 系統(tǒng)復(fù)位。
當(dāng)復(fù)位異常時(shí),系統(tǒng)執(zhí)行下列偽操作。
R14_svc = UNPREDICTABLE value
SPSR_svc = UNPREDICTABLE value
CPSR[4∶0] = 0b10011 /*進(jìn)入特權(quán)模式*/
CPSR[5] = 0 /*處理器進(jìn)入ARM狀態(tài)*/
CPSR[6] = 1 /*禁止快速中斷*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff0000
Else
PC = 0x00000000
復(fù)位異常中斷處理程序?qū)⑦M(jìn)行一些初始化工作,內(nèi)容與具體系統(tǒng)相關(guān)。下面是復(fù)位異常中斷處理程序的主要功能。
· 設(shè)置異常中斷向量表。
· 初始化數(shù)據(jù)棧和寄存器。
· 初始化存儲(chǔ)系統(tǒng),如系統(tǒng)中的MMU等。
· 初始化關(guān)鍵的I/O設(shè)備。
· 使能中斷。
· 處理器切換到合適的模式。
· 初始化C變量,跳轉(zhuǎn)到應(yīng)用程序執(zhí)行。
2.未定義指令異常
當(dāng)ARM處理器執(zhí)行協(xié)處理器指令時(shí),它必須等待一個(gè)外部協(xié)處理器應(yīng)答后,才能真正執(zhí)行這條指令。若協(xié)處理器沒有相應(yīng),則發(fā)生未定義指令異常。
未定義指令異??捎糜谠跊]有物理協(xié)處理器的系統(tǒng)上,對(duì)協(xié)處理器進(jìn)行軟件仿真,或通過軟件仿真實(shí)現(xiàn)指令集擴(kuò)展。例如,在一個(gè)不包含浮點(diǎn)運(yùn)算的系統(tǒng)中,CPU遇到浮點(diǎn)運(yùn)算指令時(shí),將發(fā)生未定義指令異常中斷,在該未定義指令異常中斷的處理程序中可以通過其他指令序列仿真浮點(diǎn)運(yùn)算指令。
仿真功能可以通過下面步驟實(shí)現(xiàn)。
?、?將仿真程序入口地址鏈接到向量表中未定義指令異常中斷入口處(0x00000004或0xffff0004),并保存原來的中斷處理程序。
?、?讀取該未定義指令的bits[27∶24],判斷其是否是一條協(xié)處理器指令。如果bits[27∶24]值為0b1110或0b110x,該指令是一條協(xié)處理器指令;否則,由軟件仿真實(shí)現(xiàn)協(xié)處理器功能,可以同過bits[11∶8]來判斷要仿真的協(xié)處理器功能(類似于SWI異常實(shí)現(xiàn)機(jī)制)。
?、?如果不仿真該未定義指令,程序跳轉(zhuǎn)到原來的未定義指令異常中斷的中斷處理程序執(zhí)行。
當(dāng)未定義異常發(fā)生時(shí),系統(tǒng)執(zhí)行下列的偽操作。
r14_und = address of next instruction after the undefined instruction
SPSR_und = CPSR
CPSR[4∶0] = 0b11011 /*進(jìn)入未定義指令模式*/
CPSR[5] = 0 /*處理器進(jìn)入ARM狀態(tài)*/
/*CPSR[6]保持不變*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff0004
Else
PC = 0x00000004
3.軟中斷SWI
軟中斷異常發(fā)生時(shí),處理器進(jìn)入特權(quán)模式,執(zhí)行一些特權(quán)模式下的操作系統(tǒng)功能。軟中斷異常發(fā)生時(shí),處理器執(zhí)行下列偽操作。
r14_svc = address of next instruction after the SWI instruction
SPSR_und = CPSR
CPSR[4∶0] = 0b10011 /*進(jìn)入特權(quán)模式*/
CPSR[5] = 0 /*處理器進(jìn)入ARM狀態(tài)*/
/*CPSR[6]保持不變*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff0008
Else
PC = 0x00000008
4.預(yù)取指令異常
預(yù)取指令異常使由系統(tǒng)存儲(chǔ)器報(bào)告的。當(dāng)處理器試圖去取一條被標(biāo)記為預(yù)取無效的指令時(shí),發(fā)生預(yù)取異常。
如果系統(tǒng)中不包含MMU時(shí),指令預(yù)取異常中斷處理程序只是簡單地報(bào)告錯(cuò)誤并退出。若包含MMU,引起異常的指令的物理地址被存儲(chǔ)到內(nèi)存中。
預(yù)取異常發(fā)生時(shí),處理器執(zhí)行下列偽操作。
r14_svc = address of the aborted instruction + 4
SPSR_und = CPSR
CPSR[4∶0] = 0b10111 /*進(jìn)入特權(quán)模式*/
CPSR[5] = 0 /*處理器進(jìn)入ARM狀態(tài)*/
/*CPSR[6]保持不變*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff000C
Else
PC = 0x0000000C
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 一文讀懂ARM微處理器指令系統(tǒng) 53次下載
- ARM微處理器的詳細(xì)資料介紹 17次下載
- 嵌入式系統(tǒng)原理及應(yīng)用教程之ARM異常中斷處理及編程的資料說明 7次下載
- 第2章 ARM微處理器的編程模型 3次下載
- ARM微處理器的概述 9次下載
- 基于ARM微處理器的指令系統(tǒng) 5次下載
- Thumb指令集之異常中斷產(chǎn)生指令解析 0次下載
- ARM微處理器編程模型之處理器工作模式解析 2次下載
- ARM體系中的異常中斷及其應(yīng)用 4次下載
- ARM系列微處理器簡介 93次下載
- ARM微處理器的編程模型
- 基于S3C44B0X處理器的VxWorks中斷設(shè)計(jì)
- ARM微處理器體系結(jié)構(gòu)
- ARM/THUMB微處理器結(jié)構(gòu)及指令系統(tǒng)
- ARM微處理器的編程模型
- dsp是嵌入式微處理器的一種設(shè)備嗎 ARM嵌入式微處理器有何特點(diǎn)? 1043次閱讀
- 嵌入式微處理器的原理和應(yīng)用 991次閱讀
- Cortex-M0處理器內(nèi)核異常中斷簡介 4969次閱讀
- ARM異常中斷的原因及處理措施 8162次閱讀
- STM32的Cortex-M3中斷異常處理 8314次閱讀
- 基于ARM異常中斷處理的方法解析 974次閱讀
- 解答arm處理器的七種工作模式 1.6w次閱讀
- 淺談arm處理器的優(yōu)勢 1.2w次閱讀
- 微處理器是cpu嗎?微處理器和cpu的區(qū)別 6.8w次閱讀
- SH-3異常中斷處理方式 SH7709S的應(yīng)用 1258次閱讀
- 淺談ARM處理器的特點(diǎn)和體系結(jié)構(gòu) 1.7w次閱讀
- 對(duì)ARM異常中斷的集中情況進(jìn)行總結(jié),并給出了一些解決方法 6554次閱讀
- ARM S3C4510B系統(tǒng)的異常中斷機(jī)制解析 1799次閱讀
- 基于ARM處理器的高效異常處理解決方案 1424次閱讀
- ARM微處理器的指令的分類與格式 1434次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1490次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關(guān)電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7藍(lán)牙設(shè)備在嵌入式領(lǐng)域的廣泛應(yīng)用
- 0.63 MB | 3次下載 | 免費(fèi)
- 89天練會(huì)電子電路識(shí)圖
- 5.91 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論