re PR c/25996 ([gomp] ICE on undefined iteration variable)
authorJakub Jelinek <jakub@redhat.com>
Wed, 26 Apr 2006 08:23:12 +0000 (10:23 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Wed, 26 Apr 2006 08:23:12 +0000 (10:23 +0200)
PR c/25996
* c-parser.c (c_parser_omp_for_loop): Don't call c_finish_omp_for if
either decl or init is error_mark_node.

* gcc.dg/gomp/pr25996.c: New test.
* g++.dg/gomp/pr25996.C: New test.

From-SVN: r113269

gcc/ChangeLog
gcc/c-parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/gomp/pr25996.C [new file with mode: 0644]
gcc/testsuite/gcc.dg/gomp/pr25996.c [new file with mode: 0644]

index 28f8d3f707b96e01334009fc1d923b712238426e..0a3504d15bfe24b2854c646eb48ed1cc587cf2e7 100644 (file)
@@ -1,5 +1,9 @@
 2006-04-26  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c/25996
+       * c-parser.c (c_parser_omp_for_loop): Don't call c_finish_omp_for if
+       either decl or init is error_mark_node.
+
        PR middle-end/25989
        * tree-flow.h (struct omp_region): Add sched_kind.
        * omp-low.c (expand_parallel_call): Use region->inner->sched_kind
index 0c90fa84bd875c75796b86c2258246451a7af4cd..8cad3108243172a572ee12d9ba5363053f3e0f09 100644 (file)
@@ -7379,7 +7379,7 @@ c_parser_omp_for_loop (c_parser *parser)
 
   /* Only bother calling c_finish_omp_for if we havn't already generated
      an error from the initialization parsing.  */
-  if (decl != NULL)
+  if (decl != NULL && decl != error_mark_node && init != error_mark_node)
     return c_finish_omp_for (loc, decl, init, cond, incr, body, NULL);
   return NULL;
 
index 4f4944eff2fe4cb88e73d40452f39e171995e7a4..c59270d4be8f4206403e53f9792513e6489ccdbd 100644 (file)
@@ -1,3 +1,9 @@
+2006-04-26  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c/25996
+       * gcc.dg/gomp/pr25996.c: New test.
+       * g++.dg/gomp/pr25996.C: New test.
+
 2006-04-25  Richard Sandiford  <richard@codesourcery.com>
 
        PR rtl-optimization/26725
diff --git a/gcc/testsuite/g++.dg/gomp/pr25996.C b/gcc/testsuite/g++.dg/gomp/pr25996.C
new file mode 100644 (file)
index 0000000..6b50ff0
--- /dev/null
@@ -0,0 +1,32 @@
+// PR c/25996
+
+void
+test1 (void)
+{
+#pragma omp for
+  for (i = 0; i < 1; ++i); // { dg-error "not declared|expected iteration decl" }
+}
+
+void
+test2 (void)
+{
+  int i;
+#pragma omp for
+  for (i = j; i < 1; ++i); // { dg-error "not declared|expected iteration decl" }
+}
+
+void
+test3 (void)
+{
+  int i;
+#pragma omp for
+  for (i = 0; i < j; ++i); // { dg-error "not declared|invalid controlling predicate" }
+}
+
+void
+test4 (void)
+{
+  int i;
+#pragma omp for
+  for (i = 0; i < 10; i += j); // { dg-error "not declared|invalid increment expression" }
+}
diff --git a/gcc/testsuite/gcc.dg/gomp/pr25996.c b/gcc/testsuite/gcc.dg/gomp/pr25996.c
new file mode 100644 (file)
index 0000000..d58c9a1
--- /dev/null
@@ -0,0 +1,32 @@
+/* PR c/25996 */
+
+void
+test1 (void)
+{
+#pragma omp for
+  for (i = 0; i < 1; ++i); /* { dg-error "undeclared|for each function" } */
+}
+
+void
+test2 (void)
+{
+  int i;
+#pragma omp for
+  for (i = j; i < 1; ++i); /* { dg-error "undeclared" } */
+}
+
+void
+test3 (void)
+{
+  int i;
+#pragma omp for
+  for (i = 0; i < j; ++i); /* { dg-error "undeclared|invalid controlling predicate" } */
+}
+
+void
+test4 (void)
+{
+  int i;
+#pragma omp for
+  for (i = 0; i < 10; i += j); /* { dg-error "undeclared|invalid increment expression" } */
+}