|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM64位参数调用规则遵循AAPCS64,规定堆栈为满递减堆栈。
. l: I% g8 r8 l寄存器调用规则如下:
$ Z4 X9 B4 w8 E+ c- X0~X7:用于传递子程序参数和结果,使用时不需要保存,多余参数采用堆栈传递,64位返回结果采用X0表示,128位返回结果采用X1:X0表示。 . B x7 g7 ~ S6 N8 U: Y' J) g
- X8:用于保存子程序返回地址, 尽量不要使用 。
$ c% V7 M, P) {" Q+ j; ~+ i- X9~X15:临时寄存器,使用时不需要保存。
5 T& `: c4 l5 w& C: F- X16~X17:子程序内部调用寄存器,使用时不需要保存,尽量不要使用。
% n# k0 |$ _- f9 I6 A1 D _9 q- X18:平台寄存器,它的使用与平台相关,尽量不要使用。 + R6 s3 v7 O; m# {: Y5 y6 h. w
- X19~X28:临时寄存器,使用时必须保存。 : o: l( @9 m3 P$ q. H
- X29:帧指针寄存器,用于连接栈帧,使用时需要保存。 & e9 E# @- q$ l" Z0 D$ N
- X30:链接寄存器LR
+ O* t7 ]% k% m# ~- X31:堆栈指针寄存器SP或零寄存器ZXR ( A3 | z) t! R4 V9 S0 ^2 e1 X' M( _
; c) R& o8 U# F6 a& j7 k) W, a u注意: " ~; u& Q6 m, c$ A9 j- o5 [
子程序调用时必须要保存的寄存器:X19~X29和SP(X31)。
, |; _" e7 Q" Q% [0 k不需要保存的寄存器:X0~X7,X9~X154 c: [& u" l$ t, ^
|
|