ARM之栈与方法

ARM之栈与方法

计算机中的栈是一种线性表,它被限定只能在一端进行插入和删除操作(先进后出)。通常将可以插入和删除操作的一端称为栈顶,相对的一端为栈底。

通常栈有递增堆栈(向高地址方向生长)、递减堆栈(向低地址方向生长)、满堆栈(堆栈指针指向最后压入堆栈的有效数据项)和空堆栈(堆栈指针指向下一个要放入的空位置)。

ARM堆栈与计算机中的栈类似,都具有先进后出和递减满堆栈特点。在调用函数时用于保存一些临时数据。

ARM堆栈从高地址向低地址入栈、从低地址向高地址出栈,SP指向栈顶的元素,其他的元素通过SP+offset获取。

栈帧

栈帧包括:

参数区:存放调用函数传递的参数;

连接区:存放调用者的下一条指令;

栈帧指针存放区:存放调用函数的栈帧的底部;

寄存器存储区:被调用函数返回需要恢复的寄存器内容;

局部存储区:存放被调用函数的局部变量;

寄存器

关于寄存器(从计算机内存结构到iOS)。

函数调用会开辟栈帧,在AArch64中,函数参数通过x0~x7传递(小数通过d0和d1传递)。

关于函数堆栈有:

PC(Program Counter)寄存器:用于记录执行代码的地址;

FP(Frame Pointer)寄存器:指向栈帧的底部(x29);

LR(Link Register)寄存器:指向返回地址(x30);

SP(Stack Pointer)寄存器:指向栈帧指针(x31);

函数调用流程

一. 函数调用前

  1. 开辟栈帧空间;
  2. 保存FP和LR寄存器(可以找到上一个栈帧和返回地址);
  3. 设置新的FP寄存器;
  4. 保存子函数会用到的寄存器;
  5. 保存局部变量或参数;
    二. 函数调用结束
  6. 还原FP和LR寄存器;
  7. 释放栈帧空间;
  8. 跳到LR子程序返回;
相关推荐
prinrf('千寻)17 分钟前
MyBatis-Plus 的 updateById 方法不更新 null 值属性的问题
java·开发语言·mybatis
香蕉可乐荷包蛋22 分钟前
浅入ES5、ES6(ES2015)、ES2023(ES14)版本对比,及使用建议---ES6就够用(个人觉得)
前端·javascript·es6
m0_5557629027 分钟前
Qt缓动曲线详解
开发语言·qt
未来之窗软件服务1 小时前
资源管理器必要性———仙盟创梦IDE
前端·javascript·ide·仙盟创梦ide
揽你·入怀1 小时前
数据结构:ArrayList简单实现与常见操作实例详解
java·开发语言
AA-代码批发V哥2 小时前
Math工具类全面指南
java·开发语言·数学建模
Nobkins2 小时前
2021ICPC四川省赛个人补题ABDHKLM
开发语言·数据结构·c++·算法·图论
十八年的好汉2 小时前
buck变换器的simulink/matlab仿真和python参数设计
开发语言·matlab
88号技师2 小时前
2025年6月一区SCI-不实野燕麦优化算法Animated Oat Optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
我不是程序猿儿2 小时前
【C#】Thread.Join()、异步等待和直接join
开发语言·c#