微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > ARM汇编的SWI指令软中断

ARM汇编的SWI指令软中断

时间:11-11 来源:互联网 点击:
从下面的一个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异常中断返回

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top