re PR tree-optimization/92644 (ICE in wide_int_to_tree_1, at tree.c:1530)
authorJakub Jelinek <jakub@redhat.com>
Tue, 26 Nov 2019 08:43:27 +0000 (09:43 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Tue, 26 Nov 2019 08:43:27 +0000 (09:43 +0100)
PR tree-optimization/92644
* tree-ssa-phiopt.c (minmax_replacement): Add INTEGRAL_TYPE_P check
next to INTEGER_CST checks.

* g++.dg/opt/pr92644.C: New test.

From-SVN: r278720

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/opt/pr92644.C [new file with mode: 0644]
gcc/tree-ssa-phiopt.c

index 6ea6e5b592fa25608c49a73499a153dc6bff0444..633836f410d397d6bd63cafe82a300870f6e54eb 100644 (file)
@@ -1,3 +1,9 @@
+2019-11-26  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/92644
+       * tree-ssa-phiopt.c (minmax_replacement): Add INTEGRAL_TYPE_P check
+       next to INTEGER_CST checks.
+
 2019-11-26  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/92645
index d105b609c84adad67d190d47c4204bc43fabbf3f..325572b5f7be461a82dfdbe65ca96c7e66f02ed0 100644 (file)
@@ -1,3 +1,8 @@
+2019-11-26  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/92644
+       * g++.dg/opt/pr92644.C: New test.
+
 2019-11-26  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/92645
diff --git a/gcc/testsuite/g++.dg/opt/pr92644.C b/gcc/testsuite/g++.dg/opt/pr92644.C
new file mode 100644 (file)
index 0000000..2f8a86f
--- /dev/null
@@ -0,0 +1,6 @@
+// PR tree-optimization/92644
+// { dg-do compile { target c++14 } }
+// { dg-options "-O2 -fno-early-inlining" }
+
+inline auto foo () { return nullptr; }
+int bar () { return foo () ? 1 : 0; }
index 90583096c945d2d9f6c541b365bddd9b3b897aa2..1ae925dc570477fc842651c1a82f9358ede6f74b 100644 (file)
@@ -1381,7 +1381,8 @@ minmax_replacement (basic_block cond_bb, basic_block middle_bb,
 
   /* Turn EQ/NE of extreme values to order comparisons.  */
   if ((cmp == NE_EXPR || cmp == EQ_EXPR)
-      && TREE_CODE (rhs) == INTEGER_CST)
+      && TREE_CODE (rhs) == INTEGER_CST
+      && INTEGRAL_TYPE_P (TREE_TYPE (rhs)))
     {
       if (wi::eq_p (wi::to_wide (rhs), wi::min_value (TREE_TYPE (rhs))))
        {
@@ -1407,7 +1408,8 @@ minmax_replacement (basic_block cond_bb, basic_block middle_bb,
       larger = rhs;
       /* If we have smaller < CST it is equivalent to smaller <= CST-1.
         Likewise smaller <= CST is equivalent to smaller < CST+1.  */
-      if (TREE_CODE (larger) == INTEGER_CST)
+      if (TREE_CODE (larger) == INTEGER_CST
+         && INTEGRAL_TYPE_P (TREE_TYPE (larger)))
        {
          if (cmp == LT_EXPR)
            {
@@ -1435,7 +1437,8 @@ minmax_replacement (basic_block cond_bb, basic_block middle_bb,
       larger = gimple_cond_lhs (cond);
       /* If we have larger > CST it is equivalent to larger >= CST+1.
         Likewise larger >= CST is equivalent to larger > CST-1.  */
-      if (TREE_CODE (smaller) == INTEGER_CST)
+      if (TREE_CODE (smaller) == INTEGER_CST
+         && INTEGRAL_TYPE_P (TREE_TYPE (smaller)))
        {
          wi::overflow_type overflow;
          if (cmp == GT_EXPR)