diff options
author | Richard Henderson <richard.henderson@linaro.org> | 2020-02-08 12:58:03 +0000 |
---|---|---|
committer | Peter Maydell <peter.maydell@linaro.org> | 2020-02-13 14:14:54 +0000 |
commit | 437864216d63f052f3cd06ec8861d0e432496424 (patch) | |
tree | 3bcc1114840244f67864a3d995175b2693f3f6f6 /target/arm/op_helper.c | |
parent | f062d1447f2a80e7a5f593b8cb5ac7cab5e16eb0 (diff) | |
download | qemu-437864216d63f052f3cd06ec8861d0e432496424.zip qemu-437864216d63f052f3cd06ec8861d0e432496424.tar.gz qemu-437864216d63f052f3cd06ec8861d0e432496424.tar.bz2 |
target/arm: Replace CPSR_ERET_MASK with aarch32_cpsr_valid_mask
CPSR_ERET_MASK was a useless renaming of CPSR_RESERVED.
The function also takes into account bits that the cpu
does not support.
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20200208125816.14954-8-richard.henderson@linaro.org
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Diffstat (limited to 'target/arm/op_helper.c')
-rw-r--r-- | target/arm/op_helper.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/target/arm/op_helper.c b/target/arm/op_helper.c index 27d16ad..acf1815 100644 --- a/target/arm/op_helper.c +++ b/target/arm/op_helper.c @@ -400,11 +400,14 @@ void HELPER(cpsr_write)(CPUARMState *env, uint32_t val, uint32_t mask) /* Write the CPSR for a 32-bit exception return */ void HELPER(cpsr_write_eret)(CPUARMState *env, uint32_t val) { + uint32_t mask; + qemu_mutex_lock_iothread(); arm_call_pre_el_change_hook(env_archcpu(env)); qemu_mutex_unlock_iothread(); - cpsr_write(env, val, CPSR_ERET_MASK, CPSRWriteExceptionReturn); + mask = aarch32_cpsr_valid_mask(env->features, &env_archcpu(env)->isar); + cpsr_write(env, val, mask, CPSRWriteExceptionReturn); /* Generated code has already stored the new PC value, but * without masking out its low bits, because which bits need |