aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Henderson <richard.henderson@linaro.org>2021-04-23 09:54:12 -0700
committerLaurent Vivier <laurent@vivier.eu>2021-05-15 21:38:45 +0200
commit0a50285ee8bf471936325f5ccd870752d2a038cb (patch)
tree82b654c26f6c8934ac93fb61aa1761bc18583dbd
parentd827f6d5fdb0826e17c80f63547c5c2dee3f0fac (diff)
linux-user/arm: Do not fill in si_code for fpa11 exceptions
There is no such decoding in linux/arch/arm/nwfpe/fpmodule.c. Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Message-Id: <20210423165413.338259-4-richard.henderson@linaro.org> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
-rw-r--r--linux-user/arm/cpu_loop.c26
1 files changed, 6 insertions, 20 deletions
diff --git a/linux-user/arm/cpu_loop.c b/linux-user/arm/cpu_loop.c
index e2a1496b9f..5f61d25717 100644
--- a/linux-user/arm/cpu_loop.c
+++ b/linux-user/arm/cpu_loop.c
@@ -262,29 +262,15 @@ static bool emulate_arm_fpa11(CPUARMState *env, uint32_t opcode)
/* Exception enabled? */
FPSR fpsr = ts->fpa.fpsr;
if (fpsr & (arm_fpe << 16)) {
- target_siginfo_t info;
+ target_siginfo_t info = { };
+ /*
+ * The kernel's nwfpe emulator does not pass a real si_code.
+ * It merely uses send_sig(SIGFPE, current, 1).
+ */
info.si_signo = TARGET_SIGFPE;
- info.si_errno = 0;
-
- /* ordered by priority, least first */
- if (arm_fpe & BIT_IXC) {
- info.si_code = TARGET_FPE_FLTRES;
- }
- if (arm_fpe & BIT_UFC) {
- info.si_code = TARGET_FPE_FLTUND;
- }
- if (arm_fpe & BIT_OFC) {
- info.si_code = TARGET_FPE_FLTOVF;
- }
- if (arm_fpe & BIT_DZC) {
- info.si_code = TARGET_FPE_FLTDIV;
- }
- if (arm_fpe & BIT_IOC) {
- info.si_code = TARGET_FPE_FLTINV;
- }
+ info.si_code = TARGET_SI_KERNEL;
- info._sifields._sigfault._addr = env->regs[15];
queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
} else {
env->regs[15] += 4;