1:在arm和C的相互调用中,R0,R1,R2,R3是默认的参数1,参数2,参数3,参数4的存放寄存器。其余的参数存在堆栈中,系统会自动的调用。
这个规则对于C调用汇编,或者汇编调用C都同样有效。一开始我还以为只是汇编调用C的时候是这样的。
2:汇编调用C语言
starts.s
IMPORT ADDF
AREA FCC,CODE,READONLY
ENTRY
start
MOV R0,#1
MOV R1,#2
MOV R2,#3
MOV R3,#4
MOV R4,#5
MOV R5,#6
;STMFD SP!,{r0-r5} 注意如果是多个参数都入栈的话,其实取的时候并不是按照你预期的那样的,可以单步看看就明白
STMFD SP!,{R4,R5}
BL ADDD
Stop
b Stop
END
ADDD.c //这几个名称貌似还得一样
int ADDD(int a,int b,int c,int d,int e,int f)
{
int h = a+b+c+d+e+f+m+n;
return h;
}
3:C调用汇编
main.c
extern int addd(int a,int b,int c,int d,int e,int f);
main()
{
int a = 1;
int b = 2;
int c = 3;
int d = 4;
int e = 5;
int f = 6;
add1(a,b,c,d,e,f);
while(1);
}
starts.s
;此时汇编中的entry不能再加了,不能有两个函数入口
;书上写的是__main,而这边直接写的是main(),直接写的话,编译器会自动生成相关的__main的代码
;传递参数的堆栈一般是FD
AREA CC,CODE,READONLY
EXPORT addd
add1
LDMFD SP!,{R4,R5}
ADD R0,R0,R1
ADD R0,R0,R2
ADD R0,R0,R3
ADD R0,R0,R4
ADD R0,R0,R5
MOV PC,LR
END