diff options
| -rw-r--r-- | gcc/ChangeLog | 6 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
| -rw-r--r-- | gcc/testsuite/gcc.dg/pr23911.c | 22 | ||||
| -rw-r--r-- | gcc/tree-ssa-ccp.c | 9 |
4 files changed, 41 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 7b1ffbb..fb66403 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2005-09-29 Steven Bosscher <stevenb@suse.de> + + PR tree-optimization/23911 + * tree-ssa-ccp.c (fold_const_aggregate_ref): Handle REALPART_EXPR + and IMAGPART_EXPR too. + 2005-09-28 Mark Mitchell <mark@codesourcery.com> PR 17886 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 1c426b4..6146c23 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2005-09-29 Steven Bosscher <stevenb@suse.de> + + * gcc.dg/pr23911.c: New test. + 2005-09-28 Mark Mitchell <mark@codesourcery.com> * g++.dg/opt/pr19650.C: Use -w -fpermissive. diff --git a/gcc/testsuite/gcc.dg/pr23911.c b/gcc/testsuite/gcc.dg/pr23911.c new file mode 100644 index 0000000..1003075 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr23911.c @@ -0,0 +1,22 @@ +/* This was a missed optimization in tree constant propagation + that CSE would catch later on. */ +/* { dg-do compile } */ +/* { dg-options "-O2 -fdump-tree-store_ccp" } */ + +double _Complex *a; +const double _Complex b[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; + +void +test (void) +{ + a[0] = b[0] + b[1]; + a[1] = b[0] + b[1]; + return; +} + +/* After store_ccp, there should not be any assignments from real or + imaginary parts anymore. The constants should be loaded from b and + propagated into the elements of a. */ +/* { dg-final { scan-tree-dump-times "= CR" 0 "store_ccp" } } */ +/* { dg-final { scan-tree-dump-times "= CI" 0 "store_ccp" } } */ +/* { dg-final { cleanup-tree-dump "store_ccp" } } */ diff --git a/gcc/tree-ssa-ccp.c b/gcc/tree-ssa-ccp.c index 1ff1528..43b8129 100644 --- a/gcc/tree-ssa-ccp.c +++ b/gcc/tree-ssa-ccp.c @@ -1045,6 +1045,15 @@ fold_const_aggregate_ref (tree t) return cval; break; + case REALPART_EXPR: + case IMAGPART_EXPR: + { + tree c = fold_const_aggregate_ref (TREE_OPERAND (t, 0)); + if (c && TREE_CODE (c) == COMPLEX_CST) + return fold_build1 (TREE_CODE (t), TREE_TYPE (t), c); + break; + } + default: break; } |
