1. 寄存器

32个x寄存器,RV32下x reg是32位宽

x0:硬连线 常数0 专门的零寄存器

x1-x31:31个通用reg

返回地址:没有强制要求那一个x作为lr,但是一般用x1

pc:额外的用户可见寄存器

2. 基本指令格式

四种基础指令格式 R/I/S/U

imm:立即数

rs1:源寄存器1

rs2:源寄存器2

rd:目标寄存器

opcode:操作码

example: C.LI 指令被扩展为 addi rd, x0, imm[5:0]。

3 整形运算

使用R或者I类指令

R类:寄存器-立即数

I类:寄存器-寄存器

整数计算不会造成运算异常

寄存器-立即数:

ADDI:将12位有符号立即数和rs相加,溢出忽略,直接使用结果的最低32bit,并存入rd

伪指令MV:"MV rd,rs"实际上是"ADDI rd, rs, 0"

SLTI:如果rs小于立即数(都是有符号整数),将rd置1,否则置0

SLTIU:和SLTI一致,不过都是无符号数

伪指令SEQZ:"SEQZ rd, rs" 实际上是 "SLTIU rd, rs1, 1"

ANDI/ORI/XORI:rs与有符号12位立即数进行and,or,xor操作

伪指令NOT:"NOT rd, rs"实际上是"XORI rd, rs1, -1"

shift是I类指令格式

SLLI:逻辑左移,低位移入0

SRLI:逻辑右移,高位移入0

SRAI:算数右移,符号移入高位

u类指令格式

LUI:创建32位无符号整数,存放立即数到rd的高20位,低12位置0

AUIPC:创建pc的相对地址,pc+无符号立即数(偏移量)=>rd

寄存器-寄存器:

ADD/SUB:rs1(+/-)rs2 => rd

SLT/SLTU: 如果rs1<rs2,rd写1; 否则rd为0

AND/OR/XOR: rs1与rs2进行and,or,xor操作

SLL/SRL/SRA: 和"寄存器-立即数"指令一致,将r2的低5位作为立即数即可

NOP指令:

实际上是ADDI x0,x0,0

4. 控制传输指令

1)非条件跳转:

JAL:J类指令,立即数+pc为跳转目标,rd存放pc+4(返回地址)

跳转范围为pc(+/-)1MB

JALR:I类指令,rs+立即数为跳转目标,rd存放pc+4(返回地址)

实现远跳转

2)条件跳转

所有分支指令使用B类指令格式,12位立即数+pc作为目标

跳转范围为pc(+/-)4KB

BEQ/BNE:rs1(==/!=)rs2, 分别在相等或者不等时,发生跳转

BLT:rs1 < rs2, 跳转

BGE:rs1 >= rs2, 跳转

5 加载存储指令

RV32I是一个加载/存储架构,只有load/store能访问内存,运算指令只操作寄存器

load是I类指令,store是S类指令

LOAD:rs作为基地址,加上有符号的偏移,读取到rd寄存器

STORE:rs1作为基地址加上有符号的偏移,作为内存地址,写入内容为rs2

6. 控制状态寄存器指令

寄存器-寄存器:读/写/修改 CSR

CSRRW:Atomic Read/Write CSR

读取CSR的值存入rd寄存器,并将rs存入CSR

另外:如果rd为x0,将不会执行

CSRRS:Atomic Read and Set Bits in CSR

读取CSR的值存入rd寄存器,并根据rs中高位对CSR置1

另外:如果rs为x0,将不会执行

CSRRC:Atomic Read and Clear Bits in CSR

读取CSR的值存入rd寄存器,并根据rs中高位对CSR置0

另外:如果rs为x0,将不会执行

立即数-寄存器:读/写/修改 CSR

CSRRWI/CSRRSI/CSRRCI

将CSRRW类寄存器中的rs换成立即数

另外:如果立即数为0,将不会执行

用户级系统指令:时钟和计数器

RV32I提供三个64位只读用户级寄存器:RDCYCLE[H]/RDTIME[H]/RDINSTRET[H]

使用CSRRS读取这三个寄存器的高32 bit

RDCYCLE:时钟周期计数

RDTIME:时间 tick数

RDINSTRET:指令数

参考文档: https://blog.csdn.net/zhangshuaiisme/article/details/80718496

