CY
读写允许U模式读取cycle
这个字段控制什么
- - 允许U模式读取cycle
常见取值
U 模式读取 cycle 未由 S 模式授权。
S 模式允许 U 模式读取 cycle;机器级授权仍由 mcounteren 等规则约束。
监管者计数器使能寄存器,控制在U模式能否访问硬件计数器。
允许U模式读取cycle
U 模式读取 cycle 未由 S 模式授权。
S 模式允许 U 模式读取 cycle;机器级授权仍由 mcounteren 等规则约束。
允许U模式读取time
U 模式读取 time 未由 S 模式授权。
S 模式允许 U 模式读取 time;机器级授权仍由 mcounteren 等规则约束。
允许U模式读取instret
U 模式读取 instret 未由 S 模式授权。
S 模式允许 U 模式读取 instret;机器级授权仍由 mcounteren 等规则约束。
允许 U 模式读取对应 hpmcounter3..31;还受 mcounteren 和计数器实现情况约束。
U 模式读取 hpmcounter3-31 未由 S 模式授权。
S 模式允许 U 模式读取 hpmcounter3-31;机器级授权仍由 mcounteren 等规则约束。
scounteren 是 Supervisor 环境配置与状态使能 CSR 中的 读写 CSR,地址为 0x106。先确认当前特权级和扩展实现情况,再根据位字段判断该 CSR 影响的架构状态。
初始化或进入相关特权流程时,软件先读取 scounteren 了解当前状态。
根据字段定义只修改目标位,保留其余位的原值。
修改后再次读取或通过后续 trap/中断/上下文切换行为验证配置是否生效。
不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;scounteren 当前记录为 S模式,权限不足或未实现时访问会触发非法指令异常。
不要把整个 CSR 当普通整数覆盖。应只修改目标字段,保留未修改位,并按规范处理 WARL、WLRL、WPRI 或保留字段。