From 722ba5eeacaeaf2c913d74f5d17b5e8ab9f04d37 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Wed, 30 May 2007 15:46:25 +0200 Subject: [PATCH] re PR tree-optimization/31769 (ICE with OpenMP and exceptions) PR tree-optimization/31769 * except.c (duplicate_eh_regions): Clear prev_try if ERT_MUST_NOT_THROW region is inside of ERT_TRY region. * g++.dg/gomp/pr31769.C: New test. From-SVN: r125183 --- gcc/ChangeLog | 6 +++ gcc/except.c | 6 ++- gcc/testsuite/ChangeLog | 5 +++ gcc/testsuite/g++.dg/gomp/pr31769.C | 61 +++++++++++++++++++++++++++++ 4 files changed, 77 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/g++.dg/gomp/pr31769.C diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3030d3ccd00..9229ee17656 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2007-05-30 Jakub Jelinek + + PR tree-optimization/31769 + * except.c (duplicate_eh_regions): Clear prev_try if + ERT_MUST_NOT_THROW region is inside of ERT_TRY region. + 2007-05-30 Zdenek Dvorak * tree-scalar-evolution.c (scev_const_prop): Do not create labels. diff --git a/gcc/except.c b/gcc/except.c index 29a28d71546..b360ae4ad1d 100644 --- a/gcc/except.c +++ b/gcc/except.c @@ -1005,7 +1005,11 @@ duplicate_eh_regions (struct function *ifun, duplicate_eh_regions_map map, for (prev_try = VEC_index (eh_region, cfun->eh->region_array, outer_region); prev_try && prev_try->type != ERT_TRY; prev_try = prev_try->outer) - ; + if (prev_try->type == ERT_MUST_NOT_THROW) + { + prev_try = NULL; + break; + } /* Remap all of the internal catch and cleanup linkages. Since we duplicate entire subtrees, all of the referenced regions will have diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d69c0d748e1..84d379a380a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2007-05-30 Jakub Jelinek + + PR tree-optimization/31769 + * g++.dg/gomp/pr31769.C: New test. + 2007-05-29 Hui-May Chang * gcc.target/i386/stack-realign.c: New. diff --git a/gcc/testsuite/g++.dg/gomp/pr31769.C b/gcc/testsuite/g++.dg/gomp/pr31769.C new file mode 100644 index 00000000000..54945f94efa --- /dev/null +++ b/gcc/testsuite/g++.dg/gomp/pr31769.C @@ -0,0 +1,61 @@ +// PR tree-optimization/31769 +// { dg-options "-O2 -fopenmp" } +// { dg-do compile } + +struct B +{ + B () {} + virtual ~B () {} +}; +struct C +{ + C (int x, int y) {} +}; +template +struct D +{ + D () {} + ~D () {} +}; +struct E +{ + E () {} + ~E () {} + D e; +}; +struct A +{ + B *b; + A () { b = __null; } + ~A () { if (b != __null) delete b; } +}; +struct F : public A +{ + explicit F (int x) { foo (0); } + F (const F &x) {} + F (F &x, C y) {} + F operator () (C x) const + { + return F (const_cast(*this), x); + } + template F & operator+= (const U &); + void foo (int); + E f; +}; + +int +main () +{ + try + { + F f (10); + F g (10); + C h (0, 9); +#pragma omp parallel for + for (int i = 0; i < 2; ++i) + g += f (h); + } + catch (int &e) + { + } +}