diff options
author | Doug Gilmore <doug.gilmore@imgtec.com> | 2016-10-04 15:28:23 +0000 |
---|---|---|
committer | Matthew Fortune <mpf@gcc.gnu.org> | 2016-10-04 15:28:23 +0000 |
commit | fe8b1e839ca91a61440288049a868944346eef4b (patch) | |
tree | e158821b60fe355cbe259f1e71d6bbcd67a4e995 /gcc/tree-ssa-loop-prefetch.c | |
parent | 9f06db14fae821a5f34196eab15df0e991c8061a (diff) | |
download | gcc-fe8b1e839ca91a61440288049a868944346eef4b.zip gcc-fe8b1e839ca91a61440288049a868944346eef4b.tar.gz gcc-fe8b1e839ca91a61440288049a868944346eef4b.tar.bz2 |
re PR tree-optimization/77808 (ICE in duplicate_ssa_name_ptr_info, at tree-ssanames.c:630 starting with r240439)
Fix PR tree-optimization/77808
gcc/
PR tree-optimization/77808
* tree-ssa-loop-prefetch.c (issue_prefetch_ref): Check base_addr
and addr are different before copying points-to information.
gcc/testsuite/
PR tree-optimization/77808
* gcc.dg/tree-ssa/pr77808.c: New testcase.
From-SVN: r240749
Diffstat (limited to 'gcc/tree-ssa-loop-prefetch.c')
-rw-r--r-- | gcc/tree-ssa-loop-prefetch.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/tree-ssa-loop-prefetch.c b/gcc/tree-ssa-loop-prefetch.c index 056815d..43ee85a 100644 --- a/gcc/tree-ssa-loop-prefetch.c +++ b/gcc/tree-ssa-loop-prefetch.c @@ -1162,7 +1162,8 @@ issue_prefetch_ref (struct mem_ref *ref, unsigned unroll_factor, unsigned ahead) NULL, true, GSI_SAME_STMT); } - if (TREE_CODE (addr_base) == SSA_NAME + if (addr_base != addr + && TREE_CODE (addr_base) == SSA_NAME && TREE_CODE (addr) == SSA_NAME) { duplicate_ssa_name_ptr_info (addr, SSA_NAME_PTR_INFO (addr_base)); |