OSDN Git Service

target/openrisc: Setup FPU for detecting tininess before rounding
authorStafford Horne <shorne@gmail.com>
Thu, 16 Mar 2023 19:18:36 +0000 (04:18 +0900)
committerStafford Horne <shorne@gmail.com>
Thu, 11 May 2023 14:40:28 +0000 (15:40 +0100)
OpenRISC defines tininess to be detected before rounding.  Setup qemu to
obey this.

Signed-off-by: Stafford Horne <shorne@gmail.com>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
target/openrisc/cpu.c

index 0ce4f79..61d748c 100644 (file)
@@ -22,6 +22,7 @@
 #include "qemu/qemu-print.h"
 #include "cpu.h"
 #include "exec/exec-all.h"
+#include "fpu/softfloat-helpers.h"
 #include "tcg/tcg.h"
 
 static void openrisc_cpu_set_pc(CPUState *cs, vaddr value)
@@ -90,6 +91,9 @@ static void openrisc_cpu_reset_hold(Object *obj)
     s->exception_index = -1;
     cpu_set_fpcsr(&cpu->env, 0);
 
+    set_float_detect_tininess(float_tininess_before_rounding,
+                              &cpu->env.fp_status);
+
 #ifndef CONFIG_USER_ONLY
     cpu->env.picmr = 0x00000000;
     cpu->env.picsr = 0x00000000;