ARM 匯編與C調(diào)用的若干問題(一般函數(shù)調(diào)用情況)
R0 用來(lái)存放函數(shù)的第一個(gè)參數(shù),R1用來(lái)存放第二個(gè)參數(shù),R2用來(lái)存放第三個(gè)參數(shù),R3用來(lái)存放第四個(gè)參數(shù)。其中R0還用來(lái)返回函數(shù)的調(diào)用結(jié)果,對(duì)應(yīng)C函數(shù)里面的return value語(yǔ)句中的value 存放在R0中。
本文引用地址:http://cafeforensic.com/article/201611/316825.htmARM堆棧的是滿棧FULL STACK,SP指針指向的位置是存放有效數(shù)據(jù)的地方,若壓棧新的數(shù)據(jù),必須先改變SP,再向SP里面壓入數(shù)據(jù)。下面結(jié)合博客http://blog.sina.com.cn/s/blog_3e5694650100tsbf.html,的內(nèi)容進(jìn)行分析。
情景(一)函數(shù)形參的個(gè)數(shù)<= 4
test_asm_args.asm
test_asm_args
void test_c_args(int a,int b,int c,int d)
{
}
int main()
{
}
情景二:函數(shù)的參數(shù)是8個(gè)
test_asm_args.asm
//--------------------------------------------------------------------------------
IMPORT test_c_args ;聲明test_c_args函數(shù)
AREA TEST_ASM, CODE, READONLY
EXPORT test_asm_args
test_asm_args
STR lr, [sp, #-4]! ;保存當(dāng)前l(fā)r
ldr r0,=0x1 ;參數(shù) 1
ldr r1,=0x2 ;參數(shù) 2
ldr r2,=0x3 ;參數(shù) 3
ldr r3,=0x4 ;參數(shù) 4
ldr r4,=0x8
str r4,[sp,#-4]! ;參數(shù) 8 入棧
ldr r4,=0x7
str r4,[sp,#-4]! ;參數(shù) 7 入棧
ldr r4,=0x6
str r4,[sp,#-4]! ;參數(shù) 6 入棧
ldr r4,=0x5
str r4,[sp,#-4]! ;參數(shù) 5 入棧
bl test_c_args_lots
ADD sp, sp, #4 ;清除棧中參數(shù) 5,本語(yǔ)句執(zhí)行完后sp指向參數(shù)6
ADD sp, sp, #4 ;清除棧中參數(shù) 6,本語(yǔ)句執(zhí)行完后sp指向參數(shù)7
ADD sp, sp, #4 ;清除棧中參數(shù) 7,本語(yǔ)句執(zhí)行完后sp指向參數(shù)8
ADD sp, sp, #4 ;清除棧中參數(shù) 8,本語(yǔ)句執(zhí)行完后sp指向 lr
LDR pc, [sp],#4 ;將lr裝進(jìn)pc(返回main函數(shù))
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 %0xn",
a,b,c,d,e,f,g,h);
}
main.c
//--------------------------------------------------------------------------------
int main()
{
test_asm_args();
for(;;);
}
評(píng)論