当前位置: 技术问答>linux和unix
ARM过程调用规范规定的编译器设计问题
来源: 互联网 发布时间:2017-05-11
本文导语: 看ARM 过程调用规范里面, 只是规定了C函数调用的时候需要用到R0,R1,R2...等寄存器,但是并没有规定哪一个寄存器存第几个形参 , 请问这些 具体的规定放在了哪里呢? | 对...
看ARM 过程调用规范里面, 只是规定了C函数调用的时候需要用到R0,R1,R2...等寄存器,但是并没有规定哪一个寄存器存第几个形参 , 请问这些 具体的规定放在了哪里呢?
|
对于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的参数传递规则,ATPCS建议函数的形参不超过4个,如果形参个数少于或等于4,则形参由R0,R1,R2,R3四个寄存器进行传递;若形参个数大于4,大于4的部分必须通过堆栈进行传递,即压栈.