EDA365电子论坛网
标题:
ARM64位寄存器以及注意事项
[打印本页]
作者:
uperrua
时间:
2021-5-19 13:59
标题:
ARM64位寄存器以及注意事项
ARM64位参数调用规则遵循AAPCS64,规定堆栈为满递减堆栈。
9 _( b+ O0 u6 G, f f
寄存器调用规则如下:
y3 \) z! K* u5 [
- X0~X7:用于传递子程序参数和结果,使用时不需要保存,多余参数采用堆栈传递,64位返回结果采用X0表示,128位返回结果采用X1:X0表示。
' h T3 J) I' p" Z
- X8:用于保存子程序返回地址, 尽量不要使用 。
2 l. B2 e9 m) ?- e
- X9~X15:临时寄存器,使用时不需要保存。
9 |+ n: N4 M$ e
- X16~X17:子程序内部调用寄存器,使用时不需要保存,尽量不要使用。
# n* u1 Y" W1 D; Q* H
- X18:平台寄存器,它的使用与平台相关,尽量不要使用。
" ], J' q. M6 H3 v- e% Z+ N
- X19~X28:临时寄存器,使用时必须保存。
% @2 i& r9 U- ]. e5 t
- X29:帧指针寄存器,用于连接栈帧,使用时需要保存。
I u, u$ k* i8 |7 ^
- X30:链接寄存器LR
4 M8 E0 `2 R! q) C- v$ ?7 F
- X31:堆栈指针寄存器SP或零寄存器ZXR
3 e( [& }5 J: y _
9 L4 v4 P* k1 ~9 u8 K
注意:
- t" h/ f4 Y$ s- m
子程序调用时必须要保存的寄存器:X19~X29和SP(X31)。
; |% A$ c% G, L% c( R! O
不需要保存的寄存器:X0~X7,X9~X15
# m( J x: c+ r- ^' Q/ s( @2 ^6 r, f
作者:
ExxNEN
时间:
2021-5-19 15:22
ARM64位寄存器以及注意事项
作者:
SsaaM7
时间:
2021-5-19 16:27
ARM64位寄存器以及注意事项
作者:
SpencerJ2
时间:
2021-5-19 16:29
ARM64位寄存器以及注意事项
欢迎光临 EDA365电子论坛网 (https://bbs.eda365.com/)
Powered by Discuz! X3.2