diff options
author | Song Gao <gaosong@loongson.cn> | 2023-05-15 21:00:42 +0800 |
---|---|---|
committer | Song Gao <gaosong@loongson.cn> | 2023-05-26 17:21:12 +0800 |
commit | 2e2ca3c8fa52c03c3725edfdd726972a223b74f3 (patch) | |
tree | 0fa2388f4282f2aad3f893399aee9fce758293e9 /target/loongarch | |
parent | a3cb6d5004ff638aefe686ecd540718a793bd1b1 (diff) | |
download | qemu-2e2ca3c8fa52c03c3725edfdd726972a223b74f3.zip qemu-2e2ca3c8fa52c03c3725edfdd726972a223b74f3.tar.gz qemu-2e2ca3c8fa52c03c3725edfdd726972a223b74f3.tar.bz2 |
target/loongarch: Fix LD/ST{LE/GT} instructions get wrong CSR_ERA and CSR_BADV
1.helper_asrtle_d/helper_asrtgt_d need use GETPC() to get PC;
2 LD/ST{LE/GT} need set CSR_BADV = gpr[rj];
3 ASRTLE.D/ASRTGT.D also write CSR_BADV, but this value is random
and has no reference value.
Signed-off-by: Song Gao <gaosong@loongson.cn>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20230515130042.2719712-1-gaosong@loongson.cn>
Diffstat (limited to 'target/loongarch')
-rw-r--r-- | target/loongarch/cpu.c | 2 | ||||
-rw-r--r-- | target/loongarch/op_helper.c | 6 |
2 files changed, 5 insertions, 3 deletions
diff --git a/target/loongarch/cpu.c b/target/loongarch/cpu.c index c0afc21..ad93eca 100644 --- a/target/loongarch/cpu.c +++ b/target/loongarch/cpu.c @@ -187,10 +187,10 @@ static void loongarch_cpu_do_interrupt(CPUState *cs) case EXCCODE_IPE: case EXCCODE_FPD: case EXCCODE_FPE: - case EXCCODE_BCE: case EXCCODE_SXD: env->CSR_BADV = env->pc; QEMU_FALLTHROUGH; + case EXCCODE_BCE: case EXCCODE_ADEM: case EXCCODE_PIL: case EXCCODE_PIS: diff --git a/target/loongarch/op_helper.c b/target/loongarch/op_helper.c index 568c071..60335a05 100644 --- a/target/loongarch/op_helper.c +++ b/target/loongarch/op_helper.c @@ -49,14 +49,16 @@ target_ulong helper_bitswap(target_ulong v) void helper_asrtle_d(CPULoongArchState *env, target_ulong rj, target_ulong rk) { if (rj > rk) { - do_raise_exception(env, EXCCODE_BCE, 0); + env->CSR_BADV = rj; + do_raise_exception(env, EXCCODE_BCE, GETPC()); } } void helper_asrtgt_d(CPULoongArchState *env, target_ulong rj, target_ulong rk) { if (rj <= rk) { - do_raise_exception(env, EXCCODE_BCE, 0); + env->CSR_BADV = rj; + do_raise_exception(env, EXCCODE_BCE, GETPC()); } } |