mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-07 01:33:56 -06:00
target/riscv: Add M-mode virtual interrupt and IRQ filtering support.
This change adds support for inserting virtual interrupts from M-mode into S-mode using mvien and mvip csrs. IRQ filtering is a use case of this change, i-e M-mode can stop delegating an interrupt to S-mode and instead enable it in MIE and receive those interrupts in M-mode and then selectively inject the interrupt using mvien and mvip. Also, the spec doesn't mandate the interrupt to be actually supported in hardware. Which allows M-mode to assert virtual interrupts to S-mode that have no connection to any real interrupt events. This is defined as part of the AIA specification [0], "5.3 Interrupt filtering and virtual interrupts for supervisor level". [0]: https://github.com/riscv/riscv-aia/releases/download/1.0/riscv-interrupts-1.0.pdf Signed-off-by: Rajnesh Kanwal <rkanwal@rivosinc.com> Reviewed-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com> Message-ID: <20231016111736.28721-6-rkanwal@rivosinc.com> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
This commit is contained in:
parent
1ebad505f3
commit
1697837ed9
6 changed files with 291 additions and 38 deletions
|
@ -202,6 +202,12 @@ struct CPUArchState {
|
|||
uint64_t mie;
|
||||
uint64_t mideleg;
|
||||
|
||||
/*
|
||||
* When mideleg[i]=0 and mvien[i]=1, sie[i] is no more
|
||||
* alias of mie[i] and needs to be maintained separatly.
|
||||
*/
|
||||
uint64_t sie;
|
||||
|
||||
target_ulong satp; /* since: priv-1.10.0 */
|
||||
target_ulong stval;
|
||||
target_ulong medeleg;
|
||||
|
@ -222,6 +228,8 @@ struct CPUArchState {
|
|||
/* AIA CSRs */
|
||||
target_ulong miselect;
|
||||
target_ulong siselect;
|
||||
uint64_t mvien;
|
||||
uint64_t mvip;
|
||||
|
||||
/* Hypervisor CSRs */
|
||||
target_ulong hstatus;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue