aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMarc Glisse <marc.glisse@inria.fr>2017-04-25 08:51:44 +0200
committerMarc Glisse <glisse@gcc.gnu.org>2017-04-25 06:51:44 +0000
commitbb0249cbb7500772af1bfcc68f8929d60f6cb51f (patch)
treee90536cb0cd55db656121748d26aa28fc47667d9 /gcc
parent452e929aae6965414b9fd85c23de7cd57e9f174b (diff)
downloadgcc-bb0249cbb7500772af1bfcc68f8929d60f6cb51f.zip
gcc-bb0249cbb7500772af1bfcc68f8929d60f6cb51f.tar.gz
gcc-bb0249cbb7500772af1bfcc68f8929d60f6cb51f.tar.bz2
Let tree_single_nonzero_warnv_p use range information
2017-04-25 Marc Glisse <marc.glisse@inria.fr> gcc/ * fold-const.c (tree_single_nonzero_warnv_p): Handle SSA_NAME. gcc/testsuite/ * gcc.dg/tree-ssa/cmpmul-1.c: New file. * gcc.dg/Wstrict-overflow-18.c: Xfail. From-SVN: r247123
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/fold-const.c5
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/Wstrict-overflow-18.c3
-rw-r--r--gcc/testsuite/gcc.dg/tree-ssa/cmpmul-1.c11
5 files changed, 27 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 95bb415..5b59d79 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+2017-04-25 Marc Glisse <marc.glisse@inria.fr>
+
+ * fold-const.c (tree_single_nonzero_warnv_p): Handle SSA_NAME.
+
2017-04-25 Julian Brown <julian@codesourcery.com>
Naveen H.S <Naveen.Hurugalawadi@cavium.com>
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index 4ae21fb..f0b8e7a 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -13412,6 +13412,11 @@ tree_single_nonzero_warnv_p (tree t, bool *strict_overflow_p)
}
break;
+ case SSA_NAME:
+ if (!INTEGRAL_TYPE_P (TREE_TYPE (t)))
+ break;
+ return expr_not_equal_to (t, wi::zero (TYPE_PRECISION (TREE_TYPE (t))));
+
default:
break;
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 824a8a1..4fb111e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2017-04-25 Marc Glisse <marc.glisse@inria.fr>
+
+ * gcc.dg/tree-ssa/cmpmul-1.c: New file.
+ * gcc.dg/Wstrict-overflow-18.c: Xfail.
+
2017-04-22 Janus Weil <janus@gcc.gnu.org>
PR fortran/80121
diff --git a/gcc/testsuite/gcc.dg/Wstrict-overflow-18.c b/gcc/testsuite/gcc.dg/Wstrict-overflow-18.c
index bab91ce..8c8ddcf 100644
--- a/gcc/testsuite/gcc.dg/Wstrict-overflow-18.c
+++ b/gcc/testsuite/gcc.dg/Wstrict-overflow-18.c
@@ -14,7 +14,8 @@ foo (struct c *p)
for (i = 0; i < p->a - p->b; ++i)
{
- if (i > 0) /* { dg-warning "signed overflow" "" } */
+ /* See PR80511 for the XFAIL. */
+ if (i > 0) /* { dg-warning "signed overflow" "" { xfail *-*-* } } */
sum += 2;
bar (p);
}
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/cmpmul-1.c b/gcc/testsuite/gcc.dg/tree-ssa/cmpmul-1.c
new file mode 100644
index 0000000..1e303b1
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/tree-ssa/cmpmul-1.c
@@ -0,0 +1,11 @@
+/* { dg-do compile } */
+/* { dg-options "-O2 -fdump-tree-optimized-raw" } */
+
+int f(int a, int b, int c){
+ c |= 1; // c cannot be 0
+ a *= c;
+ b *= c;
+ return a == b;
+}
+
+/* { dg-final { scan-tree-dump-not "bit_ior_expr" "optimized" } } */