EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM 32位寄存器
9 c5 ?& X9 Q- W9 Z+ O+ DARM汇编器对ARM的寄存器进行了预定义,所有的寄存器和协处理器名都是大小写敏感的.预定义的寄存器如下: - u+ D( |5 Z+ m5 U, Y
- Ro-R15和r0-r15
- a1-a4(参数,结果或者临时寄存器,与r0-r3同意)
- v1-v8(变量寄存器,与r4-r11同意)
- sb和SB(静态基址寄存器,与r9同意)
- sl和SL(堆栈限制寄存器,与r10同意)
- fp和FP(帧指针,与r11同意)
- ip和IP(过程调用中间临时寄存器,与r12同意)
- sp和SP(堆栈指针,与r13同意)
- lr和LR(连接寄存器,与r14同意)
- pc和PC(程序计数器,与r15同意)
- cpsr和CPSR(程序状态寄存器)
- spsr和SPSR(程序状态寄存器)
- f0-f7和F0-F7(FPA寄存器)
- s0-s31和S0-S31(VFP单精度寄存器)
- d0-d15和D0-D15(VFP双精度寄存器)
- p0-p15(协处理器0-15)
- c0-c15(协处理器寄存器0-15), s! _; B |6 D5 V: S7 N) w. o
* l$ Z( y* q( }- j. s8 {( D
7 x$ M6 k3 Y( H1 Y2 n: N, p* W使用说明: 1 L4 r. V7 V' v1 \# F: _, k
1、当参数少于4个时,子程序间通过寄存器R0~R3来传递参数;当参数个数多于4个时,将多余的参数通过数据栈进行传递,入栈顺序与参数顺序正好相反,子程序返回前无需恢复R0~R3的值; 4 y- M$ p9 C8 _2 V
2、在子程序中,使用R4~R11保存局部变量,若使用需要入栈保存,子程序返回前需要恢复这些寄存器;R12是临时寄存器,使用不需要保存。 . Z3 y, p* o* t$ u1 l3 K
3、R13用作数据帧指针,记作SP;R14用作链接寄存器,记作LR,用于保存子程序返回时的地址;R15是程序计数器,记作PC。 / |1 u3 l& k' Y9 V. r, d4 K
4、ATPCS规定堆栈是满递减堆栈FD; * T3 u0 u" m( Y( K* N5 U& v
5、子程序返回32位的整数,使用R0返回;返回64位整数时,使用R0返回低位,R1返回高位。 1 w+ h* e: ]9 q, v( R% B* P
+ j1 L6 p! Y$ z4 J8 ] |