MIT 6.1810: Lec 5: calling conventions and stack frames RISC-V

RISC-V vs x86

不同处理器使用的指令集(ISA, Instruction Sets Architecture) 不同

RISC-V (Reduced Instruction Set Computer 精简指令集)

x86是一种CISC (Complex Instruction Set Computer 复杂指令集)

RISC-V x86
e.g. SiFive Intel
指令数量 40+条基础指令+模块化扩展可达数百条 1500+(向后兼容,历史发展中并未下线任何指令)
指令内容 简单工作 一系列复杂操作
开源 闭源
ARM同样也是一个RISC
Android支持ARM, x86(主流设备是ARM)
IOS运行在Apple自研的ARM架构处理器上

gdb instructions

tui enable 打开图形界面

layout asm 显示汇编代码

layout reg 显示寄存器信息

layout split 显示源码和汇编代码

info reg / i reg 打印寄存器信息

delete / d 删除所有断点

i frame / info frame 打印stack frame有关信息

bt / backtrace 打印从当前调用栈开始所有stack frame (如果要查看其中某个栈 frame 3 i frame)

watch i 当i的值改变时打印相关信息

RISC-V registers

Caller 寄存器在函数调用时不会 保存 (e.g. ra return address)

Callee 寄存器在函数调用时被保存

Stack

函数每次被调用时,会给自己创建一个stack frame

stack从高地址开始向低地址使用,向下增长

return address 总是会出现在stack frame的第一位

To Prev. Frame 指向前一个栈的指针会出现在栈中可预测的位置

两个重要寄存器:SP(stack pointer) 指向stack底部代表当前stack frame的位置,FP(Frame Pointer) 指向stack顶部,可用于寻址return address & To Prev. Frame

相关推荐
LinXunFeng1 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
闪闪发亮的小星星6 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq6 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波6 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.6 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余6 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.6 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央6 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器6 天前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记