【arm】ARM寄存器以及使用说明

版权声明:本文为博主原创文章,未经博主允许不得转载。若允许转载,请注明来源https://blog.csdn.net/SoaringLee_fighting,否则保留追究法律责任的权利! https://blog.csdn.net/SoaringLee_fighting/article/details/81287824

Date: 2018.7.30


1、参考

http://blog.chinaunix.net/uid-20321537-id-1966791.html
https://www.cnblogs.com/summer-xwq/p/4153624.html
https://blog.csdn.net/smalosnail/article/details/53048784

2、ARM 32位寄存器

ARM汇编器对ARM的寄存器进行了预定义,所有的寄存器和协处理器名都是大小写敏感的.预定义的寄存器如下:

  1. Ro-R15和r0-r15
  2. a1-a4(参数,结果或者临时寄存器,与r0-r3同意)
  3. v1-v8(变量寄存器,与r4-r11同意)
  4. sb和SB(静态基址寄存器,与r9同意)
  5. sl和SL(堆栈限制寄存器,与r10同意)
  6. fp和FP(帧指针,与r11同意)
  7. ip和IP(过程调用中间临时寄存器,与r12同意)
  8. sp和SP(堆栈指针,与r13同意)
  9. lr和LR(连接寄存器,与r14同意)
  10. pc和PC(程序计数器,与r15同意)
  11. cpsr和CPSR(程序状态寄存器)
  12. spsr和SPSR(程序状态寄存器)
  13. f0-f7和F0-F7(FPA寄存器)
  14. s0-s31和S0-S31(VFP单精度寄存器)
  15. d0-d15和D0-D15(VFP双精度寄存器)
  16. p0-p15(协处理器0-15)
  17. c0-c15(协处理器寄存器0-15)

使用说明:
1、当参数少于4个时,子程序间通过寄存器R0~R3来传递参数;当参数个数多于4个时,将多余的参数通过数据栈进行传递,入栈顺序与参数顺序正好相反,子程序返回前无需恢复R0~R3的值;
2、在子程序中,使用R4~R11保存局部变量,若使用需要入栈保存,子程序返回前需要恢复这些寄存器;R12是临时寄存器,使用不需要保存。
3、R13用作数据帧指针,记作SP;R14用作链接寄存器,记作LR,用于保存子程序返回时的地址;R15是程序计数器,记作PC。
4、ATPCS规定堆栈是满递减堆栈FD;
5、子程序返回32位的整数,使用R0返回;返回64位整数时,使用R0返回低位,R1返回高位。

3、ARM64位寄存器

ARM64位参数调用规则遵循AAPCS64,规定堆栈为满递减堆栈。
寄存器调用规则如下:
- X0~X7:用于传递子程序参数和结果,使用时不需要保存,多余参数采用堆栈传递,64位返回结果采用X0表示,128位返回结果采用X1:X0表示。
- X8:用于保存子程序返回地址, 尽量不要使用 。
- X9~X15:临时寄存器,使用时不需要保存。
- X16~X17:子程序内部调用寄存器,使用时不需要保存,尽量不要使用。
- X18:平台寄存器,它的使用与平台相关,尽量不要使用。
- X19~X28:临时寄存器,使用时必须保存。
- X29:帧指针寄存器,用于连接栈帧,使用时需要保存。
- X30:链接寄存器LR
- X31:堆栈指针寄存器SP或零寄存器ZXR
参考自: http://infocenter.arm.com/help/topic/com.arm.doc.ihi0055b/IHI0055B_aapcs64.pdf 5.1.1小节。

注意:
子程序调用时必须要保存的寄存器:X19~X29和SP(X31)。
不需要保存的寄存器:X0~X7,X9~X15


THE END!

猜你喜欢

转载自blog.csdn.net/SoaringLee_fighting/article/details/81287824