【ARM】異常產生指令

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章