MIPS指令集-mars-cpu

news2024/10/6 1:37:06

MIPS通用寄存器

MIPS有32个通用寄存器($0-$31),各寄存器的功能及汇编程序中使用约定如下:

下表描述32个通用寄存器的别名和用途

REGISTER

NAME

USAGE

$0

$zero

常量0(constant value 0)

$1

$at

保留给汇编器(Reserved for assembler)

$2-$3

$v0-$v1

函数调用返回值(values for results and expression evaluation)

$4-$7

$a0-$a3

函数调用参数(arguments)

$8-$15

$t0-$t7

暂时的(或随便用的)

$16-$23

$s0-$s7

保存的(或如果用,需要SAVE/RESTORE的)(saved)

$24-$25

$t8-$t9

暂时的(或随便用的)

$28

$gp

全局指针(Global Pointer)

$29

$sp

堆栈指针(Stack Pointer)

$30

$fp

帧指针(Frame Pointer)

$31

$ra

返回地址(return address)

 

MIPS 指令

指令

功能

应用实例

LB

从存储器中读取一个字节的数据到寄存器中

LB R1, 0(R2)

LH

从存储器中读取半个字的数据到寄存器中

LH R1, 0(R2)

LW

从存储器中读取一个字的数据到寄存器中

LW R1, 0(R2)

LD

从存储器中读取双字的数据到寄存器中

LD R1, 0(R2)

L.S

从存储器中读取单精度浮点数到寄存器中

L.S R1, 0(R2)

L.D

从存储器中读取双精度浮点数到寄存器中

L.D R1, 0(R2)

LBU

功能与LB指令相同,但读出的是不带符号的数据

LBU R1, 0(R2)

LHU

功能与LH指令相同,但读出的是不带符号的数据

LHU R1, 0(R2)

LWU

功能与LW指令相同,但读出的是不带符号的数据

LWU R1, 0(R2)

SB

把一个字节的数据从寄存器存储到存储器中

SB R1, 0(R2)

SH

把半个字节的数据从寄存器存储到存储器中

SH R1,0(R2)

SW

把一个字的数据从寄存器存储到存储器中

SW R1, 0(R2)

SD

把两个字节的数据从寄存器存储到存储器中

SD R1, 0(R2)

S.S

把单精度浮点数从寄存器存储到存储器中

S.S R1, 0(R2)

S.D

把双精度数据从存储器存储到存储器中

S.D R1, 0(R2)

DADD

把两个定点寄存器的内容相加,也就是定点加

DADD R1,R2,R3

DADDI

把一个寄存器的内容加上一个立即数

DADDI R1,R2,#3

DADDU

不带符号的加

DADDU R1,R2,R3

DADDIU

把一个寄存器的内容加上一个无符号的立即数

DADDIU R1,R2,#3

ADD.S

把一个单精度浮点数加上一个双精度浮点数,结果是单精度浮点数

ADD.S F0,F1,F2

ADD.D

把一个双精度浮点数加上一个单精度浮点数,结果是双精度浮点数

ADD.D F0,F1,F2

ADD.PS

两个单精度浮点数相加,结果是单精度浮点数

ADD.PS F0,F1,F2

DSUB

两个寄存器的内容相减,也就是定点数的减

DSUB R1,R2,R3

DSUBU

不带符号的减

DSUBU R1,R2,R3

SUB.S

一个双精度浮点数减去一个单精度浮点数,结果为单精度

SUB.S F1,F2,F3

SUB.D

一个双精度浮点数减去一个单精度浮点数,结果为双精度浮点数

SUB.D F1,F2,F3

SUB.PS

两个单精度浮点数相减

SUB.SP F1,F2,F3

DDIV

两个定点寄存器的内容相除,也就是定点除

DDIV R1,R2,R3

DDIVU

不带符号的除法运算

DDIVU R1,R2,R3

DIV.S

一个双精度浮点数除以一个单精度浮点数,结果为单精度浮点数

DIV.S F1,F2,F3

DIV.D

一个双精度浮点数除以一个单精度浮点数,结果为双精度浮点数

DIV.D F1,F2,F3

DIV.PS

两个单精度浮点数相除,结果为单精度

DIV.PS F1,F2,F3

DMUL

两个定点寄存器的内容相乘,也就是定点乘

DMUL R1,R2,R3

DMULU

