草庐IT

MIPS指令详解

比奇堡咻飞囵 2023-07-09 原文

目录

一.R型指令

(1)R型指令格式

000000 (op)RsRtRdshamtfunct
6bits5bits5bits5bits5bits6bits

注意: 该类型指令操作数和保存结果均通过寄存器进行。

操作含义
op操作码,所有R型指令都全为0
rs寄存器编号,对应第一个源操作数
rt寄存器编号,对应第二个源操作数
rd寄存器编号,保存结果
shamt常数,在移位指令中使用
funct功能码,指定指令的具体功能

(2)具体R型指令

注意: R型指令根据操作的寄存器数可以分为三种不同类型。

【1】带有3个寄存器

指令[31 : 26][25 : 21][20 : 16][15 : 11][10 : 6][5 : 0]指令功能
add000000rsrtrd00000100000寄存器加
sub000000rsrtrd00000100010寄存器减
and000000rsrtrd00000100100寄存器与
or000000rsrtrd00000100101寄存器或
xor000000rsrtrd00000100110寄存器异或

$rd = $rs op $ rt

【2】带有2个寄存器

指令[31 : 26][25 : 21][20 : 16][15 : 11][10 : 6][5 : 0]指令功能
sll00000000000rtrdsa100000逻辑左移
srl00000000000rtrdsa000010逻辑右移
sll00000000000rtrdsa000011算术右移

$rd = $rt shift sa

【3】带有1个寄存器

指令[31 : 26][25 : 21][20 : 16][15 : 11][10 : 6][5 : 0]指令功能
jr000000rs000000000000000001000寄存器跳转

jr rs;
PC = rs

二.I型指令

(1)I型指令格式

OPRsRtimm(立即数)
6bits5bits5bits16bits

注意: 操作数中涉及立即数,结果保存到寄存器

操作含义
op标识指令的操作功能
rs第一个源操作数,是寄存器操作数
rt目的寄存器编号,用来保存运算结果
imm第二个源操作数,立即数

(2)具体I型指令

注意: I型指令存在4种不同的类型

【1】面向运算的I型指令

指令[31 : 26][25 : 21][20 : 16][15 : 0]指令功能
addi001000rsrtimm寄存器和立即数“加”
andi001100rsrtimm寄存器和立即数“与”
ori001101rsrtimm寄存器和立即数“或”
xori001110rsrtimm寄存器和立即数“异或”

第一条指令是对立即数进行符号拓展,其他都是0拓展
addi rt, rs, imm;
$rt = $rs op E(imm)

【2】面向访存的I型指令

指令[31 : 26][25 : 21][20 : 16][15 : 0]指令功能
lw100011rsrtimm从存储器种读取数据
sw101011rsrtimm把数据保存到存储器

MIPS 32中唯一两条访问存储器的指令(RISC)
lw rt, imm(rs) # r t = m e m [ rt = mem[ rt=mem[rs+E(imm)]
sw rt, imm(rs) # m e m [ mem[ mem[rs+E(imm)] = $rt

【3】面向数位设置的I型指令

指令[31 : 26][25 : 21][20 : 16][15 : 0]指令功能
lui00111100000rtimm设置寄存器的高16位

lui rt, imm #$rt = imm<<16(空位补0)

【4】面向条件转移(分支)的I型指令

指令[31 : 26][25 : 21][20 : 16][15 : 0]指令功能
beq000100rsrtimm寄存器相等则转移
bne000101rsrtimm寄存器不相等则转移

beq rs, rt, imm #if( r s = = rs== rs==rt) PC=PC+E(imm)<<2
bne rs, rt, imm #if( r s ! = rs!= rs!=rt) PC=PC+E(imm)<<2
标准的PC相对寻址方式

三.J型指令

(1)J型指令格式

OP立即数
6bits26bits

(2)具体J型指令

指令[31 : 26][25 : 0]指令功能
j000010address无条件跳转
jal001100address调用与联接

j address;
$ PC=($PC+4)H4U(address<<2)

jal address;
$ra = $PC+4(保存返回地址)
$ PC=($PC+4)H4U(address<<2)

