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

相关推荐
上课不要睡觉了2 小时前
【统计法规】4.1统计管理体制概述
笔记·统计师考试
墨白曦煜2 小时前
算法实战笔记:剥开回溯算法的外衣——从通用模板到高阶去重(八)
笔记·算法
Upsy-Daisy3 小时前
IOTA 学习笔记(四):当前 IOTA 架构总览
笔记·学习·架构
山楂树の4 小时前
JS中??和||的区别
笔记
U盘失踪了4 小时前
Browser Use — AI驱动浏览器自动化的全新范式
笔记·自动化
疯狂打码的少年4 小时前
Cache的三种映射方式(直接/全相联/组相联)
linux·服务器·数据库·笔记
RainCity5 小时前
Java Swing 自定义组件库分享(十)
java·笔记·后端
FakeOccupational5 小时前
【数学 代数学】无理数:\sqrt2和\pi 是无理数的证明 + 无理数集合的“非正则”性质(暂记)
笔记
是小王同学啊~6 小时前
Kafka 面试通关笔记:高频八股 + 生产实战 + 追问链路(上)
笔记·面试·kafka