在系统学习ARM寄存器结构和功能之前,有必要先了解一下ARM的工作模式和工作状态。
一、 ARM的工作状态
两种状态为:
- ARM状态(32位)
- Thumb状态(16位)
用BX Rn指令来进行两种状态的切换:
其中BX是跳转指令,Rn是寄存器,如果Rn的位0为1(最低位),则进入Thumb状态;如果Rn的位为0,这进入ARM状态。(ARM指令的后两位始终为0,没有被使用;而Thumb指令的后一位始终为0,没有被使用,因此采用位0来表示ARM指令与Thumb指令的切换标志位。)
例如下面两个指令就可以实现从ARM状态切换到Thumb状态,第一条指令将r6寄存器最低位置为1,接着 bx r6
就切换到了Thumb状态。
……
0x00008cfc <+12>: add r6, pc, #1
0x00008d00 <+16>: bx r6
0x00008d04 <+20