RISCV AIA (三) AIA架构下新增的CSR

 AIA架构下新增的CSR

RISC-V hart中的每个特权等级都能够处理中断,AIA架构为了中断的控制和处理增加了一些CSR。

Machine-level CSRs

由于在1.4节中AIA将interrupt cause从原有的16个扩展到48个,因此已有的CSR:mie、mip、mideleg需要扩展到64bit以支持最多64个interrupt cause,对于RV32,增加midelegh、mieh、mvienh、mviph、miph存放高32bit。

miselect和mireg作为新增的两个CSR寄存器,提供一个窗口/介质可以实现间接的方式访问多个寄存器(非CSR)。miselect为这些寄存器的地址,mireg存放这些寄存器的值。miselect存放的寄存器偏移地址由如下定义:

0x30-0x3f这个地址段是最基本的支持,0x70-0xff作为IMSIC interrupt file的映射地址,当hart支持IMSIC时,可以通过miselect和mireg访问这些寄存器。

目前 0x00~0x2F 和 0x40~0x6F 是未指定是使用者使用,故不慎使用到会引发 illegal instruction exception。通常,external interrupt 范围为 0x70-0xFF,当在实现 IMSIC 时才有效;否则,当 miselect 在此范围内时,尝试 access mireg 也会触发 illegal instruction exception。0xFF之后的地址可以由使用者自定义使用。

mtopei用于记录当前最高优先级的外部中断号(即外部中断的minor identity),由IMSIC负责维护。具体操作见下一章IMSIC的描述。mtopei用于记录当前最高优先级的pending和enable位都置位的中断号。

    1. Supervisor-level CSRs

与Machine level类似,S态下也新增了如下4个CSR:siselect、sireg、stopei和stopi,以及扩展了pending和enable寄存器:sieh和siph。

软件可以通过siselect和sireg访问S level下的IMSIC interrupt file。目前 0x00~0x2F 和 0x40~0x6F 是未指定是使用者使用,故不慎使用到会引发 illegal instruction exception,或是在 0x70~0xFF 范围内且未实现 IMSIC 时,尝试access sireg 会造成 illegal instruction exception(除非在 VM(virtual machine)执行)。

​​​​​​​Hypervisor and VS CSRs

暂不考虑虚拟化

​​​​​​​Virtual instruction exceptions

暂不考虑虚拟化

​​​​​​​Access control by the state-enable CSRs

暂不考虑

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值