summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>2006-04-26 08:24:28 +0000
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>2006-04-26 08:24:28 +0000
commit5f3cc051e19bd380df7f98e6f94b2ef5d82cfac1 (patch)
tree26c0535fb503f2609e6c8641367f2666b6ffcb55
parent1c59d5a8cc7ef3ea30e23f6c13440c00b4902e33 (diff)
downloadppe42-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/ChangeLog3
-rw-r--r--gcc/testsuite/ChangeLog3
-rw-r--r--gcc/testsuite/g++.dg/gomp/pr26913.C19
-rw-r--r--gcc/tree-cfg.c5
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)
OpenPOWER on IntegriCloud