aboutsummaryrefslogtreecommitdiff
path: root/target
diff options
context:
space:
mode:
authorJeff Kubascik <jeff.kubascik@dornerworks.com>2020-01-17 14:09:31 +0000
committerPeter Maydell <peter.maydell@linaro.org>2020-01-17 14:27:16 +0000
commit855532912b0e1bf803ae393e5b0c7e80948cd6a4 (patch)
treeb4b49d4cb4bf97316b821f53a9b465caa256c87a /target
parentf03965490e4e4223903e79a4ec97139ccdd48e1b (diff)
downloadqemu-855532912b0e1bf803ae393e5b0c7e80948cd6a4.zip
qemu-855532912b0e1bf803ae393e5b0c7e80948cd6a4.tar.gz
qemu-855532912b0e1bf803ae393e5b0c7e80948cd6a4.tar.bz2
target/arm: adjust program counter for wfi exception in AArch32
The wfi instruction can be configured to be trapped by a higher exception level, such as the EL2 hypervisor. When the instruction is trapped, the program counter should contain the address of the wfi instruction that caused the exception. The program counter is adjusted for this in the wfi op helper function. However, this correction is done to env->pc, which only applies to AArch64 mode. For AArch32, the program counter is stored in env->regs[15]. This adds an if-else statement to modify the correct program counter location based on the the current CPU mode. Signed-off-by: Jeff Kubascik <jeff.kubascik@dornerworks.com> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Diffstat (limited to 'target')
-rw-r--r--target/arm/op_helper.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/target/arm/op_helper.c b/target/arm/op_helper.c
index e5a346c..27d16ad 100644
--- a/target/arm/op_helper.c
+++ b/target/arm/op_helper.c
@@ -295,7 +295,12 @@ void HELPER(wfi)(CPUARMState *env, uint32_t insn_len)
}
if (target_el) {
- env->pc -= insn_len;
+ if (env->aarch64) {
+ env->pc -= insn_len;
+ } else {
+ env->regs[15] -= insn_len;
+ }
+
raise_exception(env, EXCP_UDEF, syn_wfx(1, 0xe, 0, insn_len == 2),
target_el);
}