[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 8/9] target/hppa: Avoid accessing %gr0 when raising exception
|
From: |
deller |
|
Subject: |
[PATCH v2 8/9] target/hppa: Avoid accessing %gr0 when raising exception |
|
Date: |
Sun, 7 Jan 2024 14:22:36 +0100 |
From: Helge Deller <deller@gmx.de>
The value of unwind_breg may reference register %r0, but we need to avoid
accessing gr0 directly and use the value 0 instead.
At runtime I've seen unwind_breg being zero with the Linux kernel when
rfi is used to jump to smp_callin().
Signed-off-by: Helge Deller <deller@gmx.de>
---
target/hppa/mem_helper.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/target/hppa/mem_helper.c b/target/hppa/mem_helper.c
index 011b192406..42bd0063c0 100644
--- a/target/hppa/mem_helper.c
+++ b/target/hppa/mem_helper.c
@@ -335,7 +335,7 @@ raise_exception_with_ior(CPUHPPAState *env, int excp,
uintptr_t retaddr,
cpu_restore_state(cs, retaddr);
- b = env->gr[env->unwind_breg];
+ b = env->unwind_breg ? env->gr[env->unwind_breg] : 0;
b >>= (env->psw & PSW_W ? 62 : 30);
env->cr[CR_IOR] |= b << 62;
--
2.43.0
- Re: [PATCH v2 4/9] target/hppa: Fix PDC address translation on PA2.0 with PSW.W=0, (continued)
[PATCH v2 5/9] target/hppa: Strip upper 32-bits of IOR on error in probe, deller, 2024/01/07
[PATCH v2 6/9] target/hppa: Strip upper 32-bits of IOR on unaligned access error, deller, 2024/01/07
[PATCH v2 7/9] hw/hppa: Move software power button address back into PDC, deller, 2024/01/07
[PATCH v2 8/9] target/hppa: Avoid accessing %gr0 when raising exception,
deller <=
[PATCH v2 9/9] target/hppa: Update SeaBIOS-hppa to version 15, deller, 2024/01/07
Re: [PATCH v2 0/9] target/hppa qemu v8.2 regression fixes, Bruno Haible, 2024/01/07