ED
读写异常委托位,bit[N]=1时异常号N委托给S模式
这个字段控制什么
- - 异常委托位,bit[N]=1时异常号N委托给S模式
常见取值
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
机器异常委托寄存器,控制哪些异常委托给S模式处理。
异常委托位,bit[N]=1时异常号N委托给S模式
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
指令地址未对齐异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
指令访问异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
非法指令异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
断点异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
Load 地址未对齐异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
Load 访问异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
Store/AMO 地址未对齐异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
Store/AMO 访问异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
U 模式环境调用异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
S 模式环境调用异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
指令页错误异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
Load 页错误异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
Store/AMO 页错误异常委托位。
对应陷阱/异常由 M 模式处理或保持在当前更高特权级路径。
对应陷阱/异常从低于 M 的特权级发生时委托给 S 模式处理。
medeleg 是 Machine 委托、环境配置与状态使能 CSR 中的 读写 CSR,地址为 0x302。先确认当前特权级和扩展实现情况,再根据位字段判断该 CSR 影响的架构状态。
初始化或进入相关特权流程时,软件先读取 medeleg 了解当前状态。
根据字段定义只修改目标位,保留其余位的原值。
修改后再次读取或通过后续 trap/中断/上下文切换行为验证配置是否生效。
不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;medeleg 当前记录为 M模式,权限不足或未实现时访问会触发非法指令异常。
不要把整个 CSR 当普通整数覆盖。应只修改目标字段,保留未修改位,并按规范处理 WARL、WLRL、WPRI 或保留字段。