找回密码
 注册
关于网站域名变更的通知
查看: 733|回复: 1
打印 上一主题 下一主题

ARM 32位寄存器以及使用说明

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2021-4-28 18:23 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
ARM 32位寄存器2 b; {7 `9 w, Z$ w; b) V" s
ARM汇编器对ARM的寄存器进行了预定义,所有的寄存器和协处理器名都是大小写敏感的.预定义的寄存器如下:

0 ]/ Q/ r9 e& n6 E( Z
  • 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), z1 c, L+ S2 @
& y( n/ A- ^- b  w! X1 Z7 b

) h" @4 L. J2 F! D9 ~
使用说明:
3 L. Y, o/ z2 R8 I- f6 m
1、当参数少于4个时,子程序间通过寄存器R0~R3来传递参数;当参数个数多于4个时,将多余的参数通过数据栈进行传递,入栈顺序与参数顺序正好相反,子程序返回前无需恢复R0~R3的值;
" w, |) q2 s! E2、在子程序中,使用R4~R11保存局部变量,若使用需要入栈保存,子程序返回前需要恢复这些寄存器;R12是临时寄存器,使用不需要保存。
$ o* [6 t7 d, `9 Z% k4 H& N3、R13用作数据帧指针,记作SP;R14用作链接寄存器,记作LR,用于保存子程序返回时的地址;R15是程序计数器,记作PC。
/ t3 y8 i$ M0 I1 f$ r4、ATPCS规定堆栈是满递减堆栈FD; 0 S, X& Y  f1 }
5、子程序返回32位的整数,使用R0返回;返回64位整数时,使用R0返回低位,R1返回高位。
) u& Y2 x- }" V! J; l1 H

' d) J/ W) [, H, U: r  G. W

该用户从未签到

2#
发表于 2021-4-28 18:31 | 只看该作者
ARM 32位寄存器以及使用说明
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-24 10:57 , Processed in 0.156250 second(s), 24 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表