aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-vect-stmts.c
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2012-08-23 11:17:29 +0000
committerRichard Guenther <rguenther@suse.de>2012-08-23 11:17:29 +0000
commitd60ce578e731eb61d7376acb3716d37d2ec05794 (patch)
treec7fd63e8223e3d722d3b671216478508446c9c30 /gcc/tree-vect-stmts.c
parent59e18fcc0bbec46430d99ecdcfd1a27905dabdc4 (diff)
2012-08-23 Richard Guenther <rguenther@suse.de>
* tree-vect-stmts.c (vect_finish_stmt_generation): Update virtual SSA form. git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@190620 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-vect-stmts.c')
-rw-r--r--gcc/tree-vect-stmts.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/gcc/tree-vect-stmts.c b/gcc/tree-vect-stmts.c
index 706b0bc6e93..ab4a26c2b28 100644
--- a/gcc/tree-vect-stmts.c
+++ b/gcc/tree-vect-stmts.c
@@ -1600,6 +1600,32 @@ vect_finish_stmt_generation (gimple stmt, gimple vec_stmt,
gcc_assert (gimple_code (stmt) != GIMPLE_LABEL);
+ if (!gsi_end_p (*gsi)
+ && gimple_has_mem_ops (vec_stmt))
+ {
+ gimple at_stmt = gsi_stmt (*gsi);
+ tree vuse = gimple_vuse (at_stmt);
+ if (vuse && TREE_CODE (vuse) == SSA_NAME)
+ {
+ tree vdef = gimple_vdef (at_stmt);
+ gimple_set_vuse (vec_stmt, gimple_vuse (at_stmt));
+ /* If we have an SSA vuse and insert a store, update virtual
+ SSA form to avoid triggering the renamer. Do so only
+ if we can easily see all uses - which is what almost always
+ happens with the way vectorized stmts are inserted. */
+ if ((vdef && TREE_CODE (vdef) == SSA_NAME)
+ && ((is_gimple_assign (vec_stmt)
+ && !is_gimple_reg (gimple_assign_lhs (vec_stmt)))
+ || (is_gimple_call (vec_stmt)
+ && !(gimple_call_flags (vec_stmt)
+ & (ECF_CONST|ECF_PURE|ECF_NOVOPS)))))
+ {
+ tree new_vdef = copy_ssa_name (vuse, vec_stmt);
+ gimple_set_vdef (vec_stmt, new_vdef);
+ SET_USE (gimple_vuse_op (at_stmt), new_vdef);
+ }
+ }
+ }
gsi_insert_before (gsi, vec_stmt, GSI_SAME_STMT);
set_vinfo_for_stmt (vec_stmt, new_stmt_vec_info (vec_stmt, loop_vinfo,