栈:栈是一种具有后进先出性质的数据组织方式,也就是说后存放的先取出,先存放的后取出。栈低是第一个进栈的数据所处的位置,栈顶是最后一个进栈的数据所处的位置。
根据SP指针指向的位置,栈可以分为满栈和空栈。
满栈:当堆栈指针SP总是指向最后压入堆栈的数据
空栈:当堆栈指针SP总是指向下一个将要放入数据的孔位置
ARM采用满栈
根据SP指针移动的方向,栈可以分为升栈和降栈
升栈:随着数据的入栈,SP指针从低地址到高地址移动
降栈:随着数据的入栈,SP指针从高地址到低地址移动
ARM采用降栈
栈帧:就是一个函数使用的那部分栈,所有函数的栈帧串
起来就组成了一个完整的栈。栈帧的两个边界分别由fp(r11)
和sp(r13)来界定。
栈的作用:保存局部变量,参数传递,保存寄存器的值。
初始化栈:只需要一行代码,就是给sp指针赋值,2440是64M,6410是256M,210是521M
stack_init: ldr sp, =0x3400000 @6410:0x5400 0000 @210:0x2400 0000 mov pc,lr