mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-02 23:33:54 -06:00
target/riscv: Update the Hypervisor trap return/entry
Signed-off-by: Alistair Francis <alistair.francis@wdc.com> Message-id: e7e4e801234f2934306e734f65860f601a5745bd.1597259519.git.alistair.francis@wdc.com Message-Id: <e7e4e801234f2934306e734f65860f601a5745bd.1597259519.git.alistair.francis@wdc.com>
This commit is contained in:
parent
84b1c04bba
commit
f2d5850f71
4 changed files with 9 additions and 26 deletions
|
@ -929,9 +929,7 @@ void riscv_cpu_do_interrupt(CPUState *cs)
|
|||
} else if (riscv_cpu_virt_enabled(env)) {
|
||||
/* Trap into HS mode, from virt */
|
||||
riscv_cpu_swap_hypervisor_regs(env);
|
||||
env->hstatus = set_field(env->hstatus, HSTATUS_SP2V,
|
||||
get_field(env->hstatus, HSTATUS_SPV));
|
||||
env->hstatus = set_field(env->hstatus, HSTATUS_SP2P,
|
||||
env->hstatus = set_field(env->hstatus, HSTATUS_SPVP,
|
||||
get_field(env->mstatus, SSTATUS_SPP));
|
||||
env->hstatus = set_field(env->hstatus, HSTATUS_SPV,
|
||||
riscv_cpu_virt_enabled(env));
|
||||
|
@ -942,13 +940,11 @@ void riscv_cpu_do_interrupt(CPUState *cs)
|
|||
riscv_cpu_set_force_hs_excep(env, 0);
|
||||
} else {
|
||||
/* Trap into HS mode */
|
||||
env->hstatus = set_field(env->hstatus, HSTATUS_SP2V,
|
||||
get_field(env->hstatus, HSTATUS_SPV));
|
||||
env->hstatus = set_field(env->hstatus, HSTATUS_SP2P,
|
||||
get_field(env->mstatus, SSTATUS_SPP));
|
||||
env->hstatus = set_field(env->hstatus, HSTATUS_SPV,
|
||||
riscv_cpu_virt_enabled(env));
|
||||
|
||||
if (!riscv_cpu_two_stage_lookup(env)) {
|
||||
env->hstatus = set_field(env->hstatus, HSTATUS_SPV,
|
||||
riscv_cpu_virt_enabled(env));
|
||||
}
|
||||
riscv_cpu_set_two_stage_lookup(env, false);
|
||||
htval = env->guest_phys_fault_addr;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue