RISC-V特权架构 - CSR寄存器

RV32/64 特权架构 - CSR寄存器

  • 1 CSR地址空间
  • 2 CSR定义
    • 2.1 用户级
    • 2.2 监管级
    • 2.3 超级监管级
    • 2.4 机器级
  • 3 CSR访问
    • 3.1 CSRRW
    • 3.2 CSRRS
    • 3.3 CSRRC
    • 3.4 CSRRWI
    • 3.5 CSRRSI
    • 3.6 CSRRCI

本文属于《 RISC-V指令集基础系列教程》之一,欢迎查看其它文章。

1 CSR地址空间

RISC-V架构中定义了一些控制和状态寄存器(control and status register),简称CSR,与32个物理寄存器不同(物理寄存器可以认为是5位地址寻址的),这些CSR是用12位地址进行寻址的,因此理论上最多可以有4096个CSR寄存器,并且地址空间是私有独立的,不同于全局地址空间。

CSR地址空间,定义如下:
在这里插入图片描述
CSR地址的高4bits,用于编码CSR在各个权级上的可读写性:

  • [11:10],表示该寄存器是可读写(00,01或10),还是只读(11)。
  • [9:8],表示允许访问该寄存器的最低权级。
    00:用户级,用户模式及以上权级(用户、监管、机器)可访问。
    01:监管级,监管模式及以上权级(监管、机器)可访问。
    10:超级监管级(扩展模式),仅在虚拟化时使用,用于访问虚拟化专用的CSR。
    11:机器级,仅机器模式可访问。
    从上图也可以看到,根据[9:8]的值,整个CSR地址空间被分为了4个部分。

除此之外,上图还指定了哪些CSR地址是标准用途,而哪些是自定义用途。
用于自定义的CSR地址,不会在未来标准扩展中被重新定义。

2 CSR定义

我们知道,CSR寄存器被划分为4个级别:用户级、监管级、超级监管级、机器级。
接下来,我们看看各个权级,具体定义了哪些寄存器。

2.1 用户级

用户级CSR,定义了两个部分的寄存器:

  • Unprivileged Floating-Point CSRs
  • Unprivileged Counter/Timers

在这里插入图片描述
以上Number列,给出了该寄存器的12位地址。
具体寄存器含义见规范手册。

2.2 监管级

监管级CSR,定义了五个部分的寄存器:

  • Supervisor Trap Setup
  • Supervisor Configuration
  • Supervisor Trap Handling
  • Supervisor Protection and Translation
  • Debug/Trace Registers

在这里插入图片描述
具体寄存器含义见规范手册。

2.3 超级监管级

超级监管级CSR,定义了七个部分的寄存器:

  • Hypervisor Trap Setup
  • Hypervisor Trap Handling
  • Hypervisor Configuration
  • Hypervisor Protection and Translation
  • Debug/Trace Registers
  • Hypervisor Counter/Timer Virtualization Registers
  • Virtual Supervisor Registers

在这里插入图片描述
具体寄存器含义见规范手册。

2.4 机器级

机器级CSR,定义了九个部分的寄存器:

  • Machine Information Registers
  • Machine Trap Setup
  • Machine Trap Handling
  • Machine Configuration
  • Machine Memory Protection
  • Machine Counter/Timers
  • Machine Counter Setup
  • Debug/Trace Registers (shared with Debug Mode)
  • Debug Mode Registers

在这里插入图片描述
在这里插入图片描述
具体寄存器含义见规范手册。

3 CSR访问

针对CSR寄存器的读写,有相应的特殊指令,这些特殊指令都被定义在RV32I中,如下所示:
在这里插入图片描述
真正的指令只有CSRRW、CSRRS、CSRRC、CSRRWI、CSRRSI、CSRRCI这6条,其他资料中的CSR指令,均为伪指令。

CSR指令机器码中共有12位(第20-31位)用来指示,被“读改写”的是哪一个CSR寄存器,这里通常填写的就是前面讲过的CSR地址,比如:mtvec寄存器那就是0x305。

注意事项:

  • 试图访问一个不存在的CSR将造成一个非法指令异常(illegal instruction exception);
  • 试图在不当的权级下访问CSR,或者尝试写入一个只读寄存器也都将造成非法指令异常;
  • 可读写寄存器中也可能包含一些只读位,此时忽略对只读位的写入。

3.1 CSRRW

在这里插入图片描述
指令形式:csrrw rd, csr, rs1
指令功能:CSR寄存器读后写。记csr值为t,将rs1写入csr,再将t写入rd。

t = csr
csr = rs1
rd = t

例如:csrrw t0, mstatus, t0
将 mstatus 的值与 t0 的值交换。

3.2 CSRRS

