summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvries <vries@138bc75d-0d04-0410-961f-82ee72b054a4>2017-09-16 13:11:43 +0000
committervries <vries@138bc75d-0d04-0410-961f-82ee72b054a4>2017-09-16 13:11:43 +0000
commit93b7a91b5f49bc79b39a2d4bef8927c3399e142a (patch)
tree888bb213198ee08c5156289bb7ed91cf22bbfbcc
parent620f2f422246721e43578032a16680e826c8b15f (diff)
downloadgcc-93b7a91b5f49bc79b39a2d4bef8927c3399e142a.tar.gz
Fix condition folding in c_parser_omp_for_loop
2017-09-16 Tom de Vries <tom@codesourcery.com> PR c/81875 * c-parser.c (c_parser_omp_for_loop): Fold only operands of cond, not cond itself. * testsuite/libgomp.c-c++-common/pr81875.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252873 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/c/ChangeLog6
-rw-r--r--gcc/c/c-parser.c9
-rw-r--r--libgomp/ChangeLog5
-rw-r--r--libgomp/testsuite/libgomp.c-c++-common/pr81875.c46
4 files changed, 65 insertions, 1 deletions
diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog
index 742867a6ad9..135445e1bbd 100644
--- a/gcc/c/ChangeLog
+++ b/gcc/c/ChangeLog
@@ -1,3 +1,9 @@
+2017-09-16 Tom de Vries <tom@codesourcery.com>
+
+ PR c/81875
+ * c-parser.c (c_parser_omp_for_loop): Fold only operands of cond, not
+ cond itself.
+
2017-09-15 Joseph Myers <joseph@codesourcery.com>
PR c/82071
diff --git a/gcc/c/c-parser.c b/gcc/c/c-parser.c
index f4e1cf6aa0c..a36397b7fbe 100644
--- a/gcc/c/c-parser.c
+++ b/gcc/c/c-parser.c
@@ -15224,7 +15224,14 @@ c_parser_omp_for_loop (location_t loc, c_parser *parser, enum tree_code code,
cond = cond_expr.value;
cond = c_objc_common_truthvalue_conversion (cond_loc, cond);
- cond = c_fully_fold (cond, false, NULL);
+ if (COMPARISON_CLASS_P (cond))
+ {
+ tree op0 = TREE_OPERAND (cond, 0), op1 = TREE_OPERAND (cond, 1);
+ op0 = c_fully_fold (op0, false, NULL);
+ op1 = c_fully_fold (op1, false, NULL);
+ TREE_OPERAND (cond, 0) = op0;
+ TREE_OPERAND (cond, 1) = op1;
+ }
switch (cond_expr.original_code)
{
case GT_EXPR:
diff --git a/libgomp/ChangeLog b/libgomp/ChangeLog
index 9fafd622b60..0c8832cf097 100644
--- a/libgomp/ChangeLog
+++ b/libgomp/ChangeLog
@@ -1,3 +1,8 @@
+2017-09-16 Tom de Vries <tom@codesourcery.com>
+
+ PR c/81875
+ * testsuite/libgomp.c-c++-common/pr81875.c: New test.
+
2017-09-14 Tom de Vries <tom@codesourcery.com>
* testsuite/libgomp.c++/cancel-taskgroup-1.C: Remove.
diff --git a/libgomp/testsuite/libgomp.c-c++-common/pr81875.c b/libgomp/testsuite/libgomp.c-c++-common/pr81875.c
new file mode 100644
index 00000000000..3067d49a492
--- /dev/null
+++ b/libgomp/testsuite/libgomp.c-c++-common/pr81875.c
@@ -0,0 +1,46 @@
+/* { dg-do run } */
+
+extern
+#ifdef __cplusplus
+"C"
+#endif
+void abort (void);
+
+#define N 32ULL
+int a[N];
+
+const unsigned long long c = 0x7fffffffffffffffULL;
+
+void
+f2_tpf_static32 (void)
+{
+ unsigned long long i;
+ #pragma omp for
+ for (i = c + N; i > c; i -= 1ULL)
+ a[i - 1ULL - c] -= 4;
+}
+
+__attribute__((noinline, noclone)) int
+test_tpf_static32 (void)
+{
+ int i, j, k;
+ for (i = 0; i < N; i++)
+ a[i] = i - 25;
+
+ f2_tpf_static32 ();
+
+ for (i = 0; i < N; i++)
+ if (a[i] != i - 29)
+ return 1;
+
+ return 0;
+}
+
+int
+main ()
+{
+ if (test_tpf_static32 ())
+ abort ();
+
+ return 0;
+}