From: Richard Guenther Date: Fri, 30 Jan 2009 22:14:39 +0000 (+0000) Subject: re PR tree-optimization/39041 (ICE on valid during vrp2) X-Git-Tag: releases/gcc-4.3.4~367 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=4c0a792cb33bcb6a94daead8a11144ccca7b7bf2;p=thirdparty%2Fgcc.git re PR tree-optimization/39041 (ICE on valid during vrp2) 2009-01-30 Richard Guenther PR tree-optimization/39041 * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Propagate variable indices only if the types match for this stmt. * gcc.c-torture/compile/pr39041.c: New testcase. From-SVN: r143809 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index fa6334a7e081..0f79c072dd6d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2009-01-30 Richard Guenther + + PR tree-optimization/39041 + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): + Propagate variable indices only if the types match for this stmt. + 2009-01-29 Uros Bizjak Backport from mainline: diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index ee63e611938f..fbe3d8a5d9d7 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-01-30 Richard Guenther + + PR tree-optimization/39041 + * gcc.c-torture/compile/pr39041.c: New testcase. + 2009-01-30 H.J. Lu Backport from mainline: diff --git a/gcc/testsuite/gcc.c-torture/compile/pr39041.c b/gcc/testsuite/gcc.c-torture/compile/pr39041.c new file mode 100644 index 000000000000..cc58a8a37e05 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/compile/pr39041.c @@ -0,0 +1,28 @@ +int test_bit(int nr, void *addr) +{ + int *a = (int *)addr; + int mask; + a += nr; + mask = 1 << nr; + return mask & *a; +} +struct { + struct { + int disabled; + } *data[1]; +} trace; +struct { + unsigned bits[1]; +} cpumask; +void inc(int *); +void dec(int *); +int foo(void) +{ + int cpu; + for (cpu = 0; cpu < 1; cpu++) { + if (test_bit(cpu, cpumask.bits)) + inc(&trace.data[cpu]->disabled); + if (!test_bit(cpu, cpumask.bits)) + dec(&trace.data[cpu]->disabled); + } +} diff --git a/gcc/tree-ssa-forwprop.c b/gcc/tree-ssa-forwprop.c index 1b901f1b2678..c0e0cf800d3e 100644 --- a/gcc/tree-ssa-forwprop.c +++ b/gcc/tree-ssa-forwprop.c @@ -677,6 +677,7 @@ forward_propagate_addr_expr_1 (tree name, tree def_rhs, tree use_stmt, array elements, then the result is converted into the proper type for the arithmetic. */ if (TREE_CODE (TREE_OPERAND (rhs, 1)) == SSA_NAME + && useless_type_conversion_p (TREE_TYPE (name), TREE_TYPE (def_rhs)) /* Avoid problems with IVopts creating PLUS_EXPRs with a different type than their operands. */ && useless_type_conversion_p (TREE_TYPE (rhs), TREE_TYPE (name)))