函数调用时参数传递规则

ARM函数调用时参数传递规则
之前在学习如何在C语言中嵌入汇编时有了解到C语言之前的参数调用是使用寄存器

R0传递第一个参数,

R1传递到第二个..

一直到R3传递第四个参数.

但是 实际上有时可能传递的参数非常多,超过8个,或是参数中有浮点数之类,参数也会超过4个寄存器,对于超出的部份并不使用R4,而是使用堆栈的方式.

对于ARM体系来说,不同语言撰写的函数之间相互调用(mix calls)遵循的是 ATPCS(ARM-Thumb Procedure Call Standard),ATPCS主要是定义了函数呼叫时参数的传递规则以及如何从函数返回,关于ATPCS的详细内容可以查看ADS1.2 Online Books ——Developer Guide的2.1节。这篇文档要讲的是 汇编代码中对C函数调用时如何进行参数的传递以及如何从C函数正确返回

不同于x86的参数传递规则,ATPCS建议函数的形参不超过4个,如果形参个数少于或等于4,则形参由R0,R1,R2,R3四个寄存器进行传递;若形参个数大于4,大于4的部分必须通过堆栈进行传递。

x86_64函数调用时参数传递规则

x86_64体系架构中函数调用时整数和指针参数按照从左到右的顺序依次保存在寄存器rdi,rsi,rdx,rcx,r8和r9中,浮点型参数保存在寄存器xmm0,xmm1……中。若有更多的参数则按照从右到左的顺序依次压入堆栈。

当使用GDB工具调试C代码时,若使用break function设置断点时,若使用break function_name则断点设置在进入function以及保存完寄存器后的汇编语句上,而使用break *function_name则断点设置在刚刚进入函数的位置上(并没有保存栈帧到堆栈)。

x86下的C函数调用惯例

网址:http://blog.csdn.net/phunxm/article/details/8985321

你可能感兴趣的:(编译原理)