RISC-V特权架构 - 中断定义

news/2024/4/29 20:00:56

RISC-V特权架构 - 中断定义

  • 1 中断类型
    • 1.1 外部中断
    • 1.2 计时器中断
    • 1.3 软件中断
    • 1.4 调试中断
  • 2 中断屏蔽
  • 3 中断等待
  • 4 中断优先级与仲裁
  • 5 中断嵌套
  • 6 异常相关寄存器

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

1 中断类型

RISC-V 架构定义的中断类型分为4 种:

  • 外部中断(External Interrupt)
  • 计时器中断(Timer Interrupt)
  • 软件中断(Software Interrupt)
  • 调试中断(Debug Interrupt)

下文将分别予以详述,由于本文为简化知识模型,在此仅介绍“机器模式”的相关内容。

1.1 外部中断

RISC-V 架构定义的外部中断,要点如下:

  • (1)外部中断,是指来自于处理器核外部的中断,譬如外部设备UART、GPIO 等产生的中断。
  • (2)RISC-V 架构,在机器模式、监督模式和用户模式下,均有对应的外部中断
  • (3)机器模式外部中断(Machine External Interrupt)的屏蔽,由CSR 寄存器mie 中的MEIE域控制;等待(Pending)标志,则反映在CSR 寄存器mip 中的MEIP 域。
  • (4)机器模式外部中断,可以作为处理器核的一个单比特输入信号,假设处理器需要支持很多个外部中断源,RISC-V 架构定义了一个平台级别中断控制器(Platform Level Interrupt Controller,PLIC)可用于多个外部中断源的优先级仲裁和派发。
    • PLIC 可以将多个外部中断源,仲裁为一个单比特的中断信号送入处理器核,处理器核收到中断,进入异常服务程序后,可以通过读PLIC 的相关寄存器,查看中断源的编号和信息。
    • 处理器核,在处理完相应的中断服务程序后,可以通过写PLIC 的相关寄存器和具体的外部中断源的寄存器,从而清除中断源(假设中断来源为GPIO,则可通过GPIO 模块的中断相关寄存器,清除该中断)。
  • (5)虽然RISC-V 架构,只明确定义了一个机器模式外部中断,同时明确定义可通过PLIC在外部管理众多的外部中断源,将其仲裁成为一根机器模式外部中断信号,传递给处理器核。但是RISC-V 架构,也预留了大量的空间,供用户扩展其他外部中断类型,如以下3 种。
    • CSR 寄存器mie 和mip 的高20 位,可以用于扩展控制其他的自定义中断类型。
    • 用户甚至可以自定义若干组新的mie和mip寄存器,以支持更多自定义中断类型。
    • CSR 寄存器mcause 的中断异常编号域为12 及以上的值,均可以用于其他自定义中断的异常编号(Exception Code)。因此理论上通过扩展,RISC-V 架构可以支持无数根自定义的外部中断(External Interrupt)信号,直接输入给处理器核。

1.2 计时器中断

RISC-V 架构定义的计时器中断,要点如下:

  • (1)计时器中断,是指来自计时器的中断。
  • (2)RISC-V 架构,在机器模式、监督模式和用户模式下,均有对应的计时器中断
  • (3)机器模式计时器中断的屏蔽,由mie 寄存器中的MTIE 域控制,等待(Pending)标志则反映在mip 寄存器中的MTIP 域。
  • (4)RISC-V 架构定义了,系统平台中必须有一个计时器,并给该计时器定义了两个64 位宽的寄存器mtimemtimecmp。mtime 寄存器用于反映当前计时器的计数值,mtimecmp 用于设置计时器的比较值。当mtime 中的计数值大于或者等于mtimecmp 中设置的比较值时,计时器便会产生计时器中断。计时器中断会一直拉高,直到软件重新写mtimecmp 寄存器的值,使得其比较值大于mtime 中的值,从而将计时器中断清除。
    • 值得注意的是,RISC-V 架构,并没有定义mtime 寄存器和mtimecmp 寄存器为CSR寄存器,而是定义其为存储器地址映射(Memory Address Mapped)的系统寄存器,具体的存储器映射(Memory Mapped)地址RISC-V 架构并没有规定,而是交由SoC系统集成者实现。
    • 另一点值得注意的是,RISC-V 架构定义mtime 定时器,为实时(Real-Time)计时器,系统必须以一种恒定的频率作为计时器的时钟。该恒定的时钟频率必须为,低速的电源常开的(Always-on)时钟,低速是为了省电,常开是为了提供准确的计时。

