mips指令学习

本文深入探讨MIPS指令集中的关键指令,如运算指令、访存指令、分支和跳转等,通过具体实例展示了如何使用这些指令进行栈帧操作、数据加载及跳转控制。此外,还介绍了MIPS指令集在64位系统中的特殊应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

func
	daddiu sp, sp, -64	//通过加法建立栈帧
	lui v0, 0x815a	//bit[31]为1,如果内核态是64位的话,那么如果bit[31]为1,则将高32位扩展为ffffffff, 也就是说对于64位系统来说,该值为0xffffffff815a0000
	sd ra, 56(sp) //将调用者的返回值压栈
	lw v1, 30880(v1) //30880=0x78a0, 该语句与第二条语句结合来看就是ffffffff815a0000+78a0=ffffffff815a78a0, 其中 cat Sysmap 可以得知全局结构体变量xxx为ffffffff815a7840, 所以该语句的含义是将全局结构体变量的域成员(偏移96字节)放到v1寄存器里面
	
	... ...
	
	ld ra, 56(sp)	
	jr ra	//该语句和后面一条语句在一条流水线里面,跳转指令执行完之后,恢复栈帧的指令也会执行完毕
	radaddiu sp, sp, 64
	nop
	

MIPS指令集:运算指令、访存指令、分支和跳转、协处理器0指令
https://blog.youkuaiyun.com/weixin_38669561/article/details/104445763

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值