From: Daniel Berlin Date: Fri, 13 Jan 2006 16:00:13 +0000 (+0000) Subject: re PR tree-optimization/25771 (ice in coalesce_abnormal_edges, at tree-outof-ssa... X-Git-Tag: releases/gcc-4.2.0~4890 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=aa4b71172e97ace10387de90ac6aee72381dc6f0;p=thirdparty%2Fgcc.git re PR tree-optimization/25771 (ice in coalesce_abnormal_edges, at tree-outof-ssa.c:621) 2006-01-13 Daniel Berlin PR tree-optimization/25771 * tree-ssa-pre.c (insert_extra_phis): Don't insert merges of abnormal SSA_NAMES. From-SVN: r109669 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 42e8a7a5ab2a..6d2d109752ad 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2006-01-13 Daniel Berlin + + PR tree-optimization/25771 + * tree-ssa-pre.c (insert_extra_phis): Don't insert merges of abnormal + SSA_NAMES. + 2006-01-13 Andrew Pinski PR tree-opt/24365 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 593db14ca547..1a59f59c355c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-01-13 Daniel Berlin + + PR tree-optimization/25771 + * g++.dg/tree-ssa/pr25771.C: New test + 2006-01-13 Andrew Pinski PR tree-opt/24365 diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr25771.C b/gcc/testsuite/g++.dg/tree-ssa/pr25771.C new file mode 100644 index 000000000000..e9e53360ebfe --- /dev/null +++ b/gcc/testsuite/g++.dg/tree-ssa/pr25771.C @@ -0,0 +1,32 @@ +int ggggg(); +struct string { + static int _S_empty_rep_storage[]; + void _M_destroy(); + char* _M_rep; + ~string() + { + if (_M_rep != (char*)&_S_empty_rep_storage ) + if (ggggg() <= 0) + _M_destroy(); + } +}; +extern void SDL_FreeSurface(int surface); +struct scoped_resource { + ~scoped_resource() { + SDL_FreeSurface(1); + } +}; +struct surface { + scoped_resource surface_; +}; +struct button { + string help_text_; + string label_; + surface image_; +}; +struct scrollbar { + string help_text_; + button uparrow_; +}; +scrollbar a; + diff --git a/gcc/tree-ssa-pre.c b/gcc/tree-ssa-pre.c index bf3e5249b77b..ada654b17c1d 100644 --- a/gcc/tree-ssa-pre.c +++ b/gcc/tree-ssa-pre.c @@ -2768,6 +2768,9 @@ insert_extra_phis (basic_block block, basic_block dom) tree val = get_value_handle (name); tree temp; + if (SSA_NAME_OCCURS_IN_ABNORMAL_PHI (name)) + continue; + if (!mergephitemp || TREE_TYPE (name) != TREE_TYPE (mergephitemp)) {