首页 > 解决方案 > RISC-V HW 如何确定权限级别?

问题描述

RISC-V 当前的 SW 特权级别未在任何 CSR 中设置。尽管如此,规范声明“尝试在没有适当特权级别的情况下访问 CSR ......引发非法指令”。那么(在硬件中)如何实现它?

标签: riscv

解决方案


好吧,在中断上——“xPP 保持以前的特权模式(x=M,S 或 U)。xPP 字段只能保持最高 x 的特权模式,所以 MPP 是两位宽,SPP 是一位宽,UPP 是隐含为零。”

实际上,我现在发现的是 xRET 指令使处理器能够(内部)存储当前模式 - “MRET、SRET 或 URET 指令用于从 M-mode、S-mode 或 U 中的陷阱返回分别为-mode。当执行xRET指令时,假设xPP保持值y,x IE设置为x PIE;特权模式更改为y;x PIE设置为1;xPP设置为U(或M,如果不支持用户模式)。”


推荐阅读