ARM 汇编与C之间的函数调用需求契合ATPCS,主张函数的形参不超越4个,假如形参个数少于或等于4,则形参由R0,R1,R2,R3四个寄存器进行传递;若形参个数大于4,大于4的部分有必要经过仓库进行传递。
R0 用来寄存函数的第一个参数,R1用来寄存第二个参数,R2用来寄存第三个参数,R3用来寄存第四个参数。其间R0还用来回来函数的调用成果,对应C函数里边的return value句子中的value 寄存在R0中。
ARM仓库的是满栈FULL STACK,SP指针指向的方位是寄存有用数据的当地,若压栈新的数据,有必要先改动SP,再向SP里边压入数据。下面结合博客http://blog.sina.com.cn/s/blog_3e5694650100tsbf.html,的内容进行剖析。
情形(一)函数形参的个数<= 4
test_asm_args.asm
test_asm_args
void test_c_args(int a,int b,int c,int d)
{
}
int main()
{
}
情形二:函数的参数是8个
test_asm_args.asm
//——————————————————————————–
IMPORT test_c_args ;声明test_c_args函数
AREA TEST_ASM, CODE, READONLY
EXPORT test_asm_args
test_asm_args
STR lr, [sp, #-4]! ;保存当时lr
ldr r0,=0x1 ;参数 1
ldr r1,=0x2 ;参数 2
ldr r2,=0x3 ;参数 3
ldr r3,=0x4 ;参数 4
ldr r4,=0x8
str r4,[sp,#-4]! ;参数 8 入栈
ldr r4,=0x7
str r4,[sp,#-4]! ;参数 7 入栈
ldr r4,=0x6
str r4,[sp,#-4]! ;参数 6 入栈
ldr r4,=0x5
str r4,[sp,#-4]! ;参数 5 入栈
bl test_c_args_lots
ADD sp, sp, #4 ;铲除栈中参数 5,本句子履行完后sp指向参数6
ADD sp, sp, #4 ;铲除栈中参数 6,本句子履行完后sp指向参数7
ADD sp, sp, #4 ;铲除栈中参数 7,本句子履行完后sp指向参数8
ADD sp, sp, #4 ;铲除栈中参数 8,本句子履行完后sp指向 lr
LDR pc, [sp],#4 ;将lr装进pc(回来main函数)
END
test_c_args.c
//——————————————————————————–
void test_c_args(int a,int b,int c,int d,int e,int f,int g,int h)
{
printk(“test_c_args_lots:\n”);
printk(“%0x %0x %0x %0x %0x %0x %0x %0x\n”,
a,b,c,d,e,f,g,h);
}
main.c
//——————————————————————————–
int main()
{
test_asm_args();
for(;;);
}