fold_real_zero_addition_p for vectors
authorMarc Glisse <marc.glisse@inria.fr>
Tue, 11 Jun 2019 12:48:26 +0000 (14:48 +0200)
committerMarc Glisse <glisse@gcc.gnu.org>
Tue, 11 Jun 2019 12:48:26 +0000 (12:48 +0000)
2019-06-11  Marc Glisse  <marc.glisse@inria.fr>

PR tree-optimization/62041
* fold-const.c (fold_real_zero_addition_p): Handle vectors.

From-SVN: r272151

gcc/ChangeLog
gcc/fold-const.c

index f115982cf1d7f0c30a2a69fa0a878cf17e43c7a7..211a55db079d35fbd6e8aef3a2cb22a3822891e6 100644 (file)
@@ -1,3 +1,8 @@
+2019-06-11  Marc Glisse  <marc.glisse@inria.fr>
+
+       PR tree-optimization/62041
+       * fold-const.c (fold_real_zero_addition_p): Handle vectors.
+
 2019-06-11  Jason Merrill  <jason@redhat.com>
 
        * gdbhooks.py (TreePrinter.to_string): Recognize ggc_free'd memory.
index 8252cc6bb6bfd5407653c2eee62899696b8f19ab..0ca472d422fd3f9b778c3cace51135eae74fb2fc 100644 (file)
@@ -6722,15 +6722,21 @@ fold_real_zero_addition_p (const_tree type, const_tree addend, int negate)
     return false;
 
   /* Don't allow the fold with -fsignaling-nans.  */
-  if (HONOR_SNANS (element_mode (type)))
+  if (HONOR_SNANS (type))
     return false;
 
   /* Allow the fold if zeros aren't signed, or their sign isn't important.  */
-  if (!HONOR_SIGNED_ZEROS (element_mode (type)))
+  if (!HONOR_SIGNED_ZEROS (type))
     return true;
 
+  /* There is no case that is safe for all rounding modes.  */
+  if (HONOR_SIGN_DEPENDENT_ROUNDING (type))
+    return false;
+
   /* In a vector or complex, we would need to check the sign of all zeros.  */
-  if (TREE_CODE (addend) != REAL_CST)
+  if (TREE_CODE (addend) == VECTOR_CST)
+    addend = uniform_vector_p (addend);
+  if (!addend || TREE_CODE (addend) != REAL_CST)
     return false;
 
   /* Treat x + -0 as x - 0 and x - -0 as x + 0.  */
@@ -6739,9 +6745,8 @@ fold_real_zero_addition_p (const_tree type, const_tree addend, int negate)
 
   /* The mode has signed zeros, and we have to honor their sign.
      In this situation, there is only one case we can return true for.
-     X - 0 is the same as X unless rounding towards -infinity is
-     supported.  */
-  return negate && !HONOR_SIGN_DEPENDENT_ROUNDING (element_mode (type));
+     X - 0 is the same as X with default rounding.  */
+  return negate;
 }
 
 /* Subroutine of match.pd that optimizes comparisons of a division by