diff options
author | Richard Guenther <rguenther@suse.de> | 2009-09-24 13:47:26 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2009-09-24 13:47:26 +0000 |
commit | 824ff0cd22d948a72853f6aad98b9cd5a832a2a5 (patch) | |
tree | d59cda303be54e77c4ec9ffea649d8ef8215be09 /gcc | |
parent | 3f13dd777c1c0f76000172eb4426ccea1fd4d79d (diff) | |
download | gcc-824ff0cd22d948a72853f6aad98b9cd5a832a2a5.zip gcc-824ff0cd22d948a72853f6aad98b9cd5a832a2a5.tar.gz gcc-824ff0cd22d948a72853f6aad98b9cd5a832a2a5.tar.bz2 |
re PR middle-end/36143 (FAIL: g++.dg/tree-ssa/pr19637.C)
2009-09-24 Richard Guenther <rguenther@suse.de>
PR tree-optimization/36143
PR tree-optimization/38747
* tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Only
create VIEW_CONVERT_EXPRs for TBAA compatible accesses.
* gcc.dg/tree-ssa/fre-vce-1.c: XFAIL.
* gcc.dg/tree-ssa/forwprop-6.c: Likewise.
* g++.dg/torture/pr38747.C: New testcase.
* g++.dg/tree-ssa/pr19637.C: Un-XFAIL.
From-SVN: r152122
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 9 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/torture/pr38747.C | 19 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/tree-ssa/pr19637.C | 3 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/tree-ssa/forwprop-6.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/tree-ssa/fre-vce-1.c | 5 | ||||
-rw-r--r-- | gcc/tree-ssa-forwprop.c | 4 |
7 files changed, 49 insertions, 7 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f2d49b6..000521b 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2009-09-24 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/36143 + PR tree-optimization/38747 + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Only + create VIEW_CONVERT_EXPRs for TBAA compatible accesses. + 2009-09-24 Jakub Jelinek <jakub@redhat.com> PR bootstrap/41457 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5b6eee2..bf75ec2 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,12 @@ +2009-09-24 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/36143 + PR tree-optimization/38747 + * gcc.dg/tree-ssa/fre-vce-1.c: XFAIL. + * gcc.dg/tree-ssa/forwprop-6.c: Likewise. + * g++.dg/torture/pr38747.C: New testcase. + * g++.dg/tree-ssa/pr19637.C: Un-XFAIL. + 2009-09-24 Eric Botcazou <ebotcazou@adacore.com> * gnat.dg/nested_proc.adb: New test. diff --git a/gcc/testsuite/g++.dg/torture/pr38747.C b/gcc/testsuite/g++.dg/torture/pr38747.C new file mode 100644 index 0000000..0f18a2f --- /dev/null +++ b/gcc/testsuite/g++.dg/torture/pr38747.C @@ -0,0 +1,19 @@ +/* { dg-do run } */ + +extern "C" void abort (void); +inline void *operator new (__SIZE_TYPE__, void *__p) throw () { return __p; } + +int __attribute__((noinline)) +foo(void) +{ + float f = 0; + int *i = new (&f) int (1); + return *(int *)&f; +} + +int main() +{ + if (foo() != 1) + abort (); + return 0; +} diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr19637.C b/gcc/testsuite/g++.dg/tree-ssa/pr19637.C index cf70e40..2d1dcceb 100644 --- a/gcc/testsuite/g++.dg/tree-ssa/pr19637.C +++ b/gcc/testsuite/g++.dg/tree-ssa/pr19637.C @@ -29,6 +29,5 @@ int foo_void_offset(void) return reinterpret_cast<Foo *>(&i[0])->i[0]; } -/* Regarding the xfail, see PR36143. */ -/* { dg-final { scan-tree-dump-times "return 1;" 3 "dom1" { xfail *-*-* } } } */ +/* { dg-final { scan-tree-dump-times "return 1;" 3 "dom1" } } */ /* { dg-final { cleanup-tree-dump "dom1" } } */ diff --git a/gcc/testsuite/gcc.dg/tree-ssa/forwprop-6.c b/gcc/testsuite/gcc.dg/tree-ssa/forwprop-6.c index 987f8a3..54e5109 100644 --- a/gcc/testsuite/gcc.dg/tree-ssa/forwprop-6.c +++ b/gcc/testsuite/gcc.dg/tree-ssa/forwprop-6.c @@ -17,6 +17,11 @@ void f(void) } /* We should be able to convert the cast to a VCE in forwprop1, - even if there is an aliasing violation. */ -/* { dg-final { scan-tree-dump-times "VIEW_CONVERT_EXPR" 1 "forwprop1"} } */ + even if there is an aliasing violation. + ??? While this would be useful and nice to our users in this + particular situation before doing this transformation we have to + assure that a is killed by a dominating store via type float for + it to be valid. Then we might as well handle the situation by + value-numbering, removing the load alltogether. */ +/* { dg-final { scan-tree-dump-times "VIEW_CONVERT_EXPR" 1 "forwprop1" { xfail *-*-* } } } */ /* { dg-final { cleanup-tree-dump "forwprop1" } } */ diff --git a/gcc/testsuite/gcc.dg/tree-ssa/fre-vce-1.c b/gcc/testsuite/gcc.dg/tree-ssa/fre-vce-1.c index 2bc6da3..340f568 100644 --- a/gcc/testsuite/gcc.dg/tree-ssa/fre-vce-1.c +++ b/gcc/testsuite/gcc.dg/tree-ssa/fre-vce-1.c @@ -32,6 +32,7 @@ void a2 (struct s1 sv, int i) } /* { dg-final { scan-tree-dump-times "sv_\[0-9\]\\\(D\\\)->i" 2 "fre" } } */ -/* { dg-final { scan-tree-dump-times "sv.i" 2 "fre" } } */ - +/* We can't value-number *(float *)&sv.i as VIEW_CONVERT_EXPR of the + value of sv.i. */ +/* { dg-final { scan-tree-dump-times "sv.i" 2 "fre" { xfail *-*-* } } } */ /* { dg-final { cleanup-tree-dump "fre" } } */ diff --git a/gcc/tree-ssa-forwprop.c b/gcc/tree-ssa-forwprop.c index 5aec334..87795a2 100644 --- a/gcc/tree-ssa-forwprop.c +++ b/gcc/tree-ssa-forwprop.c @@ -831,7 +831,9 @@ forward_propagate_addr_expr_1 (tree name, tree def_rhs, && !TYPE_VOLATILE (TREE_TYPE (rhs)) && !TYPE_VOLATILE (TREE_TYPE (TREE_OPERAND (def_rhs, 0))) && operand_equal_p (TYPE_SIZE (TREE_TYPE (rhs)), - TYPE_SIZE (TREE_TYPE (TREE_OPERAND (def_rhs, 0))), 0)) + TYPE_SIZE (TREE_TYPE (TREE_OPERAND (def_rhs, 0))), 0) + /* Make sure we only do TBAA compatible replacements. */ + && get_alias_set (TREE_OPERAND (def_rhs, 0)) == get_alias_set (rhs)) { tree def_rhs_base, new_rhs = unshare_expr (TREE_OPERAND (def_rhs, 0)); new_rhs = fold_build1 (VIEW_CONVERT_EXPR, TREE_TYPE (rhs), new_rhs); |