x64 linux c 调用约定

《x86/x64体系探索及编程》中提到x64下只有一种调用约定,分别使用ecx,edx,edi,esi,r8d,r9d

浮点数使用xmm0。。。。

c代码:

#include "stdio.h"
#include "string.h"
void pp(int a,int b,int c,int d,int e,int f, int g, int h ,int i,int j)
{}
void main(){
        pp(1,2,3,4,5,6,7,8,9,0);
}

main函数的反汇编代码。

Dump of assembler code for function main:
   0x000000000040048e <+0>:     push   rbp
   0x000000000040048f <+1>:     mov    rbp,rsp
   0x0000000000400492 <+4>:     sub    rsp,0x20
   0x0000000000400496 <+8>:     mov    DWORD PTR [rsp+0x18],0x0
   0x000000000040049e <+16>:    mov    DWORD PTR [rsp+0x10],0x9
   0x00000000004004a6 <+24>:    mov    DWORD PTR [rsp+0x8],0x8
   0x00000000004004ae <+32>:    mov    DWORD PTR [rsp],0x7
   0x00000000004004b5 <+39>:    mov    r9d,0x6
   0x00000000004004bb <+45>:    mov    r8d,0x5
   0x00000000004004c1 <+51>:    mov    ecx,0x4
   0x00000000004004c6 <+56>:    mov    edx,0x3
   0x00000000004004cb <+61>:    mov    esi,0x2
   0x00000000004004d0 <+66>:    mov    edi,0x1
   0x00000000004004d5 <+71>:    call   0x400474 <pp>
   0x00000000004004da <+76>:    leave
   0x00000000004004db <+77>:    ret

有汇编代码可知,gcc x64调用参数顺序为edi,esi,edx,ecx,r8d,r9d,edi为第一个参数esi为第二个参数,以此类推,剩下的参数使用栈来传递。

本文出自 “Backtrack-Metasploit” 博客,请务必保留此出处http://backtrackzone.blog.51cto.com/5612649/1662287

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。