四.举例

(1)关于R型指令

不同功能的R型指令使用的寄存器数量不一定相同,有一个、两个、三个

所有R型指令的操作码OP字段均为000000

R型指令既有算术运算指令,也有逻辑运算指令,它不支持访问主存的指令

(2)关于J造型指令

J型指令支持无条件跳转指令

J性指令只使用伪直接寻址方式

J型指令执行后,PC寄存器的值最后两位一定为00

J型指令需要使用ra寄存器

参考:华中科技大学mooc计算机组成原理

有关MIPS指令详解的更多相关文章

  1. 物联网MQTT协议详解 - 2

    一、什么是MQTT协议MessageQueuingTelemetryTransport:消息队列遥测传输协议。是一种基于客户端-服务端的发布/订阅模式。与HTTP一样,基于TCP/IP协议之上的通讯协议,提供有序、无损、双向连接,由IBM(蓝色巨人)发布。原理:(1)MQTT协议身份和消息格式有三种身份:发布者(Publish)、代理(Broker)(服务器)、订阅者(Subscribe)。其中,消息的发布者和订阅者都是客户端,消息代理是服务器,消息发布者可以同时是订阅者。MQTT传输的消息分为:主题(Topic)和负载(payload)两部分Topic,可以理解为消息的类型,订阅者订阅(Su

  2. Tcl脚本入门笔记详解(一) - 2

    TCL脚本语言简介•TCL(ToolCommandLanguage)是一种解释执行的脚本语言(ScriptingLanguage),它提供了通用的编程能力:支持变量、过程和控制结构;同时TCL还拥有一个功能强大的固有的核心命令集。TCL经常被用于快速原型开发,脚本编程,GUI和测试等方面。•实际上包含了两个部分:一个语言和一个库。首先,Tcl是一种简单的脚本语言,主要使用于发布命令给一些互交程序如文本编辑器、调试器和shell。由于TCL的解释器是用C\C++语言的过程库实现的,因此在某种意义上我们又可以把TCL看作C库,这个库中有丰富的用于扩展TCL命令的C\C++过程和函数,所以,Tcl是

  3. 【详解】Docker安装Elasticsearch7.16.1集群 - 2

    开门见山|拉取镜像dockerpullelasticsearch:7.16.1|配置存放的目录#存放配置文件的文件夹mkdir-p/opt/docker/elasticsearch/node-1/config#存放数据的文件夹mkdir-p/opt/docker/elasticsearch/node-1/data#存放运行日志的文件夹mkdir-p/opt/docker/elasticsearch/node-1/log#存放IK分词插件的文件夹mkdir-p/opt/docker/elasticsearch/node-1/plugins若你使用了moba,直接右键新建即可如上图所示依次类推创建

  4. 【Elasticsearch基础】Elasticsearch索引、文档以及映射操作详解 - 2

    文章目录概念索引相关操作创建索引更新副本查看索引删除索引索引的打开与关闭收缩索引索引别名查询索引别名文档相关操作新建文档查询文档更新文档删除文档映射相关操作查询文档映射创建静态映射创建索引并添加映射概念es中有三个概念要清楚,分别为索引、映射和文档(不用死记硬背,大概有个印象就可以)索引可理解为MySQL数据库;映射可理解为MySQL的表结构;文档可理解为MySQL表中的每行数据静态映射和动态映射上面已经介绍了,映射可理解为MySQL的表结构,在MySQL中,向表中插入数据是需要先创建表结构的;但在es中不必这样,可以直接插入文档,es可以根据插入的文档(数据),动态的创建映射(表结构),这就

  5. 【Linux】初识Linux --指令Ⅰ - 2

    Halo,这里是Ppeua。平时主要更新C语言,C++,数据结构算法,Linux…感兴趣就关注我吧!你定不会失望。目录1.ls显示当前目录下的文件内内容2.pwd-显示用户当前所在的目录3.cd-改变工作目录。将当前工作目录改变到指定的目录下1.cd-回到上一次待的工作空间2.cd..返回上一层目录1.相对路径:cd../aurora2.绝对路径:cd/home/aurora/lesson1/aurora3.cd~进入用户家目录4.cd/进入root目录4.mkdir-新建目录5.rmdir/rm-删除1.rmdir删除空文件夹2.rm删除1.rm-f2.rm-i3.rm-r1.ls显示当前目

  6. 最强Http缓存策略之强缓存和协商缓存的详解与应用实例 - 2

    HTTP缓存是指浏览器或者代理服务器将已经请求过的资源保存到本地,以便下次请求时能够直接从缓存中获取资源,从而减少网络请求次数,提高网页的加载速度和用户体验。缓存分为强缓存和协商缓存两种模式。一.强缓存强缓存是指浏览器直接从本地缓存中获取资源,而不需要向web服务器发出网络请求。这是因为浏览器在第一次请求资源时,服务器会在响应头中添加相关缓存的响应头,以表明该资源的缓存策略。常见的强缓存响应头如下所述:Cache-ControlCache-Control响应头是用于控制强制缓存和协商缓存的缓存策略。该响应头中的指令如下:max-age:指定该资源在本地缓存的最长有效时间,以秒为单位。例如:Ca

  7. IDEA 2022 创建 Spring Boot 项目详解 - 2

    如何用IDEA2022创建并初始化一个SpringBoot项目?目录如何用IDEA2022创建并初始化一个SpringBoot项目?0. 环境说明1.  创建SpringBoot项目 2.编写初始化代码0. 环境说明IDEA2022.3.1JDK1.8SpringBoot1.  创建SpringBoot项目        打开IDEA,选择NewProject创建项目。        填写项目名称、项目构建方式、jdk版本,按需要修改项目文件路径等信息。        选择springboot版本以及需要的包,此处只选择了springweb。        此处需特别注意,若你使用的是jdk1

  8. iOS快捷指令:执行Python脚本(利用iSH Shell) - 2

    文章目录前言核心逻辑配置iSH安装Python创建Python脚本配置启动文件测试效果快捷指令前言iOS快捷指令所能做的操作极为有限。假如快捷指令能运行Python程序,那么可操作空间就瞬间变大了。iSH是一款免费的iOS软件,它模拟了一个类似Linux的命令行解释器。我们将在iSH中运行Python程序,然后在快捷指令中获取Python程序的输出。核心逻辑我们用一个“获取当前日期”的Python程序作为演示(其实快捷指令中本身存在“获取当前日期”的操作,因而此需求可以不用Python,这里仅仅为了演示方便),核心代码如下。>>>importtime>>>time.strftime('%Y-%

  9. 详解Unity中的粒子系统Particle System (二) - 2

    前言上一篇我们简要讲述了粒子系统是什么,如何添加,以及基本模块的介绍,以及对于曲线和颜色编辑器的讲解。从本篇开始,我们将按照模块结构讲解下去,本篇主要讲粒子系统的主模块,该模块主要是控制粒子的初始状态和全局属性的,以下是关于该模块的介绍,请大家指正。目录前言本系列提要一、粒子系统主模块1.阅读前注意事项2.参考图3.参数讲解DurationLoopingPrewarmStartDelayStartLifetimeStartSpeed3DStartSizeStartSize3DStartRotationStartRotationFlipRotationStartColorGravityModif

  10. VMware虚拟机与本地主机进行磁盘共享(详解) - 2

    VMware虚拟机与本地主机进行磁盘共享前提虚拟机版本为Windows10(专业版,不是可能有问题)本地主机为家庭版或学生版(此版本会有问题,但有替代方式)最好是专业版VMware操作1.关闭防火墙,全部关闭。2.打开电脑属性3.点击共享-》高级共享-》权限4.如果没有everyone,就添加权限选择完全控制,然后应用确定。5.打开cmd输入lusrmgr.msc(只有专业版可以打开)如果不是专业版,可以跳过这一步。点击用户-》administrator密码要复杂密码,否则不行。推荐admaiN@1234类型的密码。设置完密码,点击属性,将禁用解开。6.如果虚拟机的windows不是专业版,可

随机推荐