mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-03-24 22:15:07 +00:00
target/riscv: Correctly implement TSR trap
As reported in: https://bugs.launchpad.net/qemu/+bug/1851939 we weren't correctly handling illegal instructions based on the value of MSTATUS_TSR and the current privledge level. This patch fixes the issue raised in the bug by raising an illegal instruction if TSR is set and we are in S-Mode. Backports commit ed5abf46b3c414ef58e647145f19b3966700b206 from qemu
This commit is contained in:
parent
6c8172fd08
commit
1001f0ba1f
|
@ -84,7 +84,7 @@ target_ulong helper_sret(CPURISCVState *env, target_ulong cpu_pc_deb)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (env->priv_ver >= PRIV_VERSION_1_10_0 &&
|
if (env->priv_ver >= PRIV_VERSION_1_10_0 &&
|
||||||
get_field(env->mstatus, MSTATUS_TSR)) {
|
get_field(env->mstatus, MSTATUS_TSR) && !(env->priv >= PRV_M)) {
|
||||||
riscv_raise_exception(env, RISCV_EXCP_ILLEGAL_INST, GETPC());
|
riscv_raise_exception(env, RISCV_EXCP_ILLEGAL_INST, GETPC());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue