当前位置:   article > 正文

mips指令学习_mips64 jr ra

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

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

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号