MIPS指令集整理

借此机会,再总结一下前几周理论课学习到的一些MIPS指令集:(主要查询自别处)

【空操作】

nop、ssnop(不能和其他指令同时,至少需要一个时钟周期)

【寄存器间的数据传送指令】

move、movf、movt、movn、movz(后四个为条件传递指令)

【常数加载指令】

dla、la(获取某些标号地址或程序中变量地址的宏指令);

dli、li(加载常数立即数指令);

lui(加载高位立即数指令)

【算术/逻辑操作指令】

addu、addiu、daddu,daddiu(加法指令);

dsub、sub(会触发溢出陷入的减法操作);

dsubu、subu(普通减法指令);

abs、dabs(求绝对值操作);

dneg、neg、dnegu、negu(一元非操作);

and、andi、or、ori、xor、xori、nor、not(按位逻辑指令);

drol、dror、rol、ror(循环左移和右移);

dsll、dsll32、dsllv(64位左移,低位补零);

dsra、dsra32、dsrav(64位算术右移指令);

dsrl、dsrl32、dsrlv(64位逻辑右移指令);

sll、sllv(32位左移指令);sra、srav(32位算术右移指令);

srl、srlv(32位逻辑右移指令);

slt、slti、sltiu、sltu(硬件指令,条件满足就写入1,否则写0);

seq、sge、sgeu、sgt、sgtu、sle、slue、sne(根据更复杂的条件设置目的寄存器的宏指令)

【整数乘法、除法以及求余指令】

ddiv、ddivu、div、divu(整数除法的3操作数宏指令分别处理64位或32位有符号或无符号数);

divo、divou(明确该指令是带有溢出检查的除法指令);

dmul、mul(3操作数64位或32位乘法指令,没有溢出检查);

mulo、mulou、dmulo、dumlou(乘法宏指令,如果结果不能存入一个通用寄存器,发生溢出,触发异常);

dmult、dmultu、mult、multu(执行有符号/无符号32/64位乘法的机器指令);

drem、dremu、rem、remu(求余操作);

mfhi、mflo、mthi、mtlo(用于访问整数乘除单元的结果寄存器hi和lo)

【存取指令(内存访问指令】

lb、lbu(加载一个字节,高位可以补零,或进行符号扩展,以补充整个寄存器的长度);

ld(加载一个双字);

ldl、ldr、lwl、lwr、sdl、sdr、swl、swr(向左、向右加载、存储一个字、双字);

lh、lhu(加载一个半字,高位可以补零,或进行符号扩展,以补充整个寄存器的长度);

lw、lwu(加载一个字);

pref、prefx(把数据预取到缓冲);

sb、sd、sh、sw(存储字节、双字、半字、字);

uld、ulh、ulhu、ulw、usd、usw、ush(地址非对齐的数据存取宏指令);

l.d、l.s、s.d、s.s(存取双精度和单精度浮点数的指令,地址必须对齐);

ldxcl、lwxcl、sdxcl、swxcl(采用基址寄存器+偏移寄存器的寻址方式存取指令);

【跳转、分支和子程序调用指令】

j(无条件跳转到一个绝对地址,访问256M的代码空间);

jal、jalr(直接或间接子程序调用,这种跳转不仅能跳转到指定地址,而且可以顺便把返回地址(当前指令地址+8)放到ra寄存器中);

b(基于当前指令地址的无条件相对跳转);

bal(基于当前地址的函数调用指令);

bc0f、bc0f1、bc0t、bc0t1、bc2f、bc2f1、bc2t、bc2t1(根据协处理器0和2的条件标志进行跳转);

bc1f、bc1f1、bc1t、bc1t1(根据浮点条件标志位进行跳转);

beq、beq1、beqz、beqz1、bge、bge1、bgeu、bgeu1、bgez、bgez1、bgt、bgt1、bgtu、bgtu1、bgtz、bgtz1、ble、ble1、bleu、bleu1、blez、blez1、blt、blt1、bltu、bltu1、bltz、bltz1、bne、bnel、bnez、bnezl(双操作数和单操作数的比较跳转指令);

bgeza1、bgeza11、bltza1、bltza11(如果需要 ,这些指令是用于有条件函数调用的原始机器指令);

【断点及陷阱指令】

break(产生一个“断点”类型的异常);

sdbbp(产生EJTAG异常的断点指令);

syscall(产生一个约定用于系统调用的异常类型);

teq、teqi、tge、tgei、tgeiu、tgeu、tlt、tlti、tltiu、tltu、tne、tnei(条件异常指令,对一个或两个操作数进行条件测试);

【协处理器0的功能】

cfc0、ctc0(把数据拷进和拷出协处理器0的控制寄存器);

mfc0、mtc0、dmfc0、dmtc0(在通用寄存器和协处理器0寄存器之间交换数据);

cfc2、ctc2、dmfc2、dmtc2、mfc2、mtc2(协处理器2的指令);

posted on 2015-04-20 19:54  我就是那只嵩鼠  阅读(11804)  评论(0编辑  收藏  举报

导航