CSR 位字段

RISC-V medeleg CSR 寄存器详解

地址 0x302特权级 M模式访问 读写 / XLENMachine 委托、环境配置与状态使能 CSR

机器异常委托寄存器,控制哪些异常委托给S模式处理。

位作用速览
bit 3 = 只有第 3 位;bits 12..11 = 第 12 到第 11 位
高位 MSB低位 LSB
字段映射

按 bit 字段理解 medeleg

14 个关键字段
XLEN-1:0

ED

读写

异常委托位,bit[N]=1时异常号N委托给S模式

这个字段控制什么

  • - 异常委托位,bit[N]=1时异常号N委托给S模式

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

0

IAM

读写

指令地址未对齐异常委托位。

这个字段控制什么

  • - 指令地址未对齐异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

1

IAF

读写

指令访问异常委托位。

这个字段控制什么

  • - 指令访问异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

2

ILL

读写

非法指令异常委托位。

这个字段控制什么

  • - 非法指令异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

3

BP

读写

断点异常委托位。

这个字段控制什么

  • - 断点异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

4

LAM

读写

Load 地址未对齐异常委托位。

这个字段控制什么

  • - Load 地址未对齐异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

5

LAF

读写

Load 访问异常委托位。

这个字段控制什么

  • - Load 访问异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

6

SAM

读写

Store/AMO 地址未对齐异常委托位。

这个字段控制什么

  • - Store/AMO 地址未对齐异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

7

SAF

读写

Store/AMO 访问异常委托位。

这个字段控制什么

  • - Store/AMO 访问异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

8

UECALL

读写

U 模式环境调用异常委托位。

这个字段控制什么

  • - U 模式环境调用异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

9

SECALL

读写

S 模式环境调用异常委托位。

这个字段控制什么

  • - S 模式环境调用异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

12

IPF

读写

指令页错误异常委托位。

这个字段控制什么

  • - 指令页错误异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

13

LPF

读写

Load 页错误异常委托位。

这个字段控制什么

  • - Load 页错误异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

15

SPF

读写

Store/AMO 页错误异常委托位。

这个字段控制什么

  • - Store/AMO 页错误异常委托位。

常见取值

0不委托

对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。

1委托给 S 模式

对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。

官方依据与检索要点

medeleg 是 Machine 委托、环境配置与状态使能 CSR 中的 读写 CSR,地址为 0x302。先确认当前特权级和扩展实现情况,再根据位字段判断该 CSR 影响的架构状态。

medeleg 的地址、最低访问特权级和读写属性按官方 CSR 表核对:0x302,M模式,读写。
先按 Machine 委托、环境配置与状态使能 CSR 理解它影响的架构状态,再看页面中的位字段说明。
写入前只修改目标字段并保留未修改位;WPRI/保留字段应按官方规范和实现返回值解释。

读这个 CSR 时先看什么

  • - 先确认当前 hart 是否实现 medeleg,未实现或权限不足的访问会触发非法指令异常。
  • - 结合地址 0x302 和最低访问特权级(Machine)判断软件是否可以直接读取。
  • - 读取保留位或 WARL/WLRL 位时不要假设固定值,应按规范和实现返回值解释。

写入前的风险检查

  • - 写入前保留未修改的位,避免把保留位或实现定义位写成非规范值。
  • - 优先使用 CSRRS/CSRRC 做局部置位或清位,避免 CSRRW 覆盖并发更新的状态位。

放回真实流程里理解

1

初始化或进入相关特权流程时,软件先读取 medeleg 了解当前状态。

2

根据字段定义只修改目标位,保留其余位的原值。

3

修改后再次读取或通过后续 trap/中断/上下文切换行为验证配置是否生效。

常见问题

medeleg 可以在任意特权级访问吗?

不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;medeleg 当前记录为 M模式,权限不足或未实现时访问会触发非法指令异常。

写 medeleg 时最容易忽略什么?

不要把整个 CSR 当普通整数覆盖。应只修改目标字段,保留未修改位,并按规范处理 WARL、WLRL、WPRI 或保留字段。