环境及代码介绍
环境和源码
由于有时候要透彻的理解C里面的一些细节问题,所有有必要看看汇编,首先这一切的开始就是从汇编代码进入C的main函数过程。这里不使用编译器自动生成的这部分汇编代码,因为编译器自动生成的代码会涉及环境变量的传递,参数的传递等等一系列问题。以ARM汇编来进行分析。使用一个启动汇编文件和一个main.c的文件,在ARM 2440板子上调试这段程序,使用JLinkExe借助jlink来调试:
init.s:
1 .text2 .global _start3 _start:
4 ldr sp,=4096 @设置堆栈指针以便调用C函数
5 bl main6 loop:
7 b loop
main.c:
1 void main(void)2 {3 }
为什么main函数没有使用 int main(int argc,char **argv) 这种形式?因为我这里是使用的自己写的启动汇编文件,由它来完成从汇编到C代码的进入。
寄存器介绍
ARM在任何一种模式下,都可以访问16个通用寄存器(R0-R15)和1-2个状态寄存器(CPSR,SPSR),只是有些寄存器是每种模式下都共用的(R0-R7),另外一些是同名但是使用的是不同硬件单元(其他,每种模式下有所不同)。这里的寄存器有些有特定用途:
R15--PC:程序计数器,指向要取指的那条指令
R14--LR:链接寄存器,保存发生跳转时,下一条指令的地址,方便使用BL跳回
R13--SP:堆栈指针
R12--IP:暂存SP值
R11--FP: 保存堆栈frame的地址