RISC-V架构——中断委托和中断注入

1、中断委托

1.1、中断委托的作用

(1)默认情况下,所有的陷入(中断和异常)都是在M模式下处理,然后再返回到发生陷入前的模式;

(2)所有陷入都在M模式处理会涉及到模式切换,而模式切换是比较消耗性能和时间的。比如:在S模式下发生外部中断,需要切换到M模式处理中断,然后再返回到S模式;

(3)中断委托:就是把本来需要在M模式处理的中断和异常委托给S模式处理,当被委托的中断发生时,直接跳转到S模式的异常处理函数,不用再切换到M模式处理

1.2、中断委托相关寄存器

1.2.1、中断委托寄存器mideleg

1.2.2、异常委托寄存器medeleg

1.3、中断委托注意事项

(1)当处理器支持S模式时,必须实现mideleg和medeled寄存器,如果不支持S模式就不要实现;

(2)中断委托不能把M模式产生的中断委托给S模式。举例:把非法指令异常委托给S模式处理,S模式和M模式下发生的非法指令由S模式处理,而不再用M模式处理;但是M模式发生的非法指令异常,还是需要由M模式处理,不会交由S模式处理。

(3)中断委托寄存器mideleg和medeleg,只能在M模式下访问和修改;

2、中断注入

2.1、中断注入的作用

(1)中断注入,顾名思义就是在M模式下手动向S模式去产生一个中断。比如:向mip寄存器的bit5写1,S模式就会产生一个时钟中断;

(2)中断注入类似于软件中断,由软件来产生,相对而言是硬件中断,硬件中断一般是靠GPIO引脚的高低电平来触发;

2.2、中断注入相关寄存器MIP

相关推荐
云雾J视界7 天前
FPGA+RISC-V架构解析:构建高效传感器数据采集系统
fpga开发·架构·uart·risc-v·i2c·adxl345
电子科技圈9 天前
IAR与Quintauris携手推进RISC-V汽车实时应用的功能安全软件开发
嵌入式硬件·安全·设计模式·编辑器·汽车·risc-v
CinzWS10 天前
RISC-V RV32MCU 架构、启动与运行机制深度剖析
risc-v·exception
stay_cloud10 天前
RISC-V MCU 串口通信记录 —— 基于Genesys2
mcu·uart·risc-v
ChipCamp10 天前
芯片开发验证之RISC-V编译器:绕过构建的烦恼,直接用Arduino的
编译器·risc-v·objdump·汇编器·objcopy
全球通史13 天前
[特殊字符] RISC-V实战:从0到100+FPS!进迭时空(Spacemit)开发板YOLOv8部署终极指南
嵌入式硬件·yolo·risc-v
码界奇点14 天前
Linux进程间通信三System V 共享内存完全指南原理系统调用与 C 封装实现
linux·c语言·网络·c++·ux·risc-v
飞凌嵌入式15 天前
【玩转多核异构】T153核心板RISC-V核的实时性应用解析
linux·嵌入式硬件·嵌入式·risc-v
卡奥斯开源社区官方15 天前
NVIDIA CUDA全面支持RISC-V深度解析:技术原理、开发实操与生态红利
risc-v
爱喝矿泉水的猛男15 天前
单周期Risc-V指令拆分与datapath绘制
运维·服务器·risc-v