STCE
读写Sstc 扩展相关的 stimecmp 访问控制。
这个字段控制什么
- - Sstc 扩展相关的 stimecmp 访问控制。
常见取值
较低特权级不能直接使用 Sstc 的 stimecmp 访问路径。
允许较低特权级使用 Sstc 定义的 stimecmp 访问路径。
机器环境配置寄存器,控制机器模式下的执行环境特性。
Sstc 扩展相关的 stimecmp 访问控制。
较低特权级不能直接使用 Sstc 的 stimecmp 访问路径。
允许较低特权级使用 Sstc 定义的 stimecmp 访问路径。
Svpbmt 页表内存类型扩展使能。
较低特权级页表项中的 PBMT 用法未启用。
启用较低特权级页表项中的 PBMT 用法。
硬件更新页表 A/D 位的控制。
硬件 A/D 位更新未由该字段启用;页表 A/D 行为按相关扩展规则处理。
启用硬件更新页表 A/D 位的路径。
允许较低特权级使用缓存块清零行为。
较低特权级 CBO.ZERO 不可用或会陷入。
允许较低特权级执行 CBO.ZERO。
缓存块 clean/flush 指令使能。
较低特权级 CBO.CLEAN/CBO.FLUSH 不可用或会陷入。
允许较低特权级执行 CBO.CLEAN/CBO.FLUSH。
缓存块 invalidate 指令使能;编码选择陷入、作为 flush 执行、保留或作为 invalidate 执行。
低特权级 CBO.INVAL 指令会触发非法指令异常。
低特权级 CBO.INVAL 按 CBO.FLUSH 行为执行。
保留编码;可移植软件不应写入或依赖。
低特权级 CBO.INVAL 按 invalidate 行为执行。
让 FENCE 的 I/O 排序隐含内存排序。
FENCE 的 I/O 排序不隐含普通内存排序。
FENCE 的 I/O 排序也隐含普通内存排序。
menvcfg 是 Machine 委托、环境配置与状态使能 CSR 中的 读写 CSR,地址为 0x30A。先确认当前特权级和扩展实现情况,再根据位字段判断该 CSR 影响的架构状态。
初始化或进入相关特权流程时,软件先读取 menvcfg 了解当前状态。
根据字段定义只修改目标位,保留其余位的原值。
修改后再次读取或通过后续 trap/中断/上下文切换行为验证配置是否生效。
不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;menvcfg 当前记录为 M模式,权限不足或未实现时访问会触发非法指令异常。
不要把整个 CSR 当普通整数覆盖。应只修改目标字段,保留未修改位,并按规范处理 WARL、WLRL、WPRI 或保留字段。