在这里插入图片描述

1.3 软件中断

RISC-V 架构定义的软件中断,要点如下:

  • (1)软件中断,是指来自软件自己触发的中断。
  • (2)由于RISC-V 架构,在机器模式、监督模式和用户模式下,均有对应的软件中断
  • (3)机器模式软件中断的屏蔽,由mie 寄存器中的MSIE 域控制,等待(Pending)标志则反映在mip 寄存器中的MSIP 域。
  • (4)RISC-V 架构定义的机器模式软件中断,可以通过软件写1 至msip 寄存器来触发
    • 注意:此msip 寄存器和mip 寄存器中的MSIP 域,命名不可混淆。且RISC-V 架构,并没有定义msip 寄存器为CSR 寄存器,而是定义其为存储器地址映射的系统寄存器,具体的存储器映射地址RISC-V 架构并没有规定,而是交由SoC 系统集成者实现。
  • (5)当软件写1 至msip 寄存器,触发了软件中断之后,CSR 寄存器mip 中的MSIP 域便会置高,反映其等待状态。软件可通过写0 至msip 寄存器来清除该软件中断。

1.4 调试中断

除了上述3 种中断之外,还有一种特殊的中断——调试中断(Debug Interrupt),此中断专用于实现调试器(Debugger)。

2 中断屏蔽

RISC-V 架构的狭义上的异常,是不可以被屏蔽的,也就是说一旦发生狭义上的异常,处理器一定会停止当前操作转而处理异常。但是狭义上的中断,则可以被屏蔽掉,RISC-V 架构定义了CSR 寄存器机器模式中断使能寄存器mie(Machine Interrupt Enable Registers)可以用于控制中断的屏蔽。
在这里插入图片描述

  • (1)mie 寄存器的详细格式,如上图,其中每一个比特域,用于控制每个单独的中断使能。
    • MEIE 域控制机器模式(Machine Mode)下,外部中断(External Interrupt)的屏蔽。
    • MTIE 域控制机器模式(Machine Mode)下,计时器中断(Timer Interrupt)的屏蔽。
    • MSIE 域控制机器模式(Machine Mode)下,软件中断(Software Interrupt)的屏蔽。
  • (2)软件可以通过写mie 寄存器中的值,达到屏蔽某些中断的效果。假设MTIE 域为被设置成0,则意味着将计时器中断屏蔽,处理器将无法响应计时器中断。
  • (3)如果处理器只实现了机器模式,则监督模式和用户模式对应的中断使能位(SEIE、UEIE、STIE、UTIE、SSIE 和USIE)无任何意义。

注意
除了对3 种中断的分别屏蔽,通过mstatus 寄存器中的MIE 域,还可以全局关闭所有中断

3 中断等待

RISC-V 架构定义了,CSR 寄存器机器模式中断等待寄存器mip(Machine Interrupt Pending Registers),可以用于查询中断的等待状态。
在这里插入图片描述

  • (1)mip 寄存器的详细格式,如上图所示,其中的每一个域,用于反映每个单独的中断等待状态(Pending)。
    • MEIP 域反映机器模式(Machine Mode)下的,外部中断的等待(Pending)状态。
    • MTIP 域反映机器模式(Machine Mode)下的,计时器中断的等待(Pending)状态。
    • MSIP 域反映机器模式(Machine Mode)下的,软件中断的等待(Pending)状态。
  • (2)如果处理器只实现了机器模式,则mip 寄存器中监督模式和用户模式对应的中断等待状态位(SEIP、UEIP、STIP、UTIP、SSIP 和USIP)无任何意义。
  • (3)软件可以通过读mip 寄存器中的值,达到查询中断状态的效果
    • 如果MTIP 域的值为1,则表示当前有计时器中断(Timer Interrupt)正在等待“Pending”。
    • 注意: 即便mie 寄存器中MTIE 域的值为0(被屏蔽),如果计时器中断到来,则MTIP 域仍然能够显示为1。也就是说,mie寄存器将中断屏蔽,只是让处理器无法响应中断,但是mip的pending状态仍然存在
    • MSIP、MEIP 与MTIP 同理。
  • (4)MEIP/MTIP/MSIP 域的属性均为只读,软件无法直接写这些域改变其值。只有这些中断的源头,被清除后将中断源撤销,MEIP/MTIP/MSIP 域的值才能相应地归零。譬如MEIP对应的外部中断,需要程序进入中断服务程序后,配置外部中断源,将其中断撤销。MTIP 和MSIP 同理。

