diff options
author | Jakub Jelinek <jakub@redhat.com> | 2017-02-16 13:02:24 +0100 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2017-02-16 13:02:24 +0100 |
commit | bcac0b4dac8901040c029922589d7a06a119b574 (patch) | |
tree | de1876639993a295084e8ff6f66c03c0d20db2ee | |
parent | cc46a51d4ff8bc1c42b7e6ae472494733bed5c49 (diff) | |
download | gcc-bcac0b4dac8901040c029922589d7a06a119b574.zip gcc-bcac0b4dac8901040c029922589d7a06a119b574.tar.gz gcc-bcac0b4dac8901040c029922589d7a06a119b574.tar.bz2 |
re PR c++/79512 (ICE: Segfault in gimple_build_call_1, at gimple.c:218)
PR c++/79512
c/
* c-parser.c (c_parser_omp_target): For -fopenmp-simd
ignore #pragma omp target even when not followed by identifier.
cp/
* parser.c (cp_parser_omp_target): For -fopenmp-simd
ignore #pragma omp target even when not followed by identifier.
testsuite/
* c-c++-common/gomp/pr79512.c: New test.
From-SVN: r245504
-rw-r--r-- | gcc/c/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/c/c-parser.c | 5 | ||||
-rw-r--r-- | gcc/cp/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/cp/parser.c | 5 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/c-c++-common/gomp/pr79512.c | 14 |
6 files changed, 41 insertions, 0 deletions
diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog index 3e585b0..2a198ef 100644 --- a/gcc/c/ChangeLog +++ b/gcc/c/ChangeLog @@ -1,3 +1,9 @@ +2017-02-16 Jakub Jelinek <jakub@redhat.com> + + PR c++/79512 + * c-parser.c (c_parser_omp_target): For -fopenmp-simd + ignore #pragma omp target even when not followed by identifier. + 2017-02-14 Prathamesh Kulkarni <prathamesh.kulkarni@linaro.org> * gimpler-parser.c (c_parser_gimple_statement): Handle ABS_EXPR. diff --git a/gcc/c/c-parser.c b/gcc/c/c-parser.c index 2297750..968c1dc 100644 --- a/gcc/c/c-parser.c +++ b/gcc/c/c-parser.c @@ -16505,6 +16505,11 @@ c_parser_omp_target (c_parser *parser, enum pragma_context context, bool *if_p) return c_parser_omp_target_update (loc, parser, context); } } + if (!flag_openmp) /* flag_openmp_simd */ + { + c_parser_skip_to_pragma_eol (parser, false); + return false; + } stmt = make_node (OMP_TARGET); TREE_TYPE (stmt) = void_type_node; diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index d346d68..b48a6f2 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2017-02-16 Jakub Jelinek <jakub@redhat.com> + + PR c++/79512 + * parser.c (cp_parser_omp_target): For -fopenmp-simd + ignore #pragma omp target even when not followed by identifier. + 2017-02-15 Jason Merrill <jason@redhat.com> Jakub Jelinek <jakub@redhat.com> diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index cd41ee6..060962d 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -35981,6 +35981,11 @@ cp_parser_omp_target (cp_parser *parser, cp_token *pragma_tok, return cp_parser_omp_target_update (parser, pragma_tok, context); } } + if (!flag_openmp) /* flag_openmp_simd */ + { + cp_parser_skip_to_pragma_eol (parser, pragma_tok); + return false; + } stmt = make_node (OMP_TARGET); TREE_TYPE (stmt) = void_type_node; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 85624d9..3804577 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2017-02-16 Jakub Jelinek <jakub@redhat.com> + + PR c++/79512 + * c-c++-common/gomp/pr79512.c: New test. + 2017-02-15 Martin Sebor <msebor@redhat.com> PR c++/79363 diff --git a/gcc/testsuite/c-c++-common/gomp/pr79512.c b/gcc/testsuite/c-c++-common/gomp/pr79512.c new file mode 100644 index 0000000..19ddfaf --- /dev/null +++ b/gcc/testsuite/c-c++-common/gomp/pr79512.c @@ -0,0 +1,14 @@ +/* PR c++/79512 */ +/* { dg-options "-fopenmp-simd" } */ + +void +foo (void) +{ + #pragma omp target + #pragma omp teams + { + int i; + for (i = 0; i < 10; i++) + ; + } +} |