diff options
author | Jakub Jelinek <jakub@redhat.com> | 2009-09-22 08:42:26 +0200 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2009-09-22 08:42:26 +0200 |
commit | 40742b426995886335ba3d3352b8453f2090e772 (patch) | |
tree | 74a52a670deb64eba9b7906231590d60615b6d48 /gcc | |
parent | c8c1ca587bb12a6f4c5123c48683a94d2da630ba (diff) | |
download | gcc-40742b426995886335ba3d3352b8453f2090e772.zip gcc-40742b426995886335ba3d3352b8453f2090e772.tar.gz gcc-40742b426995886335ba3d3352b8453f2090e772.tar.bz2 |
re PR middle-end/41429 (gomp tests timeout with -fpic)
PR middle-end/41429
* tree-cfg.c (remove_useless_stmts_tc): Call gsi_next (gsi) even for
GIMPLE_EH_MUST_NOT_THROW cleanup.
(verify_types_in_gimple_stmt): Handle GIMPLE_EH_MUST_NOT_THROW.
* g++.dg/gomp/pr41429.C: New test.
From-SVN: r151966
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/gomp/pr41429.C | 5 | ||||
-rw-r--r-- | gcc/tree-cfg.c | 2 |
4 files changed, 19 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 59123c6..cc1a886 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2009-09-22 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/41429 + * tree-cfg.c (remove_useless_stmts_tc): Call gsi_next (gsi) even for + GIMPLE_EH_MUST_NOT_THROW cleanup. + (verify_types_in_gimple_stmt): Handle GIMPLE_EH_MUST_NOT_THROW. + 2009-09-22 Jack Howarth <howarth@bromo.med.uc.edu> PR middle-end/41260 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8bf9349..588c747 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-09-22 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/41429 + * g++.dg/gomp/pr41429.C: New test. + 2009-09-21 Giuseppe Scrivano <gscrivano@gnu.org> * gcc.dg/tree-ssa/tailrecursion-6.c: New file. diff --git a/gcc/testsuite/g++.dg/gomp/pr41429.C b/gcc/testsuite/g++.dg/gomp/pr41429.C new file mode 100644 index 0000000..7de41b8 --- /dev/null +++ b/gcc/testsuite/g++.dg/gomp/pr41429.C @@ -0,0 +1,5 @@ +// PR middle-end/41429 +// { dg-do compile { target fpic } } +// { dg-options "-fopenmp -O2 -fpic" } + +#include "pr37189.C" diff --git a/gcc/tree-cfg.c b/gcc/tree-cfg.c index ef5f322..cfde858 100644 --- a/gcc/tree-cfg.c +++ b/gcc/tree-cfg.c @@ -2001,6 +2001,7 @@ remove_useless_stmts_tc (gimple_stmt_iterator *gsi, struct rus_data *data) case GIMPLE_EH_MUST_NOT_THROW: this_may_throw = false; + gsi_next (gsi); break; default: @@ -4354,6 +4355,7 @@ verify_types_in_gimple_stmt (gimple stmt) case GIMPLE_PREDICT: case GIMPLE_RESX: case GIMPLE_EH_DISPATCH: + case GIMPLE_EH_MUST_NOT_THROW: return false; CASE_GIMPLE_OMP: |