下一节将详细介绍,中断的类型和清除方法。

4 中断优先级与仲裁

对于中断而言,多个中断可能存在着优先级仲裁的情况。对于RISC-V 架构而言,分为如下3 种情况:

  • (1)如果3 种中断同时发生,其响应的优先级顺序如下,mcause 寄存器中,将按此优先级顺序选择更新异常编号(Exception Code)的值。
    • 外部中断(External Interrupt)优先级最高
    • 软件中断(Software Interrupt)其次。
    • 计时器中断(Timer Interrupt)再次。
  • (2)调试中断比较特殊。只有调试器(Debugger)介入调试时才发生,正常情形下不会发生,因此在此不予讨论。
  • (3)由于外部中断来自PLIC,而PLIC 可以管理数量众多的外部中断源,多个外部中断源之间的优先级和仲裁,可通过配置PLIC 的寄存器进行管理。

5 中断嵌套

曾经提到多个中断,理论上可能存在着中断嵌套的情况。而对于RISC-V 架构而言:

  • 进入异常之后,mstatus 寄存器中的MIE 域,将会被硬件自动更新成为0(意味着中断被全局关闭,从而无法响应新的中断)。
  • 退出中断后,MIE 域才被硬件自动恢复成中断发生之前的值(通过MPIE 域得到),从而再次全局打开中断。

由上可见,一旦响应中断进入异常模式后,中断被全局关闭再也无法响应新的中断,因此RISC-V 架构定义的硬件机制,默认无法支持硬件中断嵌套行为。

如果一定要支持中断嵌套,需要使用软件的方式,达到中断嵌套的目的,从理论上来讲,可采用如下方法:

  • (1)在进入异常之后,软件通过查询mcause 寄存器,确认这是响应中断造成的异常,并跳入相应的中断服务程序中。在这期间,由于mstatus 寄存器中的MIE 域被硬件自动更新成为0,因此新的中断都不会被响应。
  • (2)待程序跳入中断服务程序中后,软件可以强行改写mstatus 寄存器的值,而将MIE域的值改为1,意味着将中断再次全局打开。从此时起,处理器将能够再次响应中断。但是在强行打开MIE 域之前,需要注意如下事项。
    • 假设软件希望屏蔽比其优先级低的中断,而仅允许优先级比它高的新来打断当前中断,那么软件需要通过配置mie 寄存器中的MEIE/MTIE/MSIE 域,来有选择地屏蔽不同类型的中断。
    • 对于PLIC 管理的众多外部中断而言,由于其优先级受PLIC 控制,假设软件希望屏蔽比其优先级低的中断,而仅允许优先级比它高的新来中断打断当前中断,那么软件需要通过配置PLIC 阈值(Threshold)寄存器的方式,来有选择地屏蔽不同类型的中断。
  • (3)在中断嵌套的过程中,软件需要注意保存上下文至存储器堆栈中,或者从存储器堆栈中将上下文恢复(与函数嵌套同理)。
  • (4)在中断嵌套的过程中,软件还需要注意将mepc 寄存器,以及为了实现软件中断嵌套,被修改的其他CSR 寄存器的值,保存至存储器堆栈中,或者从存储器堆栈中恢复(与函数嵌套同理)。

除此之外,RISC-V 架构,也允许用户实现自定义的中断控制器,实现硬件中断嵌套功能。

