diff options
| author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-04-26 08:24:28 +0000 |
|---|---|---|
| committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-04-26 08:24:28 +0000 |
| commit | 5f3cc051e19bd380df7f98e6f94b2ef5d82cfac1 (patch) | |
| tree | 26c0535fb503f2609e6c8641367f2666b6ffcb55 | |
| parent | 1c59d5a8cc7ef3ea30e23f6c13440c00b4902e33 (diff) | |
| download | ppe42-gcc-5f3cc051e19bd380df7f98e6f94b2ef5d82cfac1.tar.gz ppe42-gcc-5f3cc051e19bd380df7f98e6f94b2ef5d82cfac1.zip | |
PR middle-end/26913
* tree-cfg.c (find_outermost_region_in_block): Handle RESX_EXPR.
* g++.dg/gomp/pr26913.C: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@113270 138bc75d-0d04-0410-961f-82ee72b054a4
| -rw-r--r-- | gcc/ChangeLog | 3 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 3 | ||||
| -rw-r--r-- | gcc/testsuite/g++.dg/gomp/pr26913.C | 19 | ||||
| -rw-r--r-- | gcc/tree-cfg.c | 5 |
4 files changed, 29 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 0a3504d15bf..ebec042da70 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,8 @@ 2006-04-26 Jakub Jelinek <jakub@redhat.com> + PR middle-end/26913 + * tree-cfg.c (find_outermost_region_in_block): Handle RESX_EXPR. + 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. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index c59270d4be8..e3f19e04c62 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2006-04-26 Jakub Jelinek <jakub@redhat.com> + PR middle-end/26913 + * g++.dg/gomp/pr26913.C: New test. + PR c/25996 * gcc.dg/gomp/pr25996.c: New test. * g++.dg/gomp/pr25996.C: New test. diff --git a/gcc/testsuite/g++.dg/gomp/pr26913.C b/gcc/testsuite/g++.dg/gomp/pr26913.C new file mode 100644 index 00000000000..4f5bb2834c4 --- /dev/null +++ b/gcc/testsuite/g++.dg/gomp/pr26913.C @@ -0,0 +1,19 @@ +// PR middle-end/26913 + +struct A +{ + ~A () throw (); +}; + +void foo (A); + +A bar () throw (); + +void baz () +{ +#pragma omp parallel + { + A a; + foo (bar ()); + } +} diff --git a/gcc/tree-cfg.c b/gcc/tree-cfg.c index 7913e528805..9ae48eb4b2b 100644 --- a/gcc/tree-cfg.c +++ b/gcc/tree-cfg.c @@ -4744,7 +4744,10 @@ find_outermost_region_in_block (struct function *src_cfun, tree stmt = bsi_stmt (si); int stmt_region; - stmt_region = lookup_stmt_eh_region_fn (src_cfun, stmt); + if (TREE_CODE (stmt) == RESX_EXPR) + stmt_region = TREE_INT_CST_LOW (TREE_OPERAND (stmt, 0)); + else + stmt_region = lookup_stmt_eh_region_fn (src_cfun, stmt); if (stmt_region > 0) { if (region < 0) |