RISC-V指令集介绍 - 整数基本指令集的更多相关文章

  1. 常见的CPU指令集介绍

    本文摘自网络   一.X86 是微处理器执行的计算机语言指令集,指一个intel通用计算机系列的标准编号缩写,也标识一套通用的计算机指令集合,属于CISC. 1.1.简介 X86指令集是美国Intel ...

  2. JVM指令集介绍

    转载自:http://glutinit.iteye.com/blog/1263446 延伸参考 JVM接收参数和方法调用 void spin() {    int   i;    for (i = 0 ...

  3. RV32I基础整数指令集

    RV32I是32位基础整数指令集,它支持32位寻址空间,支持字节地址访问,仅支持小端格式(little-endian,高地址高位,低地址地位),寄存器也是32位整数寄存器.RV32I指令集的目的是尽量 ...

  4. RISC指令集的五个周期

    RISC指令集的五个周期 RISC(reduced instruction set computer,精简指令集计算机)简称为精简指令集.RISC把执行指令的精力主要放在了经常使用的指令上面.本文主要 ...

  5. 自己动手写处理器之第一阶段(3)——MIPS32指令集架构简单介绍

    将陆续上传本人写的新书<自己动手写处理器>(尚未出版).今天是第四篇.我尽量每周四篇 1.4 MIPS32指令集架构简单介绍 本书设计的处理器遵循MIPS32 Release 1架构,所以 ...

  6. 常用 ARM 指令集及汇编

    ARM7TDMI(-S)指令集及汇编 ARM 处理器是基于精简指令集计算机(RISC)原理设计的,指令集和相关译码机制 较为简单,ARM7TDMI(-S)具有 32 位 ARM 指令集和 16 位 T ...

  7. 计算机系统6-> 计组与体系结构3 | MIPS指令集(中)| MIPS汇编指令与机器表示

    上一篇计算机系统5-> 计组与体系结构2 | MIPS指令集(上)| 指令系统从顶层讲解了一个指令集 / 指令系统应当具备哪些特征和工作原理.这一篇就聚焦MIPS指令集(MIPS32),看看其汇 ...

  8. X86架构CPU常识(主频,外频,FSB,cpu位和字长,倍频系数,缓存,CPU扩展指令集,CPU内核和I/O工作电压,制造工艺,指令集,超流水线与超标量)

    1.主频 主频也叫时钟频率,单位是MHz,用来表示CPU的运算速度. CPU的主频=外频×倍频系数.很多人认为主频就决定着CPU的运行速度,这不仅是个片面的,而且对于服务器来讲,这个认识也出现了偏差. ...

  9. 计算机系统5-> 计组与体系结构2 | MIPS指令集(上)| 指令系统

    系列的上一篇计算机系统4-> 计组与体系结构1 | 基础概念与系统评估,学习了一些计算机的基础概念,将一些基本的计算机组成部分的功能和相互联系了解了一下,其中很重要的一个抽象思想就是软硬件的接口 ...

随机推荐

  1. 源码分析之groupcache之consistenthash

    很多时候读开源的库就是为自己准备大量的代码库,优秀开源项目代码质量比绝大部分人的代理质量都要高. 依赖的库 ```import ( "hash/crc32" "sort& ...

  2. godoc

    Godoc-一个Go代码文档化工具 Python - Docstring Java - javadoc

  3. [Java]异常在项目中的使用

    自己经历过的两个项目都有自定义异常,网上找了项目中自定义异常的例子: https://blog.csdn.net/aiyaya_/article/details/78989226. 这个例子基本上来说 ...

  4. Android中 实现队列方式处理优先级信息

    需求:当界面在处理消息A时,突然接收到消息B,需要立马显示B的信息,然后再继续显示消息A,或者接收到消息C,再显示完消息A后再显示消息C: 原理很简单 在一个轮询中,查询消息列表中的元素,先处理优先级 ...

  5. 2019.03.25 bzoj4572: [Scoi2016]围棋(轮廓线dp)

    传送门 题解可以参见zjjzjjzjj神仙的,写的很清楚. 代码: #include<bits/stdc++.h> #define ri register int using namesp ...

  6. usb 枚举流程简介

    1. 枚举是什么?        枚举就是从设备读取一些信息,知道设备是什么样的设备,如何进行通信,这样主机就可以根据这些信息来加载合适的驱动程序.调试USB设备,很重要的一点就是USB的枚举过程,只 ...

  7. python之路(八)-迭代器&生成器

    迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优点是 ...

  8. asp.net项目配置Web.config,支持JSON

    VS2013新建的web项目不支持直接下载json文件,可以在项目的web.config下插入如下的配置信息. <configuration> <system.web> < ...

  9. Debian 9.x "stretch" 安装 vnStat 统计服务器流量

    vnStat 是一款开源的 Linux 下统计网卡流量的软件,可以很方便地查看当前.当天.当月的流量统计报告,下面我们介绍下在 Debian 9.x 下安装 vnstat 的简单方法 首先,使用 ip ...

  10. 关于NGUI Shader 和 Draw Call的优化 & 模糊shader

    序: 1.项目过程中不可避免的需要用到大量Shader 和 UITexture,由于Ngui对Shader支持非常糟糕,导致项目drawCall异常的高 2.Panel裁剪无法裁剪自定义shader内 ...