diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c2e563914f6..1d562dced73 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2006-02-26 Richard Guenther + + PR tree-optimization/26421 + * tree-ssa-alias.c (find_used_portions): Don't treat parameters + in function calls that are ADDR_EXPRs as using the whole structure. + 2006-02-26 Steven Bosscher * common.opt (-floop-optimize, -frerun-loop-opt): Remove. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 68924f56938..81f9b5e7c1e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-02-26 Richard Guenther + + PR tree-optimization/26421 + * gcc.dg/tree-ssa/pr26421.c: New testcase. + 2006-02-26 Steven Bosscher * gcc.dg/20031201-1.c: Don't use -frerun-loop-opt. diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr26421.c b/gcc/testsuite/gcc.dg/tree-ssa/pr26421.c new file mode 100644 index 00000000000..edb3685c11e --- /dev/null +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr26421.c @@ -0,0 +1,19 @@ +/* { dg-do compile } */ +/* { dg-options "-O2 -fdump-tree-alias1-vops" } */ + +typedef struct { + int i; + int j; + int k; +} Foo; + +void bar(Foo*); +void foo(void) +{ + Foo a; + a.i = 1; + bar(&a); +} + +/* { dg-final { scan-tree-dump-times "V_MAY_DEF" 1 "alias1" } } */ +/* { dg-final { cleanup-tree-dump "alias1" } } */ diff --git a/gcc/tree-ssa-alias.c b/gcc/tree-ssa-alias.c index fe69198b2f2..5e13f00ed79 100644 --- a/gcc/tree-ssa-alias.c +++ b/gcc/tree-ssa-alias.c @@ -3078,6 +3078,17 @@ find_used_portions (tree *tp, int *walk_subtrees, void *lhs_p) } } break; + case CALL_EXPR: + { + tree *arg; + for (arg = &TREE_OPERAND (*tp, 1); *arg; arg = &TREE_CHAIN (*arg)) + { + if (TREE_CODE (TREE_VALUE (*arg)) != ADDR_EXPR) + find_used_portions (&TREE_VALUE (*arg), walk_subtrees, NULL); + } + *walk_subtrees = 0; + return NULL_TREE; + } case VAR_DECL: case PARM_DECL: case RESULT_DECL: