ARM微處理器的編程模型之:異常中斷處理
3.4 異常中斷處理
異?;蛑袛嗍怯脩舫绦蛑凶罨镜囊环N執(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í)行流程,進入特定程序循環(huán)的一種機制。 |
3.4.1 異常種類
ARM體系結(jié)構(gòu)中,存在7種異常處理。當(dāng)異常發(fā)生時,處理器會把PC設(shè)置為一個特定的存儲器地址。這一地址放在被稱為向量表(vector table)的特定地址范圍內(nèi)。向量表的入口是一些跳轉(zhuǎn)指令,跳轉(zhuǎn)到專門處理某個異常或中斷的子程序。
存儲器映射地址0x00000000是為向量表(一組32位字)保留的。在有些處理器中,向量表可以選擇定位在存儲空間的高地址(從偏移量0xffff0000開始)。一些嵌入式操作系統(tǒng),如Linux和Windows CE就要利用這一特性。
表3.4列出了ARM的7種異常。
表3.4 ARM的7種異常
異 常 類 型 | 處理器模式 | 執(zhí)行低地址 | 執(zhí)行高地址 |
復(fù)位異常(Reset) | 特權(quán)模式 | 0x00000000 | 0xFFFF0000 |
未定義指令異常(Undefined interrupt) | 未定義指令中止模式 | 0x00000004 | 0xFFFF0004 |
軟中斷異常(Software Abort) | 特權(quán)模式 | 0x00000008 | 0xFFFF0008 |
預(yù)取異常(Prefetch Abort) | 數(shù)據(jù)訪問中止模式 | 0x0000000C | 0xFFFF000C |
數(shù)據(jù)異常(Data Abort) | 數(shù)據(jù)訪問中止模式 | 0x00000010 | 0xFFFF0010 |
外部中斷請求IRQ | 外部中斷請求模式 | 0x00000018 | 0xFFFF0018 |
快速中斷請求FIQ | 快速中斷請求模式 | 0x0000001C | 0xFFFF001C |
異常處理向量表如圖3.5所示。
當(dāng)異常發(fā)生時,分組寄存器r14和SPSR用于保存處理器狀態(tài),操作偽指令如下。
R14_exception_mode> = return link
SPSR_exception_mode> = CPSR
CPSR[4∶0] = exception mode number
CPSR[5] = 0 /*進入ARM狀態(tài)*/
If exception_mode> = = reset or FIQ then
CPSR[6] = 1 /*屏蔽快速中斷FIQ*/
CPSR[7] = 1 /*屏蔽外部中斷IRQ*/
PC = exception vector address
圖3.5 異常處理向量表
異常返回時,SPSR內(nèi)容恢復(fù)到CPSR,連接寄存器r14的內(nèi)容恢復(fù)到程序計數(shù)器PC。
1.復(fù)位異常
當(dāng)處理器的復(fù)位引腳有效時,系統(tǒng)產(chǎn)生復(fù)位異常中斷,程序跳轉(zhuǎn)到復(fù)位異常中斷處理程序處執(zhí)行。復(fù)位異常中斷通常用在下面兩種情況下。
· 系統(tǒng)上電。
· 系統(tǒng)復(fù)位。
當(dāng)復(fù)位異常時,系統(tǒng)執(zhí)行下列偽操作。
R14_svc = UNPREDICTABLE value
SPSR_svc = UNPREDICTABLE value
CPSR[4∶0] = 0b10011 /*進入特權(quán)模式*/
CPSR[5] = 0 /*處理器進入ARM狀態(tài)*/
CPSR[6] = 1 /*禁止快速中斷*/
CPSR[7] = 1 /*禁止外設(shè)中斷*/
If high vectors configured then
PC = 0xffff0000
Else
PC = 0x00000000
評論