資料介紹
3.4 異常中斷處理
異常或中斷是用戶程序中最基本的一種執(zhí)行流程和形態(tài)。這部分主要對ARM架構(gòu)下的異常中斷做詳細(xì)說明。
ARM有7種類型的異常,按優(yōu)先級從高到低的排列如下:復(fù)位異常(Reset)、數(shù)據(jù)異常(Data Abort)、快速中斷異常(FIQ)、外部中斷異常(IRQ)、預(yù)取異常(Prefetch Abort)、軟件中斷(SWI)和未定義指令異常(Undefined instruction)。
注意在ARM文檔中,使用術(shù)語Exception來描述異常。Exception主要是從處理器被動接受異常的角度出發(fā),而Interrupt帶有向處理器主動申請的色彩。在本書中,對“異常”和“中斷”不做嚴(yán)格區(qū)分,兩者都是指請求處理器打斷正常的程序執(zhí)行流程,進(jìn)入特定程序循環(huán)的一種機(jī)制。
3.4.1 異常種類
ARM體系結(jié)構(gòu)中,存在7種異常處理。當(dāng)異常發(fā)生時(shí),處理器會把PC設(shè)置為一個(gè)特定的存儲器地址。這一地址放在被稱為向量表(vector table)的特定地址范圍內(nèi)。向量表的入口是一些跳轉(zhuǎn)指令,跳轉(zhuǎn)到專門處理某個(gè)異常或中斷的子程序。
存儲器映射地址0x00000000是為向量表(一組32位字)保留的。在有些處理器中,向量表可以選擇定位在存儲空間的高地址(從偏移量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
外部中斷請求IRQ外部中斷請求模式0x000000180xFFFF0018
快速中斷請求FIQ快速中斷請求模式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ù)棧和寄存器。
· 初始化存儲系統(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)上,對協(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)存儲器報(bào)告的。當(dāng)處理器試圖去取一條被標(biāo)記為預(yù)取無效的指令時(shí),發(fā)生預(yù)取異常。
如果系統(tǒng)中不包含MMU時(shí),指令預(yù)取異常中斷處理程序只是簡單地報(bào)告錯(cuò)誤并退出。若包含MMU,引起異常的指令的物理地址被存儲到內(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
異常或中斷是用戶程序中最基本的一種執(zhí)行流程和形態(tài)。這部分主要對ARM架構(gòu)下的異常中斷做詳細(xì)說明。
ARM有7種類型的異常,按優(yōu)先級從高到低的排列如下:復(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í),處理器會把PC設(shè)置為一個(gè)特定的存儲器地址。這一地址放在被稱為向量表(vector table)的特定地址范圍內(nèi)。向量表的入口是一些跳轉(zhuǎn)指令,跳轉(zhuǎn)到專門處理某個(gè)異常或中斷的子程序。
存儲器映射地址0x00000000是為向量表(一組32位字)保留的。在有些處理器中,向量表可以選擇定位在存儲空間的高地址(從偏移量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
外部中斷請求IRQ外部中斷請求模式0x000000180xFFFF0018
快速中斷請求FIQ快速中斷請求模式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ù)棧和寄存器。
· 初始化存儲系統(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)上,對協(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)存儲器報(bào)告的。當(dāng)處理器試圖去取一條被標(biāo)記為預(yù)取無效的指令時(shí),發(fā)生預(yù)取異常。
如果系統(tǒng)中不包含MMU時(shí),指令預(yù)取異常中斷處理程序只是簡單地報(bào)告錯(cuò)誤并退出。若包含MMU,引起異常的指令的物理地址被存儲到內(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微处理器指令系统53次下载
- ARM微处理器的详细资料介绍17次下载
- 嵌入式系统原理及应用教程之ARM异常中断处理及编程的资料说明7次下载
- 第2章 ARM微处理器的编程模型3次下载
- ARM微处理器的概述9次下载
- Thumb指令集之异常中断产生指令解析0次下载
- ARM微处理器编程模型之处理器工作模式解析2次下载
- ARM体系中的异常中断及其应用4次下载
- ARM系列微处理器简介93次下载
- ARM微处理器的指令系统教材 PPT70次下载
- ARM微处理器的编程模型50次下载
- 基于S3C44B0X处理器的VxWorks中断设计17次下载
- ARM微处理器体系结构42次下载
- ARM/THUMB微处理器结构及指令系统33次下载
- ARM微处理器的编程模型382次下载
- dsp是嵌入式微处理器的一种设备吗 ARM嵌入式微处理器有何特点?1402次阅读
- 嵌入式微处理器的原理和应用1323次阅读
- Cortex-M0处理器内核异常中断简介5486次阅读
- ARM异常中断的原因及处理措施8528次阅读
- STM32的Cortex-M3中断异常处理8654次阅读
- 基于ARM异常中断处理的方法解析1066次阅读
- 解答arm处理器的七种工作模式17321次阅读
- 微处理器是cpu吗?微处理器和cpu的区别69252次阅读
- SH-3异常中断处理方式 SH7709S的应用1362次阅读
- 浅谈ARM处理器的特点和体系结构17927次阅读
- 对ARM异常中断的集中情况进行总结,并给出了一些解决方法6760次阅读
- ARM S3C4510B系统的异常中断机制解析1913次阅读
- 基于ARM处理器的高效异常处理解决方案1571次阅读
- ARM单片机三种中断返回情况的分析与解决1444次阅读
- ARM微处理器的指令的分类与格式1500次阅读
下載排行
本周
- 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筆記本電腦主板的元件識別和講解說明
- 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天練會電子電路識圖
- 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é)會AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評論