6 异常相关寄存器

将RISC-V 架构中,所有中断和异常相关的寄存器(M模式),加以总结,如下表所示:
在这里插入图片描述


参考文档:

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

http://www.mrgr.cn/p/41724171

相关文章

数字孪生关键技术及体系架构

摘要: 数字孪生以各领域日益庞大的数据为基本要素,借助发展迅速的建模仿真、人工智能、虚拟现实等先进技术,构建物理实体在虚拟空间中的数字孪生体,实现对物理实体的数字化管控与优化,开拓了企业数字化转型的可行思路…

Codeforces Round 937 (Div. 4) A - F 题解

A. Stair, Peak, or Neither? 题解&#xff1a;直接比较输出即可。 代码&#xff1a; #include<bits/stdc.h> using namespace std ; typedef long long ll ; const int maxn 2e5 7 ; const int mod 1e9 7 ; inline ll read() {ll x 0, f 1 ;char c getchar()…

论文《Exploring to Prompt for Vision-Language Models》阅读

论文《Exploring to Prompt for Vision-Language Models》阅读 论文概况论文动机&#xff08;Intro&#xff09;MethodologyPreliminaryCoOp[CLASS]位置Context 是否跨 class 共享表示和训练 ExperimentsOverall ComparisonDomain GeneralizationContext Length (M) 和 backbon…

uni-app(使用阿里图标)

1.注册阿里矢量图标库 注册阿里图标库账号并登录&#xff0c;https://www.iconfont.cn/ 2.加入购物车 搜索适合自己的图标&#xff0c;加入购物车&#xff0c;如下图&#xff1a; 3.加入项目 我的->资源管理->我的项目->创建项目&#xff0c;然后返回购物车&#…

企微获客助手功能,行为触发如何实现回传的?

获客助手&#xff0c;这个听起来就相当酷炫的名字&#xff0c;它实际上是一个帮助企业将推广流量快速导入企业微信的神器。通过它&#xff0c;企业可以吸引越来越多的用户加为好友&#xff0c;从而建立起更紧密的客户关系。但是&#xff0c;如何进一步提升导入企业微信的流量质…

vector类(二)

文章目录 vector类的模拟实现1.默认成员变量和函数2.迭代器函数3.空间容量和长度4.[ ]下标调用5.插入操作&#xff08;尾插&#xff09;6.调整容量大小7.判空操作8.删除操作9.插入操作10.size空间大小11.消除操作 vector类的模拟实现 1.默认成员变量和函数 首先自定义构造vec…

Vite 为什么比 Webpack 快?

目录 1. Webpack 的构建原理 2. Script 的模块化&#xff08;主流浏览器对 ES Modules 的支持&#xff09; 3. Webpack vs Vite 开发模式的差异 对 ES Modules 的支持 底层语言的差异 热更新的处理 1. Webpack 的构建原理 前端之所以需要类似于 Webpack 这样的构建工具&…

C++基本语法

C是如何工作的 文章目录 C是如何工作的1、新建Hello World工程1.1使用Visual Studio新建项目1.2 HelloWorld1.2.1 命名空间1.2.2 输出输出 1.3 注释1.4 函数1.4.1 使用有返回的函数1.4.2 自定义函数 1、新建Hello World工程 1.1使用Visual Studio新建项目 按照下面的图片&…

数组---

1、数组的定义 Java中&#xff0c;数组存储固定大小的同类型元素。 数组是多个相同类型数据按一定顺序排列的集合&#xff0c;并使用一个名字命名&#xff0c;通过编号的方式对这些数据进行统一的管理。 数组的特点&#xff1a; 数组本身是引用数据类型&#xff0c;但数组中的…

计算机专业学习单片机有什么意义吗?

玩单片机跟玩计算机区别还是很大的, 单片机有众多的种类,每一种又可能有很多个系列.可以说单片机就是为了专款专用而生的.这样来达到产品成本的降低,这就是现在身边的很多的电子产品价格一降再降的原因之一.在开始前我有一些资料&#xff0c;是我根据网友给的问题精心整理了一…

admin端

