CSR 位字段

RISC-V hpmcounter31 CSR 寄存器详解

地址 0xC1F特权级 U模式访问 只读 / XLEN用户级计数器与性能监控 CSR

hpmcounter31 是用户级硬件性能监控计数器 CSR,用于读取实现定义的硬件性能事件计数。

字段映射

按 bit 字段理解 hpmcounter31

1 个关键字段
XLEN-1:0

VALUE

只读

hpmcounter31 的完整寄存器值;未单独列出的位按对应扩展或特权规范解释,读取保留位或 WPRI 字段时忽略其值;写同一 CSR 的其他可写字段时保留这些字段原值。

这个字段控制什么

  • - hpmcounter31 的完整寄存器值;未单独列出的位按对应扩展或特权规范解释,读取保留位或 WPRI 字段时忽略其值;写同一 CSR 的其他可写字段时保留这些字段原值。

常见取值

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

打开官方手册

读这个 CSR 时先看什么

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

写入前的风险检查

  • - hpmcounter31 是只读 CSR;写入会触发非法指令异常或被实现禁止。

放回真实流程里理解

1

读取 hpmcounter31 获取硬件或运行状态。

2

按位域说明解释返回值,不要尝试写回。

3

若在当前特权级读取失败,应按非法指令异常路径处理。