@@ -440,6 +440,27 @@ typedef enum {
#define FPSR_QT_MASK 0x00ff0000
#define FPSR_QT_SHIFT 16
+/* Exception Status Byte */
+
+#define FPSR_EXC_MASK 0xff00
+#define FPSR_EXC_INEX1 0x0100
+#define FPSR_EXC_INEX2 0x0200
+#define FPSR_EXC_DZ 0x0400
+#define FPSR_EXC_UNFL 0x0800
+#define FPSR_EXC_OVFL 0x1000
+#define FPSR_EXC_OPERR 0x2000
+#define FPSR_EXC_SNAN 0x4000
+#define FPSR_EXC_BSUN 0x8000
+
+/* Accrued Exception Byte */
+
+#define FPSR_AEXC_MASK 0xf8
+#define FPSR_AEXC_INEX 0x08
+#define FPSR_AEXP_DZ 0x10
+#define FPSR_AEXP_UNFL 0x20
+#define FPSR_AEXP_OVFL 0x40
+#define FPSR_AEXP_IOP 0x80
+
/* Floating-Point Control Register */
/* Rounding mode */
#define FPCR_RND_MASK 0x0030
@@ -170,19 +170,19 @@ static int cpu_m68k_exceptbits_from_host(int host_bits)
int target_bits = 0;
if (host_bits & float_flag_invalid) {
- target_bits |= 0x80;
+ target_bits |= FPSR_AEXP_IOP;
}
if (host_bits & float_flag_overflow) {
- target_bits |= 0x40;
+ target_bits |= FPSR_AEXP_OVFL;
}
if (host_bits & (float_flag_underflow | float_flag_output_denormal)) {
- target_bits |= 0x20;
+ target_bits |= FPSR_AEXP_UNFL;
}
if (host_bits & float_flag_divbyzero) {
- target_bits |= 0x10;
+ target_bits |= FPSR_AEXP_DZ;
}
if (host_bits & float_flag_inexact) {
- target_bits |= 0x08;
+ target_bits |= FPSR_AEXC_INEX;
}
return target_bits;
}
@@ -192,19 +192,19 @@ static int cpu_m68k_exceptbits_to_host(int target_bits)
{
int host_bits = 0;
- if (target_bits & 0x80) {
+ if (target_bits & FPSR_AEXP_IOP) {
host_bits |= float_flag_invalid;
}
- if (target_bits & 0x40) {
+ if (target_bits & FPSR_AEXP_OVFL) {
host_bits |= float_flag_overflow;
}
- if (target_bits & 0x20) {
+ if (target_bits & FPSR_AEXP_UNFL) {
host_bits |= float_flag_underflow;
}
- if (target_bits & 0x10) {
+ if (target_bits & FPSR_AEXP_DZ) {
host_bits |= float_flag_divbyzero;
}
- if (target_bits & 0x08) {
+ if (target_bits & FPSR_AEXC_INEX) {
host_bits |= float_flag_inexact;
}
return host_bits;
@@ -214,7 +214,7 @@ uint32_t cpu_m68k_get_fpsr(CPUM68KState *env)
{
int host_flags = get_float_exception_flags(&env->fp_status);
int target_flags = cpu_m68k_exceptbits_from_host(host_flags);
- int except = (env->fpsr & ~(0xf8)) | target_flags;
+ int except = (env->fpsr & ~FPSR_AEXC_MASK) | target_flags;
return except;
}
Signed-off-by: Richard Henderson <richard.henderson@linaro.org> --- target/m68k/cpu.h | 21 +++++++++++++++++++++ target/m68k/fpu_helper.c | 22 +++++++++++----------- 2 files changed, 32 insertions(+), 11 deletions(-)