|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM64位参数调用规则遵循AAPCS64,规定堆栈为满递减堆栈。 0 r" J; [4 z# S7 x3 Y
寄存器调用规则如下: 7 G' l1 E3 E. ^9 M7 N. D4 n% C
- X0~X7:用于传递子程序参数和结果,使用时不需要保存,多余参数采用堆栈传递,64位返回结果采用X0表示,128位返回结果采用X1:X0表示。
x' [& e( S# f& Q; d- X8:用于保存子程序返回地址, 尽量不要使用 。 + u( G# Y, J1 [9 m
- X9~X15:临时寄存器,使用时不需要保存。
) }, c8 P; z! h8 L2 ~0 \- X16~X17:子程序内部调用寄存器,使用时不需要保存,尽量不要使用。 1 x f. Z; p( T# n0 ] Q6 O
- X18:平台寄存器,它的使用与平台相关,尽量不要使用。
. l \& d& h2 @8 B- [& L" Z- X19~X28:临时寄存器,使用时必须保存。
0 T) x- F/ c$ i6 D" u4 }0 U- X29:帧指针寄存器,用于连接栈帧,使用时需要保存。
9 F6 s. \6 V! Y. M# Y5 P' Z- X30:链接寄存器LR
! u4 A9 F5 e1 }! }- X31:堆栈指针寄存器SP或零寄存器ZXR 8 S* y5 J5 v2 s) `9 r0 l' s
, ?" L9 i6 X. l& P注意:
( j# b Z0 Q% C4 c8 H( b( h3 L# x子程序调用时必须要保存的寄存器:X19~X29和SP(X31)。
/ j8 d7 d% G& l" {. N; @. y不需要保存的寄存器:X0~X7,X9~X15" z' `+ V( |2 u
|
|