mips架构特点
- MIPS32 架构中是没有 EBP 寄存器的,程序函数调用的时候是将当前栈指针向下移动 n 比特到该函数的 stack frame 存储组空间,函数返回的时候再加上偏移量恢复栈
- 传参过程中,前四个参数a0−a3,多余的会保存在调用函数的预留的栈顶空间内
- 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”)分别来进行访问对应的内容
栈的走向是从高地址到低地址