ARM汇编之指令集的切换:ARM切换到Thumb

概念

当使用bx跳转指令,跳到一个奇数地址时,默认跳到这个奇数地址-1的位置,然后标志位T位会置1,表示切换到Thumb指令集,所以我们引出下面这条指令,经常使用它来进行指令集的切换(r3随意,任意寄存器即可,别用特殊寄存器)

add r3, pc, #1

执行这条语句时,PC的值是这条指令时+8的值,这个需要了解PC的取值、译指、执行,如下所示,当处理器执行这条语句时,PC已经加8字节了,也就是当前指令往后数的第二条指令的位置

执行过程

我们完整的切换代码下面这两句,所以根据上面的分析,当执行到add r3, pc, #1这一句的时候,r3存储的是bx r3后面一句指令+1的位置,这个地址成了奇数地址
执行到bx r3,r3存有奇数的内存地址,所以处理器对其进行了减1的操作,然后跳转过去,就刚好跳转到bx r3后面那条指令的位置,程序就继续正常的执行下去。

add r3, pc, #1
bx r3

猜你喜欢

转载自blog.csdn.net/github_38641765/article/details/85208743