CSR 位字段

RISC-V mhpmcounter26h CSR 寄存器详解

地址 0xB9A特权级 Machine 模式访问 读写 / RV32 高半 / 32 位Machine 计数器与性能监控 CSR

mhpmcounter26h(地址 0xB9A)是 RV32 上 mhpmcounter26 位 63:32 的 Machine 高半 CSR。

位作用速览
bit 3 = 只有第 3 位;bits 12..11 = 第 12 到第 11 位
高位 MSB低位 LSB
保留63:32COUNT_HI31:0读写
字段映射

按 bit 字段理解 mhpmcounter26h

1 个关键字段
31:0

COUNT_HI

读写

对应 mhpmcounter26[63:32] 的 HPM 计数高 32 位。

这个字段控制什么

  • - 对应 mhpmcounter26[63:32] 的 HPM 计数高 32 位。

常见取值

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

官方依据与检索要点

mhpmcounter26h 是 RV32 的高半访问 CSR,用来访问 mhpmcounter26 的位 63:32;它的事件含义仍由 mhpmevent26 决定。

官方计数器为 64 位;RV32 通过 mhpmcounter26/mhpmcounter26h 分低高半访问。
读取递增计数器时要避免高低半跨进位不一致。
mhpmcounter26h 不选择事件,事件选择在 mhpmevent26。

读这个 CSR 时先看什么

  • - mhpmcounter26h 是 RV32-only 高半 CSR;XLEN=64 时通过 mhpmcounter26 读取完整计数。
  • - 读取 64 位递增计数器时,应使用高-低-高等稳定读取序列避免跨 32 位进位不一致。
  • - mhpmcounter26 的事件来源仍由 mhpmevent26 决定。

写入前的风险检查

  • - 写 mhpmcounter26h 只改变 mhpmcounter26 的高 32 位;通常仅在初始化或采样重置中使用。
  • - 避免在低半 mhpmcounter26 同时更新时单独写高半造成瞬时不一致。

放回真实流程里理解

1

在 RV32 上按稳定序列读取 mhpmcounter26h 和 mhpmcounter26。

2

组合高低半得到 64 位 mhpmcounter26 计数。

3

结合 mhpmevent26 判断该计数代表的事件。

常见问题

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

不能。官方 CSR 表把 mhpmcounter26h 列为 Machine 模式 CSR;低特权级软件只有在相关标准扩展提供明确的委托或权限机制时才可访问对应状态;权限不足或未实现时直接 CSR 访问会触发非法指令异常。

mhpmcounter26h 是新的独立计数器吗?

不是。它只是 RV32 上 mhpmcounter26 的高 32 位访问 CSR。