在这里插入图片描述
指令形式:csrrs rd, csr, rs1
指令功能:CSR寄存器读后置位。记csr值为t,将t和rs1的按位或结果写入csr,再将t 写入rd。

t = csr
csr = t | rs1 
rd = t

3.3 CSRRC

在这里插入图片描述
指令形式:csrrc rd, csr, rs1
指令功能:CSR寄存器读后清位。记csr值为t,将rs1的反码和t按位与,结果写入csr,再将t写入rd。

t = csr
csr = t & ∼rs1
rd = t

3.4 CSRRWI

在这里插入图片描述
指令形式:csrrwi rd, csr, zimm[4:0]
指令功能:CSR寄存器读后写立即数。将csr 的值复制到rd 中,再将5 位立即数zimm 的零扩展结果写入csr。

rd = csr
csr = zimm

3.5 CSRRSI

在这里插入图片描述
指令形式:csrrsi rd, csr, zimm[4:0]
指令功能:CSR寄存器读后置位立即数。记csr 的值为t,将5 位立即数zimm 零扩展后,和t 按位或,结果写入csr,再将t 写入rd(csr 中的第5 及更高的位不变)。

t = csr
csr = t | zimm
rd = t

3.6 CSRRCI

在这里插入图片描述
指令形式:csrrci rd, csr, zimm[4:0]
指令功能:CSR寄存器读后清位立即数。记csr 的值为t,将5 位立即数zimm 零扩展后的反码和t 按位与,结果写入csr,再将t 写入rd(csr 中的第5 及更高的位不变)。

t = csr
csr = t & ∼zimm 
rd = t

此外,需要注意:

  • 若目的通用寄存器为x0,则不会执行读取操作;
  • 若源通用寄存器为x0或立即数0,也不会进行写入CSR操作。

基于以上6条指令和x0这样的特性,衍生出若干CSR伪指令,比如:csrr、csrc、csrci、csrs、csrw等。


参考文档:

  • 《riscv-spec-20191213》
  • 《riscv-privileged-20211203》

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

[笔记] 使用 Java Swing 实现一个简单的窗口

Java Swing 是一个用于构建图形用户界面(GUI)的Java库,它提供了丰富的组件和工具,用于创建交互式的桌面应用程序。Swing 是 Java Foundation Classes(JFC)的一部分,它是 Java 平台的一种标准用户…

超全面!Linux学习资料大合集,21套从入门到进阶,看这篇就够了

本文将为那些渴望学习Linux,但又缺乏相应资料和方向的朋友,提供21套Linux优质资料,包含入门到进阶,希望能对大家有所帮助。 此合集内容及其丰富,涉及方面颇多,不仅适合Linux入门学习的朋友,运维…

麻省理工最新开发AI模型,让机器人实现自主规划路线

文 | BFT机器人 麻省理工学院的研究人员独具匠心地应用了人工智能来解决仓库中的机器人路径规划问题,以此缓解交通拥堵的难题。据该学院介绍,他们的团队开发了一种深度学习模型,其效率比传统的强随机搜索方法高出近四倍,极大地提…

彻底剖析激光-视觉-IMU-GPS融合SLAM算法:理论推导、代码讲解和实战

自主导航是机器人与自动驾驶的核心功能,而SLAM技术是实现自主导航的前提与关键。现有的机器人与自动驾驶车辆往往会安装激光雷达,相机,IMU,GPS等多种模态的传感器,而且已有许多优秀的激光SLAM与视觉SLAM算法。但是每种…

nginx主动检测后端健康模块

一、前言 nginx也有自带的后端检测模块ngx_http_upstream_module,该模块可以做到基本的健康检查,因为该健康检查是被动的,当nginx有请求后,才会对后端服务进行健康检测,当检测到有故障时会将这个请求转发到正常的后端服…

云计算市场,从追求“规模制胜”到走向“用户分化”

文|智能相对论 作者|叶远风 通常来说,价格战放到任何行业,都不是什么好事。 如今,作为曾经的前沿技术创新,云计算行业正在被迫走入价格战的阴霾当中,引发业界担忧。 ECS(云服务器)最高降36%…

数据库之间数据迁移工具datax

简介 DataX 是阿里云 DataWorks数据集成 的开源版本,在阿里巴巴集团内被广泛使用的离线数据同步工具/平台。DataX 实现了包括 MySQL、Oracle、OceanBase、SqlServer、Postgre、HDFS、Hive、ADS、HBase、TableStore(OTS)、MaxCompute(ODPS)、Hologres、DRDS, databe…

2024.3.1 网络编程

1.思维导图 2.TCP机械臂测试 程序代码&#xff1a; #include <myhead.h> #define SER_IP "192.168.125.254" //服务器端IP #define SER_PORT 8888 //服务器端端口号#define CLI_IP "192.168.199.131" //客户端IP …

