Thumb汇编指令练习

前面2个都是ARM汇编指令,这个是Thumb,最大的区别就是一个是32位的,一个是16位的,Thumb状态下的寄存器集的子集这个还是慢慢在领会和ARM汇编之间的区别吧,在编写Thumb指令时,先要使用伪指令CODE16声明,而且,在ARM指令中要使用BX指令跳转到Thumb指令,以切换处理器状态。编写ARM指令时,则可使用伪指令CODE32声明。

先看程序:

;第一段
	AREA	EXAMPLE3,CODE,READONLY
	ENTRY
MAIN
	ADR		R0,THUMBPROG+1;
这里为啥要加1呢,主要是因为:
n(1)当操作数寄存器的状态位(位[0])为1时,执行BX指令进入Thumb状态。如果处理器在Thumb状态进入异常,则当异常处理(IRQ、FIQ、Undef、Abort和SWI)返回时,自动转换到Thumb状态。
n(2)当操作数寄存器的状态位(位[0])为0时,执行BX指令进入ARM状态,处理器进行异常处理(IRQ、FIQ、Reset、Undef、Abort和SWI)。在此情况下,把PC放入异常模式链接寄存器中。从异常向量地址开始执行也可以进入ARM状态。
 
	BX		R0          		;跳转到THUMBPROG,并且程序切换到Thumb状态
;第二段
	CODE16			      		;指示下面为Thumb指令
THUMBPROG
	MOV		R2,#2
	MOV		R3,#3
	ADD		R2,R2,R3
;切换到ARM汇编指令
	ADR		R0,ARMPROG
	BX		R0 		          	;跳转到ARMPROG,并且程序切换到ARM状态
;第三段
	CODE32        			 	;指示下面为Arm指令
ARMPROG
	MOV		R4,#4
	MOV		R5,#5
	ADD		R4,R4,R5
;第四段
STOP
	MOV		R0,#0X18
	LDR		R1,=0X20026
	SWI		0X123456		    ;通过SWI功能调用,报告程序结束
	END

又学会一条新指令,

LDR     R1,=0X20026;这个就是将立即数0x20026存入到寄存器R1中。

    SWI     0X123456            ;通过SWI功能调用,报告程序结束

 上面这条指令到时还没找到说明之处。只说这个是软件中断指令,

然后对应着这个软件中断有个中断向量表,入口地址是0x08,

0x08  b HandlerSWI

跳转到HandlerSWI这个函数入口地址,这中间有个功能号传递的,这个功能号就是在进入了软件中断的服务函数里面选择对应于功能号的选项功能。

这个暂时先这样把,如果高手看到我发的贴,那请解答,谢谢,非常感谢!

原文地址:https://www.cnblogs.com/tao560532/p/2277620.html