栈初始化

栈:栈是一种具有后进先出性质的数据组织方式,也就是说后存放的先取出,先存放的后取出。栈低是第一个进栈的数据所处的位置,栈顶是最后一个进栈的数据所处的位置。

根据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

 

 

原文地址:https://www.cnblogs.com/sanshijvshi/p/8371136.html