aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/match.pd3
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr79818.c19
4 files changed, 32 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index c8b375e..73b2f21 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2017-03-03 Richard Biener <rguenther@suse.de>
+
+ PR middle-end/79818
+ * match.pd ( X +- C1 CMP C2 -> X CMP C2 -+ C1): Add missing
+ TYPE_OVERFLOW_UNDEFINED check.
+
2017-03-02 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
* config/rs6000/vector.md (vector_ne_<mode>_p): Correct operand
diff --git a/gcc/match.pd b/gcc/match.pd
index 7b96800..4e6f719 100644
--- a/gcc/match.pd
+++ b/gcc/match.pd
@@ -3688,7 +3688,8 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
&& !TYPE_OVERFLOW_TRAPS (TREE_TYPE (@0))
&& !TYPE_SATURATING (TREE_TYPE (@0)))
(with { tree res = int_const_binop (rop, @2, @1); }
- (if (TREE_OVERFLOW (res))
+ (if (TREE_OVERFLOW (res)
+ && TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (@0)))
{ constant_boolean_node (cmp == NE_EXPR, type); }
(if (single_use (@3))
(cmp @0 { res; }))))))))
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b0034ed..e5a08ac 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2017-03-03 Richard Biener <rguenther@suse.de>
+
+ PR middle-end/79818
+ * gcc.dg/torture/pr79818.c: New testcase.
+
2017-03-02 Jakub Jelinek <jakub@redhat.com>
PR c++/79782
diff --git a/gcc/testsuite/gcc.dg/torture/pr79818.c b/gcc/testsuite/gcc.dg/torture/pr79818.c
new file mode 100644
index 0000000..5c12089
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr79818.c
@@ -0,0 +1,19 @@
+/* { dg-do run } */
+/* { dg-additional-options "-fwrapv" } */
+
+static void __attribute__((noinline,noclone))
+func(void)
+{
+ signed char c = 0;
+
+ for(; c >= 0; c++);
+
+ if(c != -128)
+ __builtin_abort();
+}
+
+int main(int argc, char* argv[])
+{
+ func();
+ return 0;
+}