CSR 位字段

RISC-V mncause CSR 寄存器详解

地址 0x742特权级 M模式访问 读写 / MXLEN/XLEN保留、自定义或未分类 CSR

RNMI 原因寄存器,记录 RNMI 中断或双重陷阱异常的原因编码。

字段映射

按 bit 字段理解 mncause

2 个关键字段
XLEN-1

Interrupt

读写

为 1 表示 RNMI 原因为中断;为 0 表示 M 模式异常导致的双重陷阱。

这个字段控制什么

  • - 为 1 表示 RNMI 原因为中断;为 0 表示 M 模式异常导致的双重陷阱。

常见取值

mncause.Interrupt
0异常/双重陷阱

mncause 记录的是导致双重陷阱的 M-mode 异常 cause。

1RNMI 中断

mncause 记录的是 RNMI 中断原因。

XLEN-2:0

CODE

读写

RNMI 原因编码或导致双重陷阱的异常 cause 编码。

这个字段控制什么

  • - RNMI 原因编码或导致双重陷阱的异常 cause 编码。

常见取值

这个字段更适合结合上下文字段解释,不用按固定枚举背诵。

读这个 CSR 时先看什么

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

写入前的风险检查

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

放回真实流程里理解

1

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

2

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

3

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