aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/fmax_d.h
diff options
context:
space:
mode:
authorAndrew Waterman <andrew@sifive.com>2017-02-01 23:11:59 -0800
committerAndrew Waterman <andrew@sifive.com>2017-02-01 23:11:59 -0800
commit6642f8c745b320bdb7bab2470c62defb1b1bb9e2 (patch)
tree976ece29fb16dc47c70c2dd2eab52f9c7ba4d642 /riscv/insns/fmax_d.h
parentd392463e5c8e47cfa030eb4640585302f800207f (diff)
downloadspike-6642f8c745b320bdb7bab2470c62defb1b1bb9e2.zip
spike-6642f8c745b320bdb7bab2470c62defb1b1bb9e2.tar.gz
spike-6642f8c745b320bdb7bab2470c62defb1b1bb9e2.tar.bz2
For FMIN(sNaN, x) and FMIN(qNaN, qNaN), return canonical NaN
Resolves #76
Diffstat (limited to 'riscv/insns/fmax_d.h')
-rw-r--r--riscv/insns/fmax_d.h4
1 files changed, 3 insertions, 1 deletions
diff --git a/riscv/insns/fmax_d.h b/riscv/insns/fmax_d.h
index f0bea9b..56c9c7a 100644
--- a/riscv/insns/fmax_d.h
+++ b/riscv/insns/fmax_d.h
@@ -1,4 +1,6 @@
require_extension('D');
require_fp;
-WRITE_FRD(isNaNF64UI(FRS2) || f64_le_quiet(f64(FRS2), f64(FRS1)) ? FRS1 : FRS2);
+WRITE_FRD(f64_le_quiet(f64(FRS2), f64(FRS1)) || isNaNF64UI(FRS2) ? FRS1 : FRS2);
+if ((isNaNF64UI(FRS1) && isNaNF64UI(FRS2)) || softfloat_exceptionFlags)
+ WRITE_FRD(defaultNaNF64UI);
set_fp_exceptions;