Thumb指令集之: ARM和Thumb的混合编程

时间:2013-09-30来源:网络

指令的语法格式为:

BLXRm>

其中Rm>为目标地址寄存器,r0~r14寄存器均可以作为目标地址寄存器。

注意

如果在此指令中使用r15作为目的寄存器,指令的执行结果不可预知。

此指令只在ARMv5版本以上指令集中被支持。

指令操作的伪代码为:

LR=(addressoftheinstructionafterthisBLX)|1

TFlag=Rm[0]

PC=Rm[31:1]1

(3)汇编伪指令

汇编编译器可以产生ARM代码也可以产生Thumb代码。使用--thumb或--16选项指示编译器产生Thumb代码。由于所有支持Thumb代码的ARM处理器都从ARM状态开始执行,所以必须人为地使用BX或BLX指令,使处理器状态切换到Thumb状态并使用下面的伪操作使编译器产生Thumb代码。

·CODE16

·CODE32

CODE32伪操作指示汇编器后面的指令为32位的ARM指令。

ARM和CODE32伪操作的意义相同。

当汇编器对源程序进行编译时,如果需要,将会在程序中插入空指令,以保证内存单元字对齐。

语法格式如下。

ARM

CODE32

使用在同时包含ARM指令和Thumb指令的源文件中。当需要从ARM指令序列切换到Thumb指令序列时,使用伪操作ARM(或CODE32);当需要从Thumb指令序列切换到ARM指令序列时使用Thumb伪操作。ARM(或CODE32)伪操作只是指示汇编器后面的指令类型是ARM指令。该伪操作本身并不进行程序状态的切换,要进行状态切换,可以使用BX指令操作。

CODE16伪指令通知编译器,其后的指令序列为16位的Thumb指令。

语法格式如下。

CODE16

若在汇编源程序中同时包含ARM指令和Thumb指令时,可用CODE16伪指令通知编译器其后的指令序列为16位的Thumb指令。

(4)编程实例

PRESERVE8

AREAAddReg,CODE,READONLY ;段名为AddReg,属性为READONLY

ENTRY ;程序入口

;SECTION1

main

ADRr0,ThumbProg+1 ;确定跳转地址

;并将bit[0]置1

;使程序切换到thumb状态

BXr0 ;程序跳转并执行状态切换

;SECTION2

CODE16 ;Thumb代码指示伪操作

ThumbProg

MOVr2,#2 ;r2=2

MOVr3,#3 ;r2=3

ADDr2,r2,r3 ;r2=r2+r3

ADRr0,ARMProg

BXr0 ;程序跳转并执行状态切换

;SECTION3

CODE32 ;ARM代码指示伪操作

ARMProg

MOVr4,#4

MOVr5,#5

ADDr4,r4,r5

;SECTION4

stopMOVr0,#0x18 ;设置semihosting软中断号

LDRr1,=0x20026 ;ADP_Stopped_ApplicationExit

SWI0x123456 ;ARMsemihostingSWI软中断调用

END ;文件结束

1 2 3 4 5 6

关键词: Thumb指令集 ARM 混合编程 Veneer AAPCS

加入微信
获取电子行业最新资讯
搜索微信公众号:EEPW

或用微信扫描左侧二维码

相关文章

查看电脑版