mips架构汇编指令

mips架构特点

  1. MIPS32 架构中是没有 EBP 寄存器的,程序函数调用的时候是将当前栈指针向下移动 n 比特到该函数的 stack frame 存储组空间,函数返回的时候再加上偏移量恢复栈
  2. 传参过程中,前四个参数a0−a3,多余的会保存在调用函数的预留的栈顶空间内
  3. MIPS 调用函数时会把函数的返回地址直接存入ra 寄存器

数据类型

所有MIPS指令都是32位长的
各单位:1字节=8位,半字长=2个字节,1字长=4个字节
一个字符空间=1个字节
一个整型=一个字长=4个字节
单个字符用单引号,例如:‘b’
字符串用双引号,例如:“A string”

寄存器(Registers)

MIPS下一共有32个通用寄存器
在汇编中,寄存器标志由$符开头
寄存器表示可以有两种方式

  • 直接使用该寄存器对应的编号,例如:从$0到$31
  • 使用对应的寄存器名称,例如:$t1, $sp

对于乘法和除法分别有对应的两个寄存器$lo, $hi
对于以上二者,不存在直接寻址;必须要通过mfhi(“move from hi”)以及mflo(“move from lo”)分别来进行访问对应的内容
栈的走向是从高地址到低地址

寄存器用途

mips架构汇编指令

汇编指令详解

  1. MIPS架构及其汇编初步
  2. mipsel汇编指令学习
  3. MIPS指令学习二
上一篇:MIPS多周期CPU设计实现(40条指令)


下一篇:【汇编语言与计算机系统结构笔记01】x86/MIPS/ARM指令集概述与特性,一篇HPCA引发的思考(商业生态的决定性作用)