C++_数据类型_字符串型

作用 用于表示一串字符 两种风格 C风格字符串&#xff1a;char 变量名[] "字符串值” 示例 注意 C风格的字符串要用双括号括起来 C风格字符串&#xff1a;string 变量名 "字符串值” 注意 用C风格字符串的时候&#xff0c;要包含这个头文件#include <st…

基于React低代码平台开发:构建高效、灵活的应用新范式

文章目录 一、React与低代码平台的结合优势二、基于React的低代码平台开发挑战三、基于React的低代码平台开发实践四、未来展望《低代码平台开发实践&#xff1a;基于React》编辑推荐内容简介作者简介目录前言为什么要写这本书 读者对象如何阅读本书 随着数字化转型的深入&…

GraphView实时图像刷新

代码&#xff1a; GraphViewTest::GraphViewTest(QWidget *parent): QWidget(parent) {ui.setupUi(this);m_bll BllData::getInstance();connect(m_bll, &BllData::returnImgDataSignal, this, &GraphViewTest::returnImgDataSlot);ui.graphicsView->setHorizonta…

RabbitMQ分享

RabbitMQ遵循AMQP协议&#xff0c;自身采用Erlang RabbitMQ工作模式 生产者发消息&#xff0c;启动多个消费者实例来消费消息&#xff0c;每个消费者仅消费部分信息&#xff0c;可达到负载均衡的效果。 RabbitMQ三种常用交换机类型&#xff1a; 交换机主要起调度分发作用。 …

正弦波生成的傅里叶级数展开法

目录&#xff1a; 一、积分法 二、傅里叶级数展开法 附录、常见波形的傅里叶级数 一、积分法 通过对三角波进行积分&#xff0c;即可得到正弦波。有关内容移步&#xff1a;运算放大器应用汇总1之六、积分电路。 下面对傅里叶级数展开法进行描述。 二、傅里叶级数展开法 三…

高通QNX基线编译原理

下面代码以高通智驾平台为例。 1 QNX应用程序编译原理 在高通提供的qnx开发包中,qnx的内核已经由qnx所提供,所以qnx的编译,其实就是大量应用程序的编译,以及最后利用buildfile文件,把内核,库文件以及应用程序打包在一起的过程。 1.1 qnx的工程目录 应用程序的编译,可…

Tomcat服务部署优化

目录 一.Tomcat的基本内容 1.概念 2.构成 &#xff08;1&#xff09;web容器 &#xff08;2&#xff09;servlet容器&#xff08;catalina&#xff09; &#xff08;3&#xff09;JSP容器 3.Tomcat顶层架构 &#xff08;1&#xff09;Tomcat中最顶层的容器是Server&…

运放设计选型中关注的参数-运算放大器选型参数

1、直流增益&#xff08;AVD&#xff09; 直流增益是运放最重要一个属性之一&#xff0c;其定义为输出电压的变化与输入电压变化之比值&#xff0c;通常用V/mV表示这个比值&#xff0c;例如&#xff0c;增益为30000&#xff0c;可表示为30V/mV&#xff0c;有些地方也会把增益用…

盲行的守护者:盲人应用的温暖相伴

作为一个视障人士&#xff0c;我常常对前方的未知感到迷茫。每一步都像是踏入未知的领域&#xff0c;恐惧与不安时刻伴随着我。然而&#xff0c;一款名为蝙蝠避障的盲人手机应用&#xff0c;成为了我前行的明灯。 在这款盲人手机应用的帮助下&#xff0c;我拥有了新的探知世界的…

midjourney提示词语法

更高级的提示可以包括一个或多个图像URL、多个文本短语和一个或更多个参数 Image Prompts 可以将图像URL添加到提示中&#xff0c;以影响最终结果的样式和内容。图像URL总是位于提示的前面。 https://docs.midjourney.com/image-prompts Text Prompt 要生成的图像的文本描述。…

内核中的Kconfig文件

Kconfig解析 编译内核时用于配置的Kconfig文件 以内核中的ttyprintk.c为例&#xff0c;其位于/kernel-sources/dirver/char/ttyprintk.c 如何将其编译进内核&#xff1f; 在char目录下有Kconfig文件&#xff0c;其中有如下内容 tristate 表示该模块可以选择 Y N M(以.ko形…

【书生·浦语大模型实战营】第 2 节 -课后作业

第二节 -轻松玩转书生浦语大模型趣味 Demo-课后作业 0.课程体验0.1 鸡兔同笼0.2 逻辑推理0.3 AI会毁灭人类吗&#xff1f; 1.课后作业1.1 基础作业1.1.1 作业11.1.2 作业2 0.课程体验 课程链接&#xff1a;https://github.com/internLM/tutorial 首先&#xff0c;这个课程是免费…