arm寄存器

参考http://blog.csdn.net/mtk_kyle/article/details/2215239

 

通用寄存器R0-R14

 

R0-R3别名a1-a4,参数,结果或暂存寄存器

R4-R11别名v1-v8,变量寄存器

R10别名SL

R11别名FP

R12别名IP

R13别名SP(stack pointer)栈指针寄存器。用于存放堆栈的栈顶地址的。32位的ARM没有专门的入栈和出栈指令,所以并不是一定要用sp来作为栈指针寄存器,除了PC外,任何普通寄存器可作为栈指针寄存器。

R14别名LR(Linked register)链接寄存器,与子程序调用密切相关,用于存放子程序的返回地址,是ARM程序实现子程序调用的关键所在。LR是专门用于存放子程序返回地址的。


 

专用寄存器

CPSR,当前程序状态寄存器CPSR(current program status register),于用保存当前程序状态。

 

CPSR在任何处理器模式下都可以被访问。其结构如下:

  31 30 29 28  ---   7   6   -   4   3   2   1   0
  N  Z  C  V         I   F       M4  M3  M2  M1  M0

N(Negative)、Z(Zero)、C(Carry)以及V(oVerflow)称为条件标志位。ARM指令根据CPSR的条件标志位来选择地执行。

CPSR条件标志位
=======================================================================================
条件标志位                   含义
------------------------------------------------------------------------------------------------------------
N                            N=1 表示运算结果为负数,N=0 表示运算结果为正数。               
Z                            Z=1 表示运算结果为0, Z=0 表示运算结果为非零。
C                            C=1 表示运算结果产生了进位。
V                            V=1 运算结果的符号位发生了溢出。
Q                            在ARMv5 E系列版本中Q=1 表示DSP指令溢出。
                             在ARMv5以前的版本中没有Q标志位。
=======================================================================================
以下指令会影响CPSR的条件标志位
(1)比较指令,如: CMP、CMN、TEQ、TST等。
(2)当一些算术逻辑运算的目标寄存器不是PC时,这些指令会影响CPSR的条件标志位。
(3)MSR与MRS指令可以对CPSR/SPSR进行操作。
(4)LDM指令可以将SPSR复制到CPSR中。

SPSR,保存程序状态寄存器(Saved Program Status Register)。在异常发生时,由硬件自动将异常发生前的CPSR的值放到SPSR中。异常处理程序结束后恢复原来的CPSR值。SPSR的结构与CPSR的结构相同,SPSR是用来备份CPSR的。

 

R15别名PC(program counter)它的值是当前正在执行的指令在内存中的位置,而当指令执行结束后,CPU硬件会自动将PC值加上一个单位,从而使得PC值为下一条即将执行的指令在中的位置,这样CPU硬件就可以根据PC值自动完成取指操作。对于汇编编程而言,可以通过汇编指令完成对PC寄存器的赋值操作,这样就完成了一次无条件跳转。由于ARM采用流水机制执行指令,故PC寄存器总是存储下一条指令的地址。

 

你可能感兴趣的:(ARM)