SSIP
读写监管者模式软件中断挂起
这个字段控制什么
- - 监管者模式软件中断挂起
常见取值
SSIP 对应中断未挂起。
SSIP 对应中断挂起;是否递送还取决于 enable、全局中断和委托状态。
机器中断挂起寄存器,指示当前有哪些中断处于挂起状态。
监管者模式软件中断挂起
SSIP 对应中断未挂起。
SSIP 对应中断挂起;是否递送还取决于 enable、全局中断和委托状态。
机器模式软件中断挂起;通常反映内存映射 msip 或平台中断控制状态,不应作为普通 mip 可写位使用。
MSIP 对应中断未挂起。
MSIP 对应中断挂起;是否递送还取决于 enable、全局中断和委托状态。
监管者模式定时器中断挂起
STIP 对应中断未挂起。
STIP 对应中断挂起;是否递送还取决于 enable、全局中断和委托状态。
机器模式定时器中断挂起(只读,由硬件根据 mtime >= mtimecmp 自动设置)
MTIP 对应中断未挂起。
MTIP 对应中断挂起;是否递送还取决于 enable、全局中断和委托状态。
监管者模式外部中断挂起
SEIP 对应中断未挂起。
SEIP 对应中断挂起;是否递送还取决于 enable、全局中断和委托状态。
机器模式外部中断挂起(只读,由平台特定机制设置)
MEIP 对应中断未挂起。
MEIP 对应中断挂起;是否递送还取决于 enable、全局中断和委托状态。
本地计数器溢出中断挂起;仅在实现相关 counter-overflow interrupt 支持时有意义。
LCOFIP 对应中断未挂起。
LCOFIP 对应中断挂起;是否递送还取决于 enable、全局中断和委托状态。
mip 是 Machine 状态、trap 与中断 CSR 中的 读写 CSR,地址为 0x344。先确认当前特权级和扩展实现情况,再根据位字段判断该 CSR 影响的架构状态。
使用 csrr/csrw/csrs/csrc 指令读写 mip,参考 RISC-V Privileged Architecture §2.8
mip 指示各中断源是否处于挂起状态。mip 与 mie 同一位位置对应同一中断源。MSIP 在 mip 中反映机器软件中断挂起状态;机器软件中断通常通过写内存映射的 msip 寄存器触发,而不是直接写 mip.MSIP。
SSIP(bit1) S模式软件中断挂起 | MSIP(bit3) M模式软件中断挂起 | STIP(bit5) S模式定时器中断挂起 | MTIP(bit7) M模式定时器中断挂起 | SEIP(bit9) S模式外部中断挂起 | MEIP(bit11) M模式外部中断挂起
初始化或进入相关特权流程时,软件先读取 mip 了解当前状态。
根据字段定义只修改目标位,保留其余位的原值。
修改后再次读取或通过后续 trap/中断/上下文切换行为验证配置是否生效。
不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;mip 当前记录为 M模式,权限不足或未实现时访问会触发非法指令异常。
不要把整个 CSR 当普通整数覆盖。应只修改目标字段,保留未修改位,并按规范处理 WARL、WLRL、WPRI 或保留字段。