ARM匯編的SWI指令軟中斷
1).在ARM狀態(tài)轉(zhuǎn)到THUNB狀態(tài)和BX的應(yīng)用
本文引用地址:http://2s4d.com/article/201611/316759.htm2).匯編的架構(gòu)
3).SWI指令的使用
AREA ADDREG,CO
ENTRY
MAIN
ADR r0,ThunbProg 1 ;(為什么要加1呢?因?yàn)锽X指令跳轉(zhuǎn)到指定的地址執(zhí)行程序 時(shí), 若 (BX{cond} Rm)Rm的位[0]為1,則跳轉(zhuǎn)時(shí)自動(dòng)將CPSR中的標(biāo)志T置位即把目標(biāo) 代碼解釋為 Thunb代碼)
BX r0
CO
ThunbProg
mov r2,#2
mov r3,#3
add r2,r2,r3
ADR r0,ARMProg
BX ro
CO
ARMProg
mov r4,#4
mov r5,#5
add r4,r4,r5
stop mov r0,#0x18
LDR r1,=0x20026
SWI 0x123456
END
SWI--軟中斷指令:
SWI指令用于產(chǎn)生軟中斷,從擁護(hù)模式變換到管理模式,CPSR保存到管理模式的SPSR中.
SWI{cond} immed_24 ;immed_24為軟中斷號(hào)(服務(wù)類型)
使用SWI指令時(shí),通常使用以下兩種方法進(jìn)行傳遞參數(shù),SWI 異常中斷處理程序就可以提供相關(guān)的服務(wù),這兩種方法均是用戶軟件協(xié)定.SWI異常中斷處理程序要通過讀取引起軟中斷的SWI指令,以取得24位立即數(shù).
(1) 指令中的24位立即數(shù)指定了用戶請求的服務(wù)類型,參數(shù)通過通用寄存器傳遞.
mov r0,#34 ;設(shè)置子功能號(hào)位34
SWI 12 ;調(diào)用12號(hào)軟中斷
(2) 指令中的24位立即數(shù)被忽略,用戶請求的服務(wù)類型有寄存器RO的值決定,參數(shù)通過其他的通用寄存器傳遞.
mov r0,#12 ;調(diào)用12號(hào)軟中斷
mov r1,#34 ;設(shè)置子功能號(hào)位34
SWI ?。?/p>
在SWI異常中斷處理程序中,取出SWI立即數(shù)的步驟為:首先確定引起軟中斷的SWI指令是ARM指令還是Thunb指令,這可通過對(duì)SPSR訪問得到;然后取得該SWI指令的地址,這可通過訪問LR寄存器得到;接著讀出指令,分解出立即數(shù).如如下程序:
T_bit EQU 0X20
SWI_Handler
STMFD SP!,{R0-R3,R12,LR} ;現(xiàn)場保護(hù)
MRS R0,SPSR ;讀取SPSR
STMFD SP!,{R0} :保存SPSR
TST R0,#T_bit
LDRNEH R0,[LR,#-2] ;若是Thunb指令,讀取指令碼(16位)
BICNE R0,#0XFF00 :取得Thunb指令的8位立即數(shù)
LDREQ R0,[LR,#-4] ;若是ARM指令,讀取指令碼(32位)
BICEQ R0,#0XFF000000 ;取得ARM指令的24位立即數(shù)
....
LDMFD SP!,{R0-R3,R12,PC}^ ;SWI異常中斷返回
評(píng)論