不带符号的乘法运算

DMULU R1,R2,R3

MUL.S

一个双精度浮点数乘以一个单精度浮点数,结果为单精度浮点数

DMUL.S F1,F2,F3

MUL.D

一个双精度浮点数乘以一个单精度浮点数,结果为双精度浮点数

DMUL.D F1,F2,F3

MUL.PS

两个单精度浮点数相乘,结果为单精度浮点数

DMUL.PS F1,F2,F3

AND

与运算,两个寄存器中的内容相与

ANDR1,R2,R3

ANDI

一个寄存器中的内容与一个立即数相与

ANDIR1,R2,#3

OR

或运算,两个寄存器中的内容相或

ORR1,R2,R3

ORI

一个寄存器中的内容与一个立即数相或

ORIR1,R2,#3

XOR

异或运算,两个寄存器中的内容相异或

XORR1,R2,R3

XORI

一个寄存器中的内容与一个立即数异或

XORIR1,R2,#3

BEQZ

条件转移指令,当寄存器中内容为0时转移发生

BEQZ R1,0

BENZ

条件转移指令,当寄存器中内容不为0时转移发生

BNEZ R1,0

BEQ

条件转移指令,当两个寄存器内容相等时转移发生

BEQ R1,R2

BNE

条件转移指令,当两个寄存器中内容不等时转移发生

BNE R1,R2

J

直接跳转指令,跳转的地址在指令中

J name

JR

使用寄存器的跳转指令,跳转地址在寄存器中

JR R1

JAL

直接跳转指令,并带有链接功能,指令的跳转地址在指令中,跳转发生时要把返回地址存放到R31这个寄存器中

JAL R1 name

JALR

使用寄存器的跳转指令,并且带有链接功能,指令的跳转地址在寄存器中,跳转发生时指令的放回地址放在R31这个寄存器中

JALR R1

MOV.S

把一个单精度浮点数从一个浮点寄存器复制到另一个浮点寄存器

MOV.S F0,F1

MOV.D

把一个双精度浮点数从一个浮点寄存器复制到另一个浮点寄存器

MOV.D F0,F1

MFC0

把一个数据从通用寄存器复制到特殊寄存器

MFC0 R1,R2

MTC0

把一个数据从特殊寄存器复制到通用寄存器

MTC0 R1,R2

MFC1

把一个数据从定点寄存器复制到浮点寄存器

MFC1 R1,F1

MTC1

把一个数据从浮点寄存器复制到定点寄存器

MTC1 R1,F1

LUI

把一个16位的立即数填入到寄存器的高16位,低16位补零

LUI R1,#42

DSLL

双字逻辑左移

DSLL R1,R2,#2

DSRL

双字逻辑右移

DSRL R1,R2,#2

DSRA

双字算术右移

DSRA R1,R2,#2

DSLLV

可变的双字逻辑左移

DSLLV R1,R2,#2

DSRLV

可变的双字罗伊右移

DSRLV R1,R2,#2

DSRAV

可变的双字算术右移

DSRAV R1,R2,#2

SLT

如果R2的值小于R3,那么设置R1的值为1,否则设置R1的值为0

SLT R1,R2,R3

SLTI

如果寄存器R2的值小于立即数,那么设置R1的值为1,否则设置寄存器R1的值为0

SLTI R1,R2,#23

SLTU

功能与SLT一致,但是带符号的

SLTU R1,R2,R3

SLTUI

功能与SLT一致,但不带符号

SLTUI R1,R2,R3

MOVN

如果第三个寄存器的内容为负,那么复制一个寄存器的内容到另外一个寄存器

MOVN R1,R2,R3

MOVZ

如果第三个寄存器的内容为0,那么复制一个寄存器的内容到另外一个寄存器

MOVZ R1,R2,R3

TRAP

根据地址向量转入管态

ERET

从异常中返回到用户态

MADD.S

一个双精度浮点数与单精度浮点数相乘加,结果为单精度

MADD.D

一个双精度浮点数与单精度浮点数相乘加,结果为双精度

MADD.PS

两个单精度浮点数相乘加,结果为单精度

MFC0  把一个数据从通用寄存器复制到特殊寄存器

 

 

 

 

 

 

 

 

 

 

 

 

 

 

