SSIE
读写监管者模式软件中断使能
这个字段控制什么
- - 监管者模式软件中断使能
常见取值
SSIE 对应的 Machine 中断使能关闭。
SSIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。
机器中断使能寄存器,控制在M模式下哪些中断可以被响应。
监管者模式软件中断使能
SSIE 对应的 Machine 中断使能关闭。
SSIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。
机器模式软件中断使能
MSIE 对应的 Machine 中断使能关闭。
MSIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。
监管者模式定时器中断使能
STIE 对应的 Machine 中断使能关闭。
STIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。
机器模式定时器中断使能
MTIE 对应的 Machine 中断使能关闭。
MTIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。
监管者模式外部中断使能
SEIE 对应的 Machine 中断使能关闭。
SEIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。
机器模式外部中断使能
MEIE 对应的 Machine 中断使能关闭。
MEIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。
本地计数器溢出中断使能;仅在实现相关 counter-overflow interrupt 支持时有意义。
LCOFIE 对应的 Machine 中断使能关闭。
LCOFIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。
mie 是 Machine 状态、trap 与中断 CSR 中的 读写 CSR,地址为 0x304。先确认当前特权级和扩展实现情况,再根据位字段判断该 CSR 影响的架构状态。
使用 csrr/csrw/csrs/csrc 指令读写 mie,参考 RISC-V Privileged Architecture §2.8
mie 控制各中断源是否被使能。对在 M 模式处理的中断,还需要 mstatus.MIE 允许全局中断;已委托给 S 模式的中断按 sstatus.SIE 与 sie/sip 规则判断。mip 指示哪些中断源当前有挂起请求。sie 是 mie 在 S 模式下的受限视图。常见中断位包括 MSIE(bit3)、MTIE(bit7)、MEIE(bit11)、SSIE(bit1)、STIE(bit5)、SEIE(bit9);本地计数器溢出中断使用 LCOFIE/LCOFIP(bit13,取决于相关扩展实现)。
SSIE(bit1) S模式软件中断 | MSIE(bit3) M模式软件中断 | STIE(bit5) S模式定时器中断 | MTIE(bit7) M模式定时器中断 | SEIE(bit9) S模式外部中断 | MEIE(bit11) M模式外部中断 | LCOFIE(bit13) 本地计数器溢出中断使能(条件实现)
初始化或进入相关特权流程时,软件先读取 mie 了解当前状态。
根据字段定义只修改目标位,保留其余位的原值。
修改后再次读取或通过后续 trap/中断/上下文切换行为验证配置是否生效。
不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;mie 当前记录为 M模式,权限不足或未实现时访问会触发非法指令异常。
不要把整个 CSR 当普通整数覆盖。应只修改目标字段,保留未修改位,并按规范处理 WARL、WLRL、WPRI 或保留字段。