CSR 位字段

RISC-V mie CSR 寄存器详解

地址 0x304特权级 M模式访问 读写 / XLENMachine 状态、trap 与中断 CSR

机器中断使能寄存器,控制在M模式下哪些中断可以被响应。

位作用速览
bit 3 = 只有第 3 位;bits 12..11 = 第 12 到第 11 位
高位 MSB低位 LSB
保留63:14保留0
字段映射

按 bit 字段理解 mie

7 个关键字段
1

SSIE

读写

监管者模式软件中断使能

这个字段控制什么

  • - 监管者模式软件中断使能

常见取值

0关闭

SSIE 对应的 Machine 中断使能关闭。

1开启

SSIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。

3

MSIE

读写

机器模式软件中断使能

这个字段控制什么

  • - 机器模式软件中断使能

常见取值

0关闭

MSIE 对应的 Machine 中断使能关闭。

1开启

MSIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。

5

STIE

读写

监管者模式定时器中断使能

这个字段控制什么

  • - 监管者模式定时器中断使能

常见取值

0关闭

STIE 对应的 Machine 中断使能关闭。

1开启

STIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。

7

MTIE

读写

机器模式定时器中断使能

这个字段控制什么

  • - 机器模式定时器中断使能

常见取值

0关闭

MTIE 对应的 Machine 中断使能关闭。

1开启

MTIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。

9

SEIE

读写

监管者模式外部中断使能

这个字段控制什么

  • - 监管者模式外部中断使能

常见取值

0关闭

SEIE 对应的 Machine 中断使能关闭。

1开启

SEIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。

11

MEIE

读写

机器模式外部中断使能

这个字段控制什么

  • - 机器模式外部中断使能

常见取值

0关闭

MEIE 对应的 Machine 中断使能关闭。

1开启

MEIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。

13

LCOFIE

读写

本地计数器溢出中断使能;仅在实现相关 counter-overflow interrupt 支持时有意义。

这个字段控制什么

  • - 本地计数器溢出中断使能;仅在实现相关 counter-overflow interrupt 支持时有意义。

常见取值

0关闭

LCOFIE 对应的 Machine 中断使能关闭。

1开启

LCOFIE 对应的 Machine 中断使能开启;递送还取决于 mstatus 和 pending/delegation 状态。

官方依据与检索要点

mie 是 Machine 状态、trap 与中断 CSR 中的 读写 CSR,地址为 0x304。先确认当前特权级和扩展实现情况,再根据位字段判断该 CSR 影响的架构状态。

mie 的地址、最低访问特权级和读写属性按官方 CSR 表核对:0x304,M模式,读写。
先按 Machine 状态、trap 与中断 CSR 理解它影响的架构状态,再看页面中的位字段说明。
写入前只修改目标字段并保留未修改位;WPRI/保留字段应按官方规范和实现返回值解释。

汇编操作示例

使用 csrr/csrw/csrs/csrc 指令读写 mie,参考 RISC-V Privileged Architecture §2.8

csrr t0, mie
读取当前已使能的中断源位掩码
li t0, 0x00000088; csrs mie, t0
使能 MTIE(bit7)+MSIE(bit3)
li t0, 0x00000088; csrc mie, t0
禁用 MTIE+MSIE(原子清除)
# Enable machine timer interrupt — complete flow
启用机器定时器中断——完整流程
li t0, 0x80; csrs mie, t0
step 1: 在 mie 中置 MTIE(bit7)=1,允许定时器中断源
li t0, 0x08; csrs mstatus, t0
step 2: 置 mstatus.MIE(bit3)=1,开启全局中断总开关
csrr t0, mip; andi t0, t0, 0x80; bnez t0, handle_mtip
step 3: 轮询 mip.MTIP(bit7),确认定时器中断已挂起再处理

与其他 CSR 的关系

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) 本地计数器溢出中断使能(条件实现)

读这个 CSR 时先看什么

  • - 先确认当前 hart 是否实现 mie,未实现或权限不足的访问会触发非法指令异常。
  • - 结合地址 0x304 和最低访问特权级(Machine)判断软件是否可以直接读取。
  • - 读取保留位或 WARL/WLRL 位时不要假设固定值,应按规范和实现返回值解释。

写入前的风险检查

  • - 写入前保留未修改的位,避免把保留位或实现定义位写成非规范值。
  • - 优先使用 CSRRS/CSRRC 做局部置位或清位,避免 CSRRW 覆盖并发更新的状态位。

放回真实流程里理解

1

初始化或进入相关特权流程时,软件先读取 mie 了解当前状态。

2

根据字段定义只修改目标位,保留其余位的原值。

3

修改后再次读取或通过后续 trap/中断/上下文切换行为验证配置是否生效。

常见问题

mie 可以在任意特权级访问吗?

不能只看 CSR 名称判断。官方 CSR 地址编码和表格给出最低访问特权级;mie 当前记录为 M模式,权限不足或未实现时访问会触发非法指令异常。

写 mie 时最容易忽略什么?

不要把整个 CSR 当普通整数覆盖。应只修改目标字段,保留未修改位,并按规范处理 WARL、WLRL、WPRI 或保留字段。