2. 算数运算指令
  算数运算指令的所有操作数都是寄存器,不能直接使用RAM地址或间接寻址。
  操作数的大小都为 Word (4-Byte)
  指令格式与实例 注释
  move $t5, $t1       // $t5 = $t1;
  add $t0, $t1,       // $t2 $t0 = $t1 + $t2; 带符号数相加
  sub $t0, $t1,       // $t2 $t0 = $t1 - $t2; 带符号数相减
  addi $t0, $t1, 5    // $t0 = $t1 + 5;
  addu $t0, $t1, $t2  // $t0 = $t1 + $t2; 无符号数相加
  subu $t0, $t1, $t2  // $t0 = $t1 - $t2; 无符号数相减
  mult $t3, $t4       // $t3 * $t4, 把64-Bits 的积,存储到Lo,Hi中。即: (Hi, Lo) = $t3 * $t4;
  div $t5, $t6        // Lo = $t5 / $t6 (Lo为商的整数部分); Hi = $t5 mod $t6 (Hi为余数)
  mfhi $t0            // $t0 = Hi
  mflo $t1            // $t1 = Lo

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/457809.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

K近邻算法(手写代码+图像识别实践)

k近邻算法作为一个分类算法,他通过计算不同特征值之间的距离来进行分类,它的工作原理是存在一个样本集合作为训练样本集,且每个样本都存在一个标签,此时,输入一个新的样本不存在标签,我们通过计算这个新样本…

【Android车载系列】第10章 系统服务-SystemServer源码分析(API28)

