00. 目錄
01. 異常產生指令概述
ARM 指令集中提供了兩條產生異常的指令,通過這兩條指令可以用軟件的方法實現異常。如表 3-15 所示爲 ARM 異常產生指令。
02. 軟件中斷指令
軟件中斷指令(Software Interrupt,SWI)用於產生軟中斷,從而實現從用戶模式變換到管理模式,CPSR 保存到管理模式的 SPSR 中,執行轉移到 SWI 向量,在其他模式下也可以使用 SWI 指令,處理器同樣切換到管理模式。
2.1 指令的語法格式
SWI{<cond>} <immed_24>
2.2 應用示例
① 下面指令產生軟中斷,中斷立即數爲 0。
SWI 0;
② 產生軟中斷,中斷立即數爲 0x123456。
SWI 0x123456;
③ 使用 SWI 指令時,通常使用以下兩種方法進行參數傳遞。
指令 24 位的立即數指定了用戶請求的類型,中斷服務程序的參數通過寄存器傳遞。
@ 下面的程序產生一箇中斷號爲 12 的軟中斷。
MOV R0,#34 ;設置功能號爲 34
SWI 12 ;產生軟中斷,中斷號爲 12
另一種情況,指令中的 24 位立即數被忽略,用戶請求的服務類型由寄存器 R0 的值決定,參數通過其他寄存器傳遞。
@ 下面的例子通過 R0 傳遞中斷號,R1 傳遞中斷的子功能號。
MOV R0,#12 ;設置 12 號軟中斷
MOV R1,#34 ;設置功能號爲 34
SWI 0
03. 附錄
11.1 ARM Architecture Reference Manual