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

ARM64位寄存器以及注意事项

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2021-5-19 13:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

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

x
ARM64位参数调用规则遵循AAPCS64,规定堆栈为满递减堆栈。 7 ]' j9 a$ p  l3 g. f
寄存器调用规则如下: 2 W4 C9 W" h0 O4 ~4 o
- X0~X7:用于传递子程序参数和结果,使用时不需要保存,多余参数采用堆栈传递,64位返回结果采用X0表示,128位返回结果采用X1:X0表示。
3 t7 u- d* Z! S" {8 v/ W) i- X8:用于保存子程序返回地址, 尽量不要使用 。
: r5 c9 Y6 v' b* r. y+ D  O; v5 V- X9~X15:临时寄存器,使用时不需要保存。
+ y! }3 f7 M5 u" ~% r- |- X16~X17:子程序内部调用寄存器,使用时不需要保存,尽量不要使用。
' `$ D" V. ^1 P$ C- X18:平台寄存器,它的使用与平台相关,尽量不要使用。
8 I/ j# M! {. g- s* M) I9 C' R- X19~X28:临时寄存器,使用时必须保存。 ! L, h- H$ A/ \4 H/ w
- X29:帧指针寄存器,用于连接栈帧,使用时需要保存。 " R: u+ Z* ^# C. S
- X30:链接寄存器LR
) S4 n( a6 B  n/ e0 |0 C- X31:堆栈指针寄存器SP或零寄存器ZXR - Z9 o$ j1 n7 f- ^  G, U
. M  v( ]& I: J; C9 e4 u8 R
注意:
" ~- D0 j3 b. k$ l; X子程序调用时必须要保存的寄存器:X19~X29和SP(X31)。
8 l8 K. U+ G" q4 B9 U- a' r  ~& h" l不需要保存的寄存器:X0~X7,X9~X15
$ A6 h: b/ u" e& h) S- W7 r' G- I$ d

该用户从未签到

2#
发表于 2021-5-19 15:22 | 只看该作者
ARM64位寄存器以及注意事项

该用户从未签到

3#
发表于 2021-5-19 16:27 | 只看该作者
ARM64位寄存器以及注意事项

该用户从未签到

4#
发表于 2021-5-19 16:29 | 只看该作者
ARM64位寄存器以及注意事项
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-6-23 04:32 , Processed in 0.093750 second(s), 23 queries , Gzip On.

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

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

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