1 SystemServer启动 &emps;&emps;SystemServer进程启动,首先从SystemServer.java文件的main()方法开始。 290 /** 291 * The main entry point from zygote. 292 */ 293 public static void main(String[] args) { 294 new SystemSe…

S32K3系列单片机开发笔记(SIUL是什么/配置引脚复用的功能·)

前言 今天花时间看了一下,SIUL2模块的相关内容,并参照文档,以及例程作了一些小记录,知道该如何使用这个外设,包括引脚的配置,中断配置,以及常用函数的使用等,但对其中的一些细节还需…

如何利用代码快速生成mapper.xml的<resultMap>

一,问题引入 当我们开发 mapper.xml ---->dao接层 ---->service接口---->serviceImp ---->controller层, 其中在mapper.xml编写查询语句的sql时会遇到sql查询到的结果 涉及到多张表的字段,或者单张表的字段过多时, 这…

Python文件处理

文章目录 1️⃣基本语法2️⃣读取文件⚜️读取整个文件read()⚜️with 关键词⚜️逐行读取 3️⃣写入文件⚜️写入文件write()⚜️写入数字⚜️追加内容到文件 4️⃣读取和写入二进制文件 简介 读完本篇你将学会文件的创建、读取、写入等。 1️⃣基本语法 在Python中使用文件的…

ThreadLocal机制解读和源码分析

目录 线程数据共享和安全 -ThreadLocal 什么是 ThreadLocal 代码演示 创建Dog.java 创建Pig.java T2DAO.java T2DAO T1解读set T1Service 解读 get ThreadLocalTest这个是换一种法 ThreadLocal 原理分析图 1. ThreadLocal 原理分析图(重点 set 和 get) 线程数据共…

Go Fuzzing:发现你未曾发现的漏洞

文章目录 Fuzzing(模糊测试)要求示例模拟crash 总结参考资料 Fuzzing(模糊测试) go fuzz文档 对于软件开发者而言,一项重要的任务就是确保程序的安全性。而其中一种风险就是软件中可能存在的漏洞。传统的测试方法往往需要耗费大量的时间和人力,而使用F…

【C++: 模块二 ---运算符、流程控制语句】

C: 模块二 ---运算符、流程控制语句 一、运算符:1.1算数运算符:1.2赋值运算符:1.3比较运算符:1.4逻辑运算符:1.5三目运算符: 二、程序流程结构2.1顺序结构:2.2选择结构:&…

ChatGPT免费第一版本

最近利用空余时间做了一个供大家免费体验的chatgpt国内可直接访问的版本 输入12345gpt.com可直接访问 贴上GPT给我回复的内容,😀 当今社会,交流已经成为人们日常不可或缺的一部分。然而,随着技术的发展,人们对于交流工…

【Linux 裸机篇(七)】I.MX6U 中断系统

目录 一、中断向量表1. 中断向量偏移 二、中断系统简介1. 创建中断向量表 三、GIC 控制器简介1. 中断 ID 四、GIC 逻辑分块1. Distributor(分发器端)2. CPU Interface(CPU 接口端) 五、CP15 协处理器六、中断使能1. IRQ 和 FIQ 总中断使能2. ID0~ID1019 中断使能和禁止 七、中断…

【PXE高效的批量网络装机】

目录 一、PXE的概述1.1、PXE批量部署的优点1.2、搭建PXE满足的以下的前提条件1.3、搭建PXE远程安装 二、搭建PXE远程安装服务器1、安装并启动 TFTP 服务2、安装并启用 DHCP 服务3、准备 Linux 内核、初始化镜像文件4、准备PXE 引导程序5、安装FTP服务,准备CentOS 7 …

SpringMVC使用域对象共享数据

1、SpringMVC中的域对象 此处只有request、session、servletContext被使用,而page是jsp页面的域,不使用jsp。 request:一次请求的范围内session:一次会话的范围内servletContext:整个web的应用范围内 2、向request域…

MySQL高级第十七篇:数据库主从复制原理及保证数据一致性

MySQL高级第十七篇:数据库主从复制原理及保证数据一致性 一、概述1. 提升数据库的并发能力2. 主从复制的作用? 二、主从复制原理三、搭建一主一从环境四、如何解决数据一致性问题?1. 方案一、异步复制2. 方案二、半同步复制3. 方案三、组复制…

3.黑马Springboot原理篇自己修改笔记

原理篇 1.自动配置的工作流程 1.1 bean的加载方式 方式一&#xff1a;配置文件<bean/>标签 缺点&#xff1a;配置bean太繁琐 方式二&#xff1a;配置文件扫描注解定义bean⭐️ 获取bean方式 ①通过配置文件&#xff0c;扫描指定包&#xff0c;加载bean ②通过注解声…

C++ STL之string容器的模拟实现

目录 一、经典的string类问题 1.出现的问题 2.浅拷贝 3.深拷贝 二、string类的模拟实现 1.传统版的string类 2.现代版的string类&#xff08;采用移动语义&#xff09; 3.相关习题* 习题一 习题二 4.写时拷贝 5.完整版string类的模拟实现[注意重定义] MyString.h…

磁珠的工作原理

磁珠是一个耗能元器件&#xff0c;他能把频率相对较高的信号以热量的形式耗散掉&#xff0c;保留频率相对较低的信号。 主要有这种插件的磁珠&#xff0c;还有这种贴片的磁珠。 下面我们来看下磁珠具体工作原理。 磁珠的构造我们可以简单的看成一个导线穿过环形铁氧体的磁性材…

[渗透教程]-015-网络与系统渗透

文章目录 1.0基本概念2.0 网络与系统渗透基本原理2.1 渗透测试2.2 入侵和预防2.3 案例一:从信息收集到入侵提权2.3.1 从域名到ip2.3.2 从IP获取旁站2.3.3 收集系统与⽹络配置详细信息2.3.4 踩点2.3.5发现漏洞2.3.6漏洞利用2.3.7维持系统控制权2.3.8清理访问痕迹2.4 案例二:Goo…

TryHackMe-Jeff(boot2root | Hard?)

Jeff 你能破解杰夫的网络服务器吗&#xff1f; 如果你发现自己在暴力破解SSH&#xff0c;你就做错了。 端口扫描 循例nmap 进80&#xff0c;是一个空页面&#xff0c;查看源代码 将jeff.thm加入hosts 上gobuster /admin是空页面&#xff0c;/backups也没东西&#xff0c;/up…

Centos安全加固策略

目录 密码安全策略 设置密码的有效期和最小长度 设置用户密码的复杂度 登录安全策略 设置用户远程登录的安全策略 安全的远程管理方式 访问控制 限制root用户登录 修改ssh 22端口 设置登录超时时间 限制IP访问 安全审计 审核策略开启 日志属性设置 查看系统登录…

基础巩固、探寻Java装箱和拆箱的奥妙!

前言 今天在逛某知名论坛的时候&#xff0c;看到一篇"请不要使用包装类型&#xff0c;避免造成性能损失"的文章。一下子就吸引了我的注意。大意就是&#xff0c;能用基本数据类型就尽量用基本数据类型&#xff0c;因为包装类型自动拆箱、装箱会带来性能损失尤其是循环…