|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM64位参数调用规则遵循AAPCS64,规定堆栈为满递减堆栈。 - J4 ?; Y7 D/ [
寄存器调用规则如下: _+ O$ C* m5 E. t. t/ |
- X0~X7:用于传递子程序参数和结果,使用时不需要保存,多余参数采用堆栈传递,64位返回结果采用X0表示,128位返回结果采用X1:X0表示。 6 }, O( |0 o( C: V; o7 h
- X8:用于保存子程序返回地址, 尽量不要使用 。
6 N3 [, \/ {# |- X9~X15:临时寄存器,使用时不需要保存。
1 A1 L/ O, Y0 X' ]- X16~X17:子程序内部调用寄存器,使用时不需要保存,尽量不要使用。 ' O, N+ V. G' ?
- X18:平台寄存器,它的使用与平台相关,尽量不要使用。
6 t7 z/ ?& E' B$ n$ }- X19~X28:临时寄存器,使用时必须保存。 6 O- x( ?& P6 A- p
- X29:帧指针寄存器,用于连接栈帧,使用时需要保存。 6 U6 T6 P4 \8 }
- X30:链接寄存器LR $ m( u% v2 s" H* n) E: C5 ?
- X31:堆栈指针寄存器SP或零寄存器ZXR
( {" A# s3 s, R$ N1 A& W$ i1 f& {3 D) z3 I2 z! [$ k {
注意: * Q9 l7 \6 \. H% P3 k' S0 i* m3 \
子程序调用时必须要保存的寄存器:X19~X29和SP(X31)。 ) y1 r% m; e1 J. o! ]8 m
不需要保存的寄存器:X0~X7,X9~X150 ~$ u4 {: h' Q+ J
|
|