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

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处理器》

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

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

相关文章

Docker Protainer可视化平台,忘记登录密码,重置密码。

由于好久没有登录portainer系统,导致忘记了登录密码,试了好多常用的密码都不对,无奈只能重置密码。 一、停止protainer 容器 查看容器ID和COMMAND 用于停止容器 docker ps -a停止容器 docker stop portainer二、查找volume data 宿主机所在…

脉冲电阻器负载、功率和电压降额,选型分析

本文讨论了关键的电阻脉冲负载、功率和电压降额参数,这些参数对于正确选择指南和可靠运行这些无源元件非常重要。 EAK脉冲负载 在许多应用中,电阻器将承受脉冲负载。我们区分周期性/重复性负载和脉冲序列;一方面,脉冲以一定频率重复&#xff…

Spring中最常用的11个扩展点

前言 我们一说到spring,可能第一个想到的是 IOC(控制反转) 和 AOP(面向切面编程)。 没错,它们是spring的基石,得益于它们的优秀设计,使得spring能够从众多优秀框架中脱颖而出。 除…

Thingsboard本地源码部署教程

本章将介绍ThingsBoard的本地环境搭建,以及源码的编译安装。本机环境:jdk11、maven 3.6.2、node v12.18.2、idea 2023.1、redis 6.2 环境安装 开发环境要求: Jdk 11 版本 ;Postgresql 9 以上;Maven 3.6 以上&#xf…

PaddleOCR CPU 文本文字识别 docker部署

需求: 需要把所有滑块图片的数据文字提取出来 启动服务 mkdir paddle cd paddle docker run -itd --name ppocr -v $PWD:/paddle --networkhost -it registry.baidubce.com/paddlepaddle/paddle:2.1.3-gpu-cuda10.2-cudnn7 /bin/bash docker exec -it ppocr bash …

深入理解Tomcat

目录: TomcatTomcat简介如何下载tomcatTomcat工作原理Tomcat架构图Tomcat组件Server组件Service组件Connector组件Engine组件Host组件Context组件 配置虚拟主机(Host)配置Context Tomcat Tomcat简介 Tomcat服务器是Apache的一个开源免费的Web容器。它实现了JavaEE…

mysql学习笔记7——数据库查询深入

.sql文件 在实际使用数据库时,常常要对数据库文件进行备份,以便在数据库遭到入侵或者非人为因素导致损坏后,快速恢复数据 .sql文件便提供了这种功能,首先.sql文件是由一串串mysql指令组成的,我们插入.sql文件实际相当…

5G工业智能网关保障煤矿安全生产

随着物联网技术发展与煤矿需求的持续激增,矿山矿井的分布范围广泛、户外环境恶劣等管理问题急需解决,而物联网网关工业级设计能够无惧恶劣环境干扰,轻松解决户外网络部署问题。 工业网关通过采集矿井内的各类传感器数据对矿井进行远程监控&a…

[C#]winform部署yolov9的onnx模型

C# WinForms 部署 YOLOv9 ONNX 模型简介 在当今的计算机视觉领域,目标检测是不可或缺的一项技术。YOLO(You Only Look Once)系列模型以其高效和准确的特点受到了广泛关注。随着YOLOv9的发布,其性能进一步提升,为实际应…

在全志V853平台上成功部署深度学习步态识别算法

北理工通信课题组辛喆同学在本科毕业设计《基于嵌入式系统的步态识别的研究》中,成功将深度步态识别算法GaitSet移植到全志V853开发板上。本研究在CASIA-B数据集上进行测试,正常行走状态下该系统的步态识别准确率达到了94.9%,背包行走和穿外套…

C++输入输出(I\O)

我们知道C是由C语言发展而来的,几乎完全兼容C语言,换句话说,你可以在C里面编译C语言代码。如下图: C语言是面向过程的语言,C在C语言之上增加了面向对象以及泛型编程机制,因此C更适合中大型程序的开发,然而C…

基于MVO优化的Bi-LSTM多输入时序预测(Matlab)多元宇宙算法优化长短期神经网络时序预测

目录 一、程序及算法内容介绍: 基本内容: 亮点与优势: 二、实际运行效果: 三、算法介绍: 四、完整程序下载: 一、程序及算法内容介绍: 基本内容: 本代码基于Matlab平台编译&am…

华为的5中nat配置

1. 静态NAT(服务器地址转换)1:1 静态nat实现了私有地址和公有地址的一对一转换,一个公网地址对应一个私网地址 2. 动态NAT 不进行端口转换(no-pat),多对多,不解决ip地址 动态nat基…

白银期货开户交割规则有哪些?

白银期货交割是指期货合约到期时,交易双方通过该期货合约所载商品所有权的转移,了结到期未平仓合约的过程。小编在此为大家详细介绍白银期货的交割规则有哪些。白银期货的交割规则有哪些?白银期货的交割规则主要有: 一、交割商品…

比特币终局:或将等于人类全部剩余的价值总和!

原创 | 刘教链 草长莺飞二月天,拂堤杨柳醉春烟。 还有不到一周,便是农历二月天。这加密市场,也真的是一片草长莺飞,春意盎然。 不久前,比特币怒发冲冠,急破6万刀重要关口。2月29日教链文章赞曰《比特币始本…

第十七天-反爬与反反爬-验证码识别

目录 反爬虫介绍 基于身份识别反爬和解决思路 Headers反爬-使用User-agent Headers反爬-使用coookie字段 Headers反爬-使用Referer字段 基于参数反爬 验证码反爬 1.验证码介绍 2.验证码分类: 3.验证码作用 4.处理方案 5.图片识别引擎:ocr 6.使用打码平…

QT入门介绍

简单使用 1、创建工程项目 创建类的基类&#xff1a; 带菜单栏的窗口、空白窗口、对话框窗口 2、QT中文乱码解决 3、按钮属性 #include <QPushButton>QPushButton *button new QPushButton; // button->show(); button->setParent(this); // 设置按钮的父对象…

【go从入门到精通】go环境安装和第一个经典程序

go下载和环境变量配置 下载地址 Go官网下载地址&#xff1a;https://golang.org/dl/All releases - The Go Programming Languagehttps://golang.org/dl/ 然后根据自己的系统环境来选择不同的安装包下载&#xff0c;下面我分别针对不同环境进行说明&#xff08;大家可以根据自…

Rabbitmq消息丢失-生产者消息丢失(一)

说明&#xff1a;消息生产者在将数据发送到Mq的时候&#xff0c;可能由于网络等原因造成数据投递失败。 消息丢失大致分三种&#xff1a;这里说的是生产者消息丢失&#xff01; 分析原因&#xff1a; 1.有没有一种可能&#xff0c;我刚发送消息&#xff0c;消息还没有到交换…

超全Chat GPT论文修改指令

文献综述指令润色修改指令论文选题指令论文大指令研究理论指令论文致谢指令参考文献指令论文润色整体逻辑论文整体优化提问指令 1&#xff0e;文献综述指令 请你帮我写一份关于&#xff08;研究主题&#xff09;的文献综述。我的论文选题方向是 XXXX &#xff0c;我已经找到了…