|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM64位参数调用规则遵循AAPCS64,规定堆栈为满递减堆栈。
6 M* d# a5 w" h: G0 J寄存器调用规则如下: * S' d( K5 Y1 F% d/ b! a& }
- X0~X7:用于传递子程序参数和结果,使用时不需要保存,多余参数采用堆栈传递,64位返回结果采用X0表示,128位返回结果采用X1:X0表示。
+ g! z4 D' c! _* }: B9 i* M/ o# ]- X8:用于保存子程序返回地址, 尽量不要使用 。
5 H' z" Y5 _* f1 }: e- X9~X15:临时寄存器,使用时不需要保存。
; Y5 W% b5 @. g1 O- X16~X17:子程序内部调用寄存器,使用时不需要保存,尽量不要使用。 7 b) N5 G: i* K2 y" }$ p
- X18:平台寄存器,它的使用与平台相关,尽量不要使用。 : v' f, b, I9 {$ P
- X19~X28:临时寄存器,使用时必须保存。
( \# _) M, F- _0 @' t9 e8 S- X29:帧指针寄存器,用于连接栈帧,使用时需要保存。
5 V- m, }3 ~- c0 h& D- X30:链接寄存器LR % b% G7 {) R# Y& K8 D; O
- X31:堆栈指针寄存器SP或零寄存器ZXR
3 S$ g- W9 o' F) v/ a b, V# p. }: _0 Q# x$ t* A
注意:
$ u+ i( q' j+ c; z' U子程序调用时必须要保存的寄存器:X19~X29和SP(X31)。
. J% P7 M, F& ^- e$ q0 Z" _不需要保存的寄存器:X0~X7,X9~X15
6 h* L7 o0 @# x% {9 H# O# G |
|