背景
突然好奇x86架构下函数参数怎么传递的,之前只是听别人说过通过寄存器,但是怎么传,什么顺序都没有仔细研究过,也没有实际测试过,因此就想着用实践来检验一下咯。
传参顺序
在32位和64位机器上,寄存器名称不同,64位机器为rxx,32位机器为exx。传参顺序如下,
64位系统有16个寄存器,32位系统只有8个。e开头的寄存器命名依然可以直接运用于相应寄存器的低32位。而剩下的寄存器名则是从r8 - r15,其低位分别用d,w,b指定长度。
测试程序
我们通过简单的程序编译后,使用gdb反汇编看下参数传入是否和上面描述的相符合。
先看看32位程序是怎么传递参数的,
#include
static int test32(int arg1, int arg2, int arg3, int arg4,int arg5,
int arg6, int arg7, int arg8)
{
return 0;
}
int main(void)
{
test32(1, 2, 3, 4, 5, 6, 7, 8);
return 0;
}
将函数入参设置成8个,使用gdb反汇编观察参数具体传递情况。
[root@CentOS-7-2 /home/register]# gcc -g -m32 test.c -o t