ARM與Thumb狀態切換及其代碼分析
ARM與Thumb之間的狀態切換通過專用的轉移交換指令BX來實現。BX指令以通用寄存器(R0~R15)為操作數,通過拷貝Rn到PC實現絕對跳轉。BX利用Rn寄存器中目的地址值的最后一位判斷跳轉后的狀態。
下面是一段直接進行狀態切換的代碼:
CODE32 ;程序從ARM狀態開始
ADR r0, ThumbProg+1 ;跳轉到ThumbProg
BX r0 ;程序切換到Thumb狀態
CODE16 ;Code16指示編譯器后面為Thumb指令
ThumbProg
MOV r2, #2
MOV r3, #3
ADD r2, r2, r3
ADR r0, ARMProg
BX r0 ;跳轉到ARMProg,程序切換到ARM狀態
CODE32 ;code32指示編譯器后面為ARM指令
ARMProg
MOV r4, #4
MOV r5, #5
ADD r4, r4, r5


評論