* [PATCH for-9.0] target/arm: take HSTR traps of cp15 accesses to EL2, not EL1
@ 2024-03-25 13:31 Peter Maydell
2024-03-25 18:28 ` Richard Henderson
0 siblings, 1 reply; 2+ messages in thread
From: Peter Maydell @ 2024-03-25 13:31 UTC (permalink / raw)
To: qemu-devel; +Cc: qemu-stable
The HSTR_EL2 register allows the hypervisor to trap AArch32 EL1 and
EL0 accesses to cp15 registers. We incorrectly implemented this so
they trap to EL1 when we detect the need for a HSTR trap at code
generation time. (The check in access_check_cp_reg() which we do at
runtime to catch traps from EL0 is correctly routing them to EL2.)
Use the correct target EL when generating the code to take the trap.
Cc: qemu-stable@nongnu.org
Resolves: https://gitlab.com/qemu-project/qemu/-/issues/2226
Fixes: 049edada5e93df ("target/arm: Make HSTR_EL2 traps take priority over UNDEF-at-EL1")
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
---
target/arm/tcg/translate.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/target/arm/tcg/translate.c b/target/arm/tcg/translate.c
index c8a24706750..69585e6003d 100644
--- a/target/arm/tcg/translate.c
+++ b/target/arm/tcg/translate.c
@@ -4585,7 +4585,7 @@ static void do_coproc_insn(DisasContext *s, int cpnum, int is64,
tcg_gen_andi_i32(t, t, 1u << maskbit);
tcg_gen_brcondi_i32(TCG_COND_EQ, t, 0, over.label);
- gen_exception_insn(s, 0, EXCP_UDEF, syndrome);
+ gen_exception_insn_el(s, 0, EXCP_UDEF, syndrome, 2);
/*
* gen_exception_insn() will set is_jmp to DISAS_NORETURN,
* but since we're conditionally branching over it, we want
--
2.34.1
^ permalink raw reply related [flat|nested] 2+ messages in thread* Re: [PATCH for-9.0] target/arm: take HSTR traps of cp15 accesses to EL2, not EL1
2024-03-25 13:31 [PATCH for-9.0] target/arm: take HSTR traps of cp15 accesses to EL2, not EL1 Peter Maydell
@ 2024-03-25 18:28 ` Richard Henderson
0 siblings, 0 replies; 2+ messages in thread
From: Richard Henderson @ 2024-03-25 18:28 UTC (permalink / raw)
To: Peter Maydell, qemu-devel; +Cc: qemu-stable
On 3/25/24 03:31, Peter Maydell wrote:
> The HSTR_EL2 register allows the hypervisor to trap AArch32 EL1 and
> EL0 accesses to cp15 registers. We incorrectly implemented this so
> they trap to EL1 when we detect the need for a HSTR trap at code
> generation time. (The check in access_check_cp_reg() which we do at
> runtime to catch traps from EL0 is correctly routing them to EL2.)
>
> Use the correct target EL when generating the code to take the trap.
>
> Cc:qemu-stable@nongnu.org
> Resolves:https://gitlab.com/qemu-project/qemu/-/issues/2226
> Fixes: 049edada5e93df ("target/arm: Make HSTR_EL2 traps take priority over UNDEF-at-EL1")
> Signed-off-by: Peter Maydell<peter.maydell@linaro.org>
> ---
> target/arm/tcg/translate.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
r~
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2024-03-25 18:29 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-03-25 13:31 [PATCH for-9.0] target/arm: take HSTR traps of cp15 accesses to EL2, not EL1 Peter Maydell
2024-03-25 18:28 ` Richard Henderson
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).