原创 ARM汇编的SWI指令软中断

2007-10-31 20:43 5721 8 2 分类: MCU/ 嵌入式

从下面的一个ARM 汇编小程序要弄懂的以下三个问题:


1).在ARM状态转到THUNB状态和BX的应用


2).汇编的架构


3).SWI指令的使用


    AREA ADDREG,CODE,READONLY


    ENTRY


MAIN


  ADR r0,ThunbProg 1 ;(为什么要加1呢?因为BX指令跳转到指定的地址执行程序 时, 若   (BX{cond} Rm)Rm的位[0]为1,则跳转时自动将CPSR中的标志T置位即把目标 代码解释为 Thunb代码)


    BX r0


   CODE16


ThunbProg


   mov r2,#2


    mov r3,#3


    add r2,r2,r3


    ADR r0,ARMProg


    BX ro


    CODE32


ARMProg


    mov r4,#4


    mov r5,#5


    add r4,r4,r5


stop mov r0,#0x18


LDR r1,=0x20026


SWI 0x123456


END


SWI--软中断指令:


SWI指令用于产生软中断,从拥护模式变换到管理模式,CPSR保存到管理模式的SPSR中.


 SWI{cond} immed_24 ;immed_24为软中断号(服务类型)


使用SWI指令时,通常使用以下两种方法进行传递参数,SWI 异常中断处理程序就可以提供相关的服务,这两种方法均是用户软件协定.SWI异常中断处理程序要通过读取引起软中断的SWI指令,以取得24位立即数.


(1) 指令中的24位立即数指定了用户请求的服务类型,参数通过通用寄存器传递.


 mov r0,#34 ;设置子功能号位34


SWI 12 ;调用12号软中断


(2) 指令中的24位立即数被忽略,用户请求的服务类型有寄存器RO的值决定,参数通过其他的通用寄存器传递.


 mov r0,#12 ;调用12号软中断


 mov r1,#34 ;设置子功能号位34


 SWI  0


在SWI异常中断处理程序中,取出SWI立即数的步骤为:首先确定引起软中断的SWI指令是ARM指令还是Thunb指令,这可通过对SPSR访问得到;然后取得该SWI指令的地址,这可通过访问LR寄存器得到;接着读出指令,分解出立即数.如如下程序:


T_bit EQU 0X20


SWI_Handler


STMFD SP!,{R0-R3,R12,LR} ;现场保护


MRS R0,SPSR ;读取SPSR


STMFD SP!,{R0} :保存SPSR


TST R0,#T_bit


LDRNEH R0,[LR,#-2] ;若是Thunb指令,读取指令码(16位)


   BICNE R0,#0XFF00 :取得Thunb指令的8位立即数


   LDREQ R0,[LR,#-4] ;若是ARM指令,读取指令码(32位)


   BICEQ R0,#0XFF000000 ;取得ARM指令的24位立即数


   ....


   LDMFD SP!,{R0-R3,R12,PC}^ ;SWI异常中断返回

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
8
关闭 站长推荐上一条 /3 下一条