On Wed, Feb 29, 2012 at 4:31 PM, Jakub Jelinek <ja...@redhat.com> wrote: > Hi! > > Since debug stmts can contain LABEL_DECLs we can ICE in parloops on them, > fixed thusly, bootstrapped/regtested on x86_64-linux and i686-linux. Ok > for trunk?
Ok. Thanks, Richard. > 2012-02-29 Jakub Jelinek <ja...@redhat.com> > > PR tree-optimization/52429 > * tree-parloops.c (separate_decls_in_region_debug): Return early > if var is LABEL_DECL. > > * gcc.dg/torture/pr52429.c: New test. > * g++.dg/opt/pr52429.C: New test. > > --- gcc/tree-parloops.c.jj 2012-02-12 15:46:32.000000000 +0100 > +++ gcc/tree-parloops.c 2012-02-29 13:06:18.857910264 +0100 > @@ -909,7 +909,7 @@ separate_decls_in_region_debug (gimple s > var = gimple_debug_source_bind_get_var (stmt); > else > return true; > - if (TREE_CODE (var) == DEBUG_EXPR_DECL) > + if (TREE_CODE (var) == DEBUG_EXPR_DECL || TREE_CODE (var) == LABEL_DECL) > return true; > gcc_assert (DECL_P (var) && SSA_VAR_P (var)); > ielt.uid = DECL_UID (var); > --- gcc/testsuite/gcc.dg/torture/pr52429.c.jj 2012-02-29 13:39:25.133074390 > +0100 > +++ gcc/testsuite/gcc.dg/torture/pr52429.c 2012-02-29 13:39:04.000000000 > +0100 > @@ -0,0 +1,24 @@ > +/* PR tree-optimization/52429 */ > +/* { dg-do compile } */ > +/* { dg-require-effective-target pthread } */ > +/* { dg-options "-g -ftree-parallelize-loops=4" } */ > + > +double d[65536], e[65536]; > + > +void > +foo (void) > +{ > + int i; > + double f, g; > + for (i = 0; i < 65536; i++) > + { > + f = e[i]; > + goto lab1; > + lab2: > + d[i] = f * g; > + continue; > + lab1: > + g = d[i]; > + goto lab2; > + } > +} > --- gcc/testsuite/g++.dg/opt/pr52429.C.jj 2012-02-29 13:37:15.918778821 > +0100 > +++ gcc/testsuite/g++.dg/opt/pr52429.C 2012-02-29 13:36:42.000000000 +0100 > @@ -0,0 +1,23 @@ > +// PR tree-optimization/52429 > +// { dg-do compile } > +// { dg-require-effective-target pthread } > +// { dg-options "-O -g -ftree-parallelize-loops=4" } > + > +struct B > +{ > + B () : b (__null) {} > + int *b; > +}; > + > +void * > +operator new (__SIZE_TYPE__, void *p) > +{ > + return p; > +} > + > +void > +foo (B *x, unsigned y) > +{ > + while (y--) > + new (x) B; > +} > > Jakub