【ARM】异常产生指令
生活随笔
收集整理的這篇文章主要介紹了
【ARM】异常产生指令
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
00. 目錄
文章目錄
- 00. 目錄
- 01. 異常產生指令概述
- 02. 軟件中斷指令
- 2.1 指令的語法格式
- 2.2 應用示例
- 03. 附錄
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 003. 附錄
11.1 ARM Architecture Reference Manual
總結
以上是生活随笔為你收集整理的【ARM】异常产生指令的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【ARM】协处理器指令
- 下一篇: 【ARM】ARM其它指令