diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3a59fe7c1b1..8b2e26b55c5 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2012-02-29 Jakub Jelinek + + PR tree-optimization/52429 + * tree-parloops.c (separate_decls_in_region_debug): Return early + if var is LABEL_DECL. + 2012-02-29 Bill Schmidt PR tree-optimization/52424 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 4abeb9af661..7b1ad21c8d4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2012-02-29 Jakub Jelinek + + PR tree-optimization/52429 + * gcc.dg/torture/pr52429.c: New test. + * g++.dg/opt/pr52429.C: New test. + 2012-02-29 Richard Guenther PR testsuite/52297 diff --git a/gcc/testsuite/g++.dg/opt/pr52429.C b/gcc/testsuite/g++.dg/opt/pr52429.C new file mode 100644 index 00000000000..0ab8b4015ae --- /dev/null +++ b/gcc/testsuite/g++.dg/opt/pr52429.C @@ -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; +} diff --git a/gcc/testsuite/gcc.dg/torture/pr52429.c b/gcc/testsuite/gcc.dg/torture/pr52429.c new file mode 100644 index 00000000000..e2aeaa9714d --- /dev/null +++ b/gcc/testsuite/gcc.dg/torture/pr52429.c @@ -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; + } +} diff --git a/gcc/tree-parloops.c b/gcc/tree-parloops.c index 221f25798f3..0ae5d444e67 100644 --- a/gcc/tree-parloops.c +++ b/gcc/tree-parloops.c @@ -909,7 +909,7 @@ separate_decls_in_region_debug (gimple stmt, htab_t name_copies, 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);