在C语言中,在调用一个函数func()时,如果func()接受不超过4个的参数,则调用者直接将实参从左到右依次赋值给r0, r1, r2, r3寄存器(如果是指针则传入地址),然后调用func()。
进入func()函数后,func()将自己的栈紧接着caller的栈顶向下扩展,从r0, r1, r2, r3寄存器中拿参数,然后开始做事。
而如果func()有超过4个参数,例如:
int func(int a, int *b, int c, int d, struct sh_info * e, int f) {}
则前4个参数仍然通过寄存器传递,其余参数e和f则放在栈里面让func()来取。就如下图:
也就是说,caller函数在调用func()之前,将参数e和f放到自己栈顶的位置。在编译阶段caller函数知道在函数栈里为这两个参数留出空间,而func()也根据自己参