一、创建项目 1.1 技术栈 1.2 vite 项目初始化 npm init vitelatest vue3-element-admin --template vue-ts 1.3 src 路径别名配置 Vite 配置 配置 vite.config.ts // https://vitejs.dev/config/import { UserConfig, ConfigEnv, loadEnv, defineConfig } from vite im…

Kubernetes Gateway API 介绍

Kubernetes Gateway API 诞生背景 在 kubernetes 中&#xff0c;流量的治理主要分为两个部分&#xff1a; 南北向流量东西向流量 南北向流量&#xff08;NORTH-SOUTH traffic&#xff09; 在计算机网络中&#xff0c;南北向流量通常指数据流量从一个**内部网络&#xff08;…

前后端分离开发【Yapi平台】【Swagger注解自动生成接口文档平台】

前后端分离开发 介绍开发流程Yapi&#xff08;api接口文档编写平台&#xff09;介绍 Swagger使用方式1). 导入knife4j的maven坐标2). 导入knife4j相关配置类3). 设置静态资源映射4). 在LoginCheckFilter中设置不需要处理的请求路径 查看接口文档常用注解注解介绍 当前项目中&am…

笔记本电脑死机了怎么办?

笔记本死机是常有的事&#xff0c;尤其是在玩游戏、看电影或者是使用办公软件的时候&#xff0c;电脑卡住了&#xff0c;无论你怎么按鼠标或键盘&#xff0c;显示屏始终没有反应。那么笔记本电脑死机了怎么办呢?接下来跟大家分享几个小技巧来快速解决这类死机问题&#xff0c;…

uniapp对接萤石云 实现监控播放、云台控制、截图、录像、历史映像等功能

萤石云开发平台地址&#xff1a;文档概述 萤石开放平台API文档 (ys7.com) 萤石云监控播放 首先引入萤石云js js地址&#xff1a;GitHub - Ezviz-OpenBiz/EZUIKit-JavaScript-npm: 轻应用npm版本&#xff0c;降低接入难度&#xff0c;适配自定义UI&#xff0c;适配主流框架 vi…

Ansible-1

Ansible是一款自动化运维、批量管理服务器的工具&#xff0c;批量系统配置、程序部署、运行命令等功能。基于Python开发&#xff0c;基于ssh进行管理&#xff0c;不需要在被管理端安装任何软件。Ansible在管理远程主机的时候&#xff0c;只有是通过各种模块进行操作的。 需要关…

|行业洞察·趋势报告|《2024旅游度假市场简析报告-17页》

报告的主要内容解读&#xff1a; 居民收入提高推动旅游业发展&#xff1a;报告指出&#xff0c;随着人均GDP的提升&#xff0c;居民的消费能力增强&#xff0c;旅游需求从传统的观光游向休闲、度假游转变&#xff0c;国内人均旅游消费持续增加。 政府政策促进旅游市场复苏&…

iOS - Runtime-API

文章目录 iOS - Runtime-API1. Runtime应用1.1 字典转模型1.2 替换方法实现1.3 利用关联对象给分类添加属性1.4 利用消息转发机制&#xff0c;解决方法找不到的异常问题 2. Runtime-API2.1 Runtime API01 – 类2.1.1 动态创建一个类&#xff08;参数&#xff1a;父类&#xff0…

分类任务中的评估指标:Accuracy、Precision、Recall、F1

概念理解 T P TP TP、 T N TN TN、 F P FP FP、 F N FN FN精度/正确率&#xff08; A c c u r a c y Accuracy Accuracy&#xff09; 二分类查准率 P r e c i s i o n Precision Precision&#xff0c;查全率 R e c a l l Recall Recall 和 F 1 − s c o r e F1-score F1−s…

关于使用vscode搭建c/c++编程环境

目录 关于使用vscode搭建c/c编程环境一、前言二、安装 IDE 二、安装TDM-GCC安装三、安装C/C环境四、编写代码并进行编译 关于使用vscode搭建c/c编程环境 一、前言 一直觉得vscode是生产强有力的生产工具&#xff0c;基于此&#xff0c;做一篇学习笔记进行记录。 二、安装 ID…