mstatush 可以在任意特权级访问吗?
不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;mstatush 当前记录为 M模式,权限不足或未实现时访问会触发非法指令异常。
机器状态寄存器高位(仅RV32),包含mstatus中不适合32位的附加字段。
mstatush 只存在于 RV32,用于承载 mstatus 的高位状态字段。官方说明 SD、SXL 和 UXL 不存在于 mstatush。
初始化或进入相关特权流程时,软件先读取 mstatush 了解当前状态。
根据字段定义只修改目标位,保留其余位的原值。
修改后再次读取或通过后续 trap/中断/上下文切换行为验证配置是否生效。
不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;mstatush 当前记录为 M模式,权限不足或未实现时访问会触发非法指令异常。
不要把整个 CSR 当普通整数覆盖。应只修改目标字段,保留未修改位,并按规范处理 WARL、WLRL、WPRI 或保留字段。