aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHaijian Zhang <z.zhanghaijian@huawei.com>2020-04-24 08:56:25 +0800
committerRichard Biener <rguenther@suse.de>2020-04-24 11:25:38 +0200
commitcbd2a10dd9edadb262934aed64c0959339da68d1 (patch)
tree7907278cac6c08c1adff8e654207b05d24dc7fd8
parent6f6c79920883f3fc301a4acc0544ed5a130bf7c5 (diff)
downloadgcc-cbd2a10dd9edadb262934aed64c0959339da68d1.zip
gcc-cbd2a10dd9edadb262934aed64c0959339da68d1.tar.gz
gcc-cbd2a10dd9edadb262934aed64c0959339da68d1.tar.bz2
rtl combine should consider NaNs when generate fp min/max [PR94708]
As discussed on PR94708, it's unsafe for rtl combine to generate fp min/max under -funsafe-math-optimizations, considering NaNs. In addition to flag_unsafe_math_optimizations check, we also need to do extra mode feature testing here: && !HONOR_NANS (mode) && !HONOR_SIGNED_ZEROS (mode) 2020-04-24 Haijian Zhang <z.zhanghaijian@huawei.com> gcc/ PR rtl-optimization/94708 * combine.c (simplify_if_then_else): Add check for !HONOR_NANS (mode) && !HONOR_SIGNED_ZEROS (mode). gcc/testsuite/ PR fortran/94708 * gfortran.dg/pr94708.f90: New test.
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/combine.c5
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/pr94708.f9013
4 files changed, 28 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index cf97cfe..6032e68 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2020-04-24 Haijian Zhang <z.zhanghaijian@huawei.com>
+
+ PR rtl-optimization/94708
+ * combine.c (simplify_if_then_else): Add check for
+ !HONOR_NANS (mode) && !HONOR_SIGNED_ZEROS (mode).
+
2020-04-23 Martin Sebor <msebor@redhat.com>
PR driver/90983
diff --git a/gcc/combine.c b/gcc/combine.c
index cff76cd..4c324f3 100644
--- a/gcc/combine.c
+++ b/gcc/combine.c
@@ -6643,7 +6643,10 @@ simplify_if_then_else (rtx x)
/* Look for MIN or MAX. */
- if ((! FLOAT_MODE_P (mode) || flag_unsafe_math_optimizations)
+ if ((! FLOAT_MODE_P (mode)
+ || (flag_unsafe_math_optimizations
+ && !HONOR_NANS (mode)
+ && !HONOR_SIGNED_ZEROS (mode)))
&& comparison_p
&& rtx_equal_p (XEXP (cond, 0), true_rtx)
&& rtx_equal_p (XEXP (cond, 1), false_rtx)
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index a955cd5..4b1e9e1 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2020-04-24 Haijian Zhang <z.zhanghaijian@huawei.com>
+
+ PR rtl-optimization/94708
+ * gfortran.dg/pr94708.f90: New test.
+
2020-04-23 David Edelsohn <dje.gcc@gmail.com>
* gcc.dg/torture/pr90020.c: Skip on AIX.
diff --git a/gcc/testsuite/gfortran.dg/pr94708.f90 b/gcc/testsuite/gfortran.dg/pr94708.f90
new file mode 100644
index 0000000..9b5f138
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/pr94708.f90
@@ -0,0 +1,13 @@
+! { dg-do compile { target aarch64*-*-* } }
+! { dg-options "-O2 -funsafe-math-optimizations -fdump-rtl-combine" }
+
+subroutine f(vara,varb,varc,res)
+ REAL, INTENT(IN) :: vara,varb,varc
+ REAL, INTENT(out) :: res
+
+ res = vara
+ if (res .lt. varb) res = varb
+ if (res .gt. varc) res = varc
+end subroutine
+
+! { dg-final { scan-rtl-dump-not "smin" "combine" } }