diff options
author | Jakub Jelinek <jakub@redhat.com> | 2008-01-22 18:25:37 +0100 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2008-01-22 18:25:37 +0100 |
commit | 61c3a446a26621584ec95c6317df22826e301734 (patch) | |
tree | 1c406740b0055c955a3dfd59b712cbd0ff764cc9 /gcc | |
parent | 270e749db4e806317425bf51a774c87eae069057 (diff) | |
download | gcc-61c3a446a26621584ec95c6317df22826e301734.zip gcc-61c3a446a26621584ec95c6317df22826e301734.tar.gz gcc-61c3a446a26621584ec95c6317df22826e301734.tar.bz2 |
re PR c++/34607 (ICE with invalid for loop after #pragma omp for)
PR c++/34607
* c-parser.c (c_parser_omp_for_loop): Don't call c_finish_omp_for
if DECL_INITIAL (decl) is error_mark_node.
* semantics.c (finish_omp_for): Don't call c_finish_omp_for
if decl or init is error_mark_node.
* gcc.dg/gomp/pr34607.c: New test.
* g++.dg/gomp/pr34607.C: New test.
From-SVN: r131730
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/c-parser.c | 4 | ||||
-rw-r--r-- | gcc/cp/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/cp/semantics.c | 5 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/gomp/pr34607.C | 18 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/gomp/pr34607.c | 18 |
7 files changed, 54 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a428833..2f80c36 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,9 @@ 2008-01-22 Jakub Jelinek <jakub@redhat.com> + PR c++/34607 + * c-parser.c (c_parser_omp_for_loop): Don't call c_finish_omp_for + if DECL_INITIAL (decl) is error_mark_node. + PR c++/34914 * c-common.c (handle_vector_size_attribute): Only allow integral, scalar float and fixed point types. Handle OFFSET_TYPE diff --git a/gcc/c-parser.c b/gcc/c-parser.c index 107b114..72f8a21 100644 --- a/gcc/c-parser.c +++ b/gcc/c-parser.c @@ -7547,6 +7547,8 @@ c_parser_omp_for_loop (c_parser *parser) decl = check_for_loop_decls (); if (decl == NULL) goto error_init; + if (DECL_INITIAL (decl) == error_mark_node) + decl = error_mark_node; init = decl; } else if (c_parser_next_token_is (parser, CPP_NAME) @@ -7597,7 +7599,7 @@ c_parser_omp_for_loop (c_parser *parser) c_break_label = save_break; c_cont_label = save_cont; - /* Only bother calling c_finish_omp_for if we havn't already generated + /* Only bother calling c_finish_omp_for if we haven't already generated an error from the initialization parsing. */ if (decl != NULL && decl != error_mark_node && init != error_mark_node) return c_finish_omp_for (loc, decl, init, cond, incr, body, NULL); diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index b039b37..eab41cf 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,9 @@ 2008-01-22 Jakub Jelinek <jakub@redhat.com> + PR c++/34607 + * semantics.c (finish_omp_for): Don't call c_finish_omp_for + if decl or init is error_mark_node. + PR c++/34918 * error.c (dump_expr): Handle VECTOR_CST. diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 8cf9ceb..5afc701 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -3827,7 +3827,7 @@ tree finish_omp_for (location_t locus, tree decl, tree init, tree cond, tree incr, tree body, tree pre_body) { - tree omp_for; + tree omp_for = NULL; if (decl == NULL) { @@ -3919,7 +3919,8 @@ finish_omp_for (location_t locus, tree decl, tree init, tree cond, TREE_OPERAND (cond, n) = fold_build_cleanup_point_expr (TREE_TYPE (t), t); } - omp_for = c_finish_omp_for (locus, decl, init, cond, incr, body, pre_body); + if (decl != error_mark_node && init != error_mark_node) + omp_for = c_finish_omp_for (locus, decl, init, cond, incr, body, pre_body); if (omp_for != NULL && TREE_CODE (OMP_FOR_INCR (omp_for)) == MODIFY_EXPR && TREE_SIDE_EFFECTS (TREE_OPERAND (OMP_FOR_INCR (omp_for), 1)) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index aae550a..ab1f6b8 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,9 @@ 2008-01-22 Jakub Jelinek <jakub@redhat.com> + PR c++/34607 + * gcc.dg/gomp/pr34607.c: New test. + * g++.dg/gomp/pr34607.C: New test. + PR c++/34914 * g++.dg/ext/vector10.C: New test. diff --git a/gcc/testsuite/g++.dg/gomp/pr34607.C b/gcc/testsuite/g++.dg/gomp/pr34607.C new file mode 100644 index 0000000..1dbba4a --- /dev/null +++ b/gcc/testsuite/g++.dg/gomp/pr34607.C @@ -0,0 +1,18 @@ +// PR c++/34607 +// { dg-do compile } +// { dg-options "-fopenmp" } + +void +foo () +{ +#pragma omp for + for (int i =; i < 2; ++i) // { dg-error "expected primary-expression" } + ; +#pragma omp for + for (T i = 54; i < 56; i++) // { dg-error "was not declared|expected" } + ; + T j; // { dg-error "was not declared|expected" } +#pragma omp for + for (j = 1; j < 3; j++) // { dg-error "was not declared" } + ; // { dg-error "expected" } +} diff --git a/gcc/testsuite/gcc.dg/gomp/pr34607.c b/gcc/testsuite/gcc.dg/gomp/pr34607.c new file mode 100644 index 0000000..1b96099 --- /dev/null +++ b/gcc/testsuite/gcc.dg/gomp/pr34607.c @@ -0,0 +1,18 @@ +/* PR c++/34607 */ +/* { dg-do compile } */ +/* { dg-options "-fopenmp -std=gnu99" } */ + +void +foo () +{ +#pragma omp for + for (int i =; i < 2; ++i) /* { dg-error "expected expression before" } */ + ; +#pragma omp for + for (T i = 54; i < 56; i++) /* { dg-error "expected iteration declaration" } */ + ; + T j; /* { dg-error "undeclared|for each function|expected" } */ +#pragma omp for + for (j = 1; j < 3; j++) /* { dg-error "undeclared" } */ + ; +} |