RISC-V特权架构 - 机器模式下的异常处理

news2025/1/11 16:50:48

RISC-V特权架构 - 机器模式下的异常处理

  • 1 进入异常
    • 1.1 从mtvec 定义的PC 地址开始执行
    • 1.2 更新CSR 寄存器mcause
    • 1.3 更新CSR 寄存器mepc
    • 1.4 更新CSR 寄存器mtval
    • 1.5 更新CSR 寄存器mstatus
  • 2 退出异常
    • 2.1 从mepc 定义的PC 地址开始执行
    • 2.2 更新CSR 寄存器mstatus
  • 3 异常服务程序

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

狭义的中断和异常,均可以被归于广义的异常范畴,因此本文自此将用“异常”作为统一概念进行论述,其包含了狭义上的“中断”和“异常”

RISC-V 定义的三种模式 User、Supervisor 和 Machine,均可发生异常,但是只有特权模式 SupervisorMachine 才能处理异常,因为处理异常需要 CSR 寄存器。默认情况下,RISC-V所有的异常,都在Machine模式下处理。除此以外,还可以通过委托机制,将异常委托给Supervisor模式下处理。

这里本文介绍的是Machine模式下的异常处理机制。

1 进入异常

进入异常时,RISC-V 架构规定的硬件行为,可以简述如下:

(1)停止执行当前程序流,转而从CSR 寄存器mtvec 定义的PC 地址开始执行。

(2)进入异常,不仅会让处理器跳转到,上述的PC 地址开始执行,还会让硬件,同时更新其他几个CSR 寄存器,分别是以下4 个寄存器:

  • 机器模式异常原因寄存器mcause(Machine Cause Register)
  • 机器模式异常PC 寄存器mepc(Machine Exception Program Counter)
  • 机器模式异常值寄存器mtval(Machine Trap Value Register )
  • 机器模式状态寄存器mstatus(Machine Status Register)

下文将分别予以详述。

1.1 从mtvec 定义的PC 地址开始执行

RISC-V 架构规定,在处理器的程序执行过程中,一旦遇到异常发生,则终止当前的程序流,处理器被强行跳转到一个新的PC 地址。该过程在RISC-V 的架构中定义为“陷阱(trap)”,字面含义为“跳入陷阱”,更加准确的意译为“进入异常”。

RISC-V 处理器trap 后跳入的PC 地址,由一个叫做机器模式异常入口基地址寄存器mtvec(Machine Trap-Vector Base-Address Register)的CSR 寄存器指定,其要点如下:

(1)mtvec 寄存器是一个可读可写的CSR 寄存器,因此软件可以编程更改其中的值。

(2)mtvec 寄存器的详细格式,如下图所示,其中的最低2 位是MODE 域,高30 位是BASE 域。(32位架构下,XLEN为32;64位架构下,XLEN为64。)
在这里插入图片描述

  • 假设MODE 的值为0,则所有的异常响应时,处理器均跳转到BASE 值指示的PC 地址。
  • 假设MODE 的值为1,则狭义的异常发生时,处理器跳转到BASE 值指示的PC 地址;狭义的中断发生时,处理器跳转到BASE+4*CAUSE 值指示的PC 地址。CAUSE的值,表示中断对应的异常编号(Exception Code),如下图所示(Machine cause register (mcause) values)。譬如机器计时器中断(Machine Timer Interrupt)的异常编号为7,则其跳转的地址为BASE+4×7=BASE+28= BASE+0x1c。

1.2 更新CSR 寄存器mcause

RISC-V 架构规定,在进入异常时,机器模式异常原因寄存器mcause(Machine Cause Register)被同时更新,以反映当前的异常种类,软件可以通过读此寄存器,查询造成异常的具体原因。

mcause 寄存器的详细格式,如下图所示,其中最高1 位为Interrupt 域,低31 位为异常编号域。
在这里插入图片描述
此两个域的组合表示值,如下图所示,用于指示RISC-V 架构定义的12 种中断类型和16 种异常类型。 在这里插入图片描述

1.3 更新CSR 寄存器mepc

RISC-V 架构定义,异常的返回地址由机器模式异常PC 寄存器mepc(Machine Exception Program Counter)保存。
在这里插入图片描述
在进入异常时,硬件将自动更新mepc 寄存器的值,为当前遇到异常的指令PC 值(即当前程序的停止执行点)。该寄存器将作为异常的返回地址,在异常结束之后,能够使用它保存的PC 值,回到之前被停止执行的程序点。

(1)值得注意的是,虽然mepc 寄存器会在异常发生时,自动被硬件更新,但是mepc 寄存器,本身也是一个可读可写的寄存器,因此软件也可以直接写该寄存器以修改其值。

(2)对于狭义的中断和狭义的异常而言,RISC-V 架构定义其返回地址(更新的mepc 值)有些细微差别:

  • 出现中断时,中断返回地址mepc 的值,被更新为下一条尚未执行的指令
  • 出现异常时,中断返回地址mepc 的值,被更新为当前发生异常的指令PC

注意:
如果异常由ecall 或ebreak 产生,由于mepc 的值被更新为ecall 或ebreak 指令自己的PC。因此在异常返回时,如果直接使用mepc 保存的PC值作为返回地址,则会再次跳回ecall 或者ebreak指令,从而造成死循环(执行ecall 或者ebreak 指令导致重新进入异常)。正确的做法是,在异常处理程序中,软件改变mepc指向下一条指令,由于现在ecall/ebreak(或c.ebreak)是4(或2)字节指令,因此改写设定 mepc=mepc+4(或+2) 即可。

1.4 更新CSR 寄存器mtval

在这里插入图片描述
RISC-V 架构规定,在进入异常时,硬件将自动更新机器模式异常值寄存器mtval(Machine Trap Value Register ),以反映引起当前异常的存储器访问地址或者指令编码。

  • 如果是由存储器访问造成的异常,譬如遭遇硬件断点、取指令、存储器读写造成的异常,则将存储器访问的地址,更新到mtval 寄存器中。
  • 如果是由非法指令造成的异常,则将该指令的指令编码,更新到mtval 寄存器中。

注意:mtval 寄存器,又名mbadaddr 寄存器,在某些早期版本的RISC-V 编译器中仅识别mbadaddr 名称。

1.5 更新CSR 寄存器mstatus

RISC-V 架构规定,在进入异常时,硬件将自动更新机器模式状态寄存器mstatus(Machine Status Register)的某些域。
在这里插入图片描述
(1)mstatus 寄存器的详细格式,如上图所示,其中的MIE 域,表示在Machine Mode 下中断全局使能。

  • 当该MIE 域的值为1 时,表示Machine Mode 下所有中断的全局打开。
  • 当该MIE 域的值为0 时,表示Machine Mode 下所有中断的全局关闭。

(2)RISC-V 架构规定,异常发生时有如下情况。

  • MPIE 域的值,被更新为异常发生前MIE 域的值。MPIE 域的作用,是在异常结束之后,能够使用MPIE 的值,恢复出异常发生之前的MIE 值。
  • MIE 的值,则被更新成为0(意味着进入异常服务程序后,中断被全局关闭,所有的中断都将被屏蔽不响应)。也就是说,RISC-V架构默认不支持中断嵌套。
  • MPP 的值,被更新为异常发生前的模式。MPP 域的作用,是在异常结束之后,能够使用MPP 的值,恢复出异常发生之前的工作模式。对于只支持机器模式(Machine Mode Only)的处理器核,则MPP 的值永远为二进制值11。

注意:由于为简化知识模型,在此仅介绍“只支持机器模式”的架构,因此对SIE、UIE、SPP、SPIE 等不做赘述。

2 退出异常

当程序完成异常处理之后,最终需要从异常服务程序中退出,并返回主程序。RISC-V架构定义了一组专门的退出异常指令(Trap-Return Instructions),包括MRET、SRET、和URET。

  • 其中MRET 指令是必备的;
  • 而SRET 和URET 指令,仅在支持监督模式和用户模式的处理器中使用。

注意:由于为简化知识模型,在此仅介绍“只支持机器模式”的架构,对SRET 和URET 指令不做赘述。

在机器模式下,退出异常时,软件必须使用MRET 指令。
RISC-V 架构规定,处理器执行MRET 指令后的硬件行为,如下:

  • 停止执行当前程序流,转而从CSR 寄存器mepc 定义的PC 地址开始执行。
  • 执行MRET 指令,不仅会让处理器跳转到上述的PC 地址开始执行,还会让硬件同时更新CSR 寄存器机器模式状态寄存器mstatus(Machine Status Register)。

下文将分别予以详述。

2.1 从mepc 定义的PC 地址开始执行

在上文中曾经提及,在进入异常时,mepc 寄存器被同时更新,以反映当时遇到异常的指令的PC 值。通过这个机制,意味着MRET 指令执行后,处理器回到了当时遇到异常的指令的PC 地址,从而可以继续执行之前被中止的程序流。

2.2 更新CSR 寄存器mstatus

mstatus 寄存器的详细格式,如上图所示。RISC-V 架构规定,在执行MRET 指令后,硬件将自动更新机器模式状态寄存器mstatus(Machine Status Register)的某些域。

RISC-V 架构规定,执行MRET 指令退出异常时有如下情况:

  • mstatus 寄存器MIE 域的值,被更新为当前MPIE 的值(恢复)。
  • mstatus 寄存器MPIE 域的值,则被更新为1。

在上文中曾提及,在进入异常时,MPIE 的值曾经被更新为异常发生前的MIE 值。而MRET 指令执行后,再次将MIE 域的值更新为MPIE 的值。通过这个机制,则意味着MRET指令执行后,处理器的MIE 值被恢复成异常发生之前的值(假设之前的MIE 值为1,则意味着中断被重新全局打开)。

3 异常服务程序

如上文中所述,当处理器进入异常后,即开始从mtvec 寄存器定义的PC 地址执行新的程序。该程序通常为异常服务程序,并且程序还可以通过查询mcause 中的异常编号(Exception Code)决定进一步跳转到更具体的异常服务程序。

譬如当程序查询mcause 中的值为0x2,则得知该异常,是非法指令错误(Illegal Instructions)引起的,因此可以进一步跳转到,非法指令错误异常服务子程序中去。

下图所示为一异常入口程序实例片段,程序通过读取mcause 的值,进而判断异常的类型,从而进入不同的异常服务子程序。
在这里插入图片描述

注意:
由于RISC-V 架构规定的进入异常和退出异常机制中没有硬件自动保存和恢复上下文的操作,因此需要软件明确地使用指令进行上下文的保存和恢复。


参考文档:

  • 《手把手教你设计CPU.RISC-V处理器》

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

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

相关文章

Collection接口常用方法总结。

Collection接口常用方法总结。 1. 常用的Collection接口方法2. 代码示例 Java中的Collection接口是所有集合类的父接口,它定义了集合类的基本行为和操作。 1. 常用的Collection接口方法 boolean add(E e) : 将指定元素添加到集合中(如果成功则返回tru…

设计师必读:打造作品集封面的关键思路!

精致美观的作品集封面设计可以在最短的时间内吸引甲方或面试官的注意,让他们快速了解你的实力水平。作品集的封面设计是整个作品集的门面,也是高质量作品集的关键。独特的作品集封面设计能起到更引人入胜的效果。那么,如何设计出独特醒目的作…

基于springboot+vue的物流管理系统

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战,欢迎高校老师\讲师\同行交流合作 ​主要内容:毕业设计(Javaweb项目|小程序|Pyt…

EIP-1559

EIP EIP是以太坊改进提案(Ethereum Improvement Proposal)的缩写。它是一种标准化的提案制度,用于描述和讨论对以太坊区块链网络的改进和升级。EIP的目的是提供一个开放的、透明的过程,让社区成员、开发者和其他利益相关者能够共同…

Linux 驱动 中断(二)

中断下半部 在 Linux 内核中,中断下半部(也称为中断下半场)是指在中断服务程序(Top Half)执行完毕后,在上下文之外延迟执行的一些操作。中断下半部通常用于处理那些不适合在中断上下文中立即执行的任务&am…

YOLOv5创新改进:SPPF创新涨点篇 | SPPELAN:SPP创新结合ELAN ,效果优于SPP、SPPF| YOLOv9

💡💡💡本文独家改进:新颖SPPF创新涨点改进,SPP创新结合ELAN,来自于YOLOv9,助力YOLOv5,将SPPELAN代替原始的SPPF 💡💡💡在多个私有数据集和公开数据集VisDrone2019、PASCAL VOC实现涨点 收录 YOLOv5原创自研 https://blog.csdn.net/m0_63774211/category_12…

Java多线程导入Excel示例

在导入Excel的时候,如果文件比较大,行数很多,一行行读往往速度比较慢,为了加快导入速度,我们可以采用多线程的方式 话不多说直接上代码 首先是Controller import com.sakura.base.service.ExcelService; import com.s…

URI is not registered (Settings | Languages Frameworks | Schemas and DTDs)

在我们实际编码,配置xml文件时,会出现如下的问题 因此应该从File->Settings-> 这样在xml中就显示正常了

SpringMVC--03--前端传数组给后台

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 案例1乘客个人信息方法1:表单提交,以字段数组接收方法2:表单提交,以BeanListModel接收方法3:将Json对象序…

S2---FPGA-A7板级原理图硬件实战

视频链接 FPGA-A7板级系统硬件实战01_哔哩哔哩_bilibili FPGA-A7板级原理图硬件实战 基于XC7A100TFGG484的FPGA硬件设计流程图 A7核心板,是基于XILINX公司的ARTIX-7系列100T的XC7A100T,2FGG484I这款芯片开发的高性能核心板,具有高速,高带宽&a…

B084-SpringCloud-Zuul Config

目录 zuul系统架构和zuul的作用zuul网关实现配置映射路径过滤器 Config概述云端管理本地配置 zuul zuul是分布式和集群后前端统一访问入口 系统架构和zuul的作用 zuul把自己注册进eureka,然后可通过前端传来的服务名发现和访问对应的服务集群 为了预防zuul单点故…

Raid5阵列数据恢复+Openmediavault配置内网与外网远程访问+服务器到服务器的大量文件转移备份

一、适用场景: 1、OpenMediaVault,是一个开源的(免费)基于Debian Linux的下一代网络附加存储(NAS)解决方案。 2、易于使用的 WEB 管理界面:OpenMediaVault 的用户界面设计直观,即使是没有 Linux 经验的用户…

FPGA-AXI4接口协议概述

假设我们要传一帧1080P的图片到显示屏显示,那么需要多大的储存空间呢? 一帧1080P的RGB565图像数据需要1920*1080*1633.1776Mb 存储空间 下图是ZYNQ-7000系列中Block RAM的大小: 可以看到最大存储空间的BRAM都不能存储一帧图片,那…

#QT(智能家居界面-布局)

1.IDE:QTCreator 2.实验: 水平布局,垂直布局,栅格布局(弹簧) 界面自动调整 3.记录 注意弹簧不是拖拽拉长,而是使用栅格布局 运行发现窗口放大缩小可以自动调整 如果想要重新布局,需…

【短时交通流量预测】基于双层BP神经网络

课题名称:基于双层BP神经网络的短时交通流量预测 版本时间:2023-04-27 代码获取方式:QQ:491052175 或者 私聊博主获取 模型简介: 城市交通路网中交通路段上某时刻的交通流量与本路段前几个时段的交通流量有关&…

为什么各品牌主食冻干差价那么大?真正性价比高的主食冻干分享

随着科学养猫知识的普及,主食冻干喂养逐渐受到了许多铲屎官的青睐。然而,也有不少的铲屎官看到主食冻干的价格望而却步。实际上,像我这样的资深铲屎官早已开始主食冻干喂养。虽然主食冻干的价格相对于烘焙粮和膨化粮要高一些,但它…

es6 相关面试题

1 var, let ,const 区别? 2 手写将对象进行合并 手写合并对象 3 普通函数和箭头函数区别? 4 find 和 filter的区别? 5 some和every区别?

OCR 文字识别在未来会有哪些发展趋势?

随着技术的不断进步,OCR(光学字符识别)文字识别技术也在不断发展。未来,OCR 文字识别技术将会呈现以下几个发展趋势: 一、更高的识别准确率 OCR 技术的核心是识别准确率。随着深度学习等人工智能技术的发展&#xff0c…

测温线夹装置

测温线夹是一种用于测量温度的装置,通常用于电力系统中监测电气设备的温度。它可以安装在电气设备的导线上,通过感应导线的温度来测量电气设备的运行状态。测温线夹通常由金属材料制成,具有耐高温、耐腐蚀等特点,适用于各种恶劣的…

一文读懂Persistence One- 如何将Restaking带入Cosmos

Persistence One正在将Restaking引入Cosmos。用户将能够通过pSTAKE、Stride、Quicksilver和Milkyway将Liquid Staked Tokens(如ATOM、TIA、DYDX等)存入Persistence One,对其进行Restaking,从而安全地连接更多区块链,首…