Date: 2018.9.20


1、X86 函数调用约定

X86 有三种常用调用约定,cdecl(C规范)/stdcall(WinAPI默认)/fastcall 函数调用约定。详细可参考:

函数调用协议__cdecl,__fastcall,__stdcall。

其中:

  1. Cdecl调用规范:参数从右往左一次入栈,调用者实现栈平衡,返回值存放在 EAX 中。
  2. stdcall调用规范:参数从右往左一次入栈,被调用者实现栈平衡,返回值存放在 EAX 中。
  3. fastcall调用规范:参数1、参数2分别保存在 ECX、EDX ,剩下的参数从右往左一次入栈,被调用者实现栈平衡,返回值存放在 EAX 中。

2、X64函数调用约定

X64只有一种 fastcall 函数调用约定。

参数1、参数2、参数3、参数4分别保存在 RCX、RDX、R8D、R9D ,剩下的参数从右往左一次入栈,被调用者实现栈平衡,返回值存放在 RAX 中。

3、arm32函数调用约定

arm32位调用约定采用ATPCS。

参数1~参数4 分别保存到 R0~R3 寄存器中 ,剩下的参数从右往左一次入栈,被调用者实现栈平衡,返回值存放在 R0 中。

4、arm64函数调用约定

arm64位调用约定采用AAPCS64。

参数1~参数8 分别保存到 X0~X7 寄存器中 ,剩下的参数从右往左一次入栈,被调用者实现栈平衡,返回值存放在 X0 中。

详细的调用规则分析可以采用IDA静态反汇编软件进行分析和查看。

参考:


THE END!