照例先上一段原文:
按照《ARM 架构应用程序调用规范》(Arm Architecture Procedure Calling Standard, AAPCS)
ARM的16个通用寄存器,部分有约定的用法:
R0~R3:函数调用时的前四个参数。R0为第一个参数、R1为第二个参数、R2为第三个参数、R3为第四个参数;
R0~R1:函数返回时,存放函数返回值。当返回值的长度小于32位时,放在R0中,当返回值的长度超过32位不超过64位时,低32位放在R0,高32位放在R1。
R13(SP):栈顶寄存器,指向栈顶元素的地址(此处要注意:是栈顶元素,不是栈顶元素的下一个)
R14(LR):链接寄存器(函数返回地址)。指向函数(子程序)返回时的地址。ARM的函数调用指令(如:BL ),默认会将函数返回地址放入R14
R15(PC):程序计数器。指向将要取指的地址。
R9(SB、TR)、R11(FP)、R12(IP),看起来好像也有约定的用法,但是没太看懂要怎么用,如果有这方面的专家,欢迎留言指教。
剩下的寄存器,没有约定用法。
以上的约定用法,除了(PC、SP、LR),我个人理解,是用来约束编译器的,即:
当你通过汇编去调用一个C的函数,当这个函数参数不超过4个时,就通过R0~R3来传递;函数返回后,通过R0~R1获取返回值。
当C去调用一个汇编函数时,也一样,C会把参数放到R0~R3,函数返回后读取R0和R1来获取返回值。
当然你如果自己写汇编函数,自己调用,不跟C语言产生关系,当然可以不遵守上述约定,但是:
为了代码风格一致,避免不必要的麻烦,强烈建议遵守。
参考文档: