Commit 0682ed3e by Richard Biener Committed by Richard Biener

tree-vect-stmts.c (vectorizable_load): When vectorizing an invariant load do not…

tree-vect-stmts.c (vectorizable_load): When vectorizing an invariant load do not generate a vector load from the...

2013-01-02  Richard Biener  <rguenther@suse.de>

	* tree-vect-stmts.c (vectorizable_load): When vectorizing an
	invariant load do not generate a vector load from the scalar
	location.

From-SVN: r194806
parent 0f9f12f6
2013-01-02 Richard Biener <rguenther@suse.de> 2013-01-02 Richard Biener <rguenther@suse.de>
* tree-vect-stmts.c (vectorizable_load): When vectorizing an
invariant load do not generate a vector load from the scalar
location.
2013-01-02 Richard Biener <rguenther@suse.de>
PR bootstrap/55784 PR bootstrap/55784
* configure.ac: Add $GMPINC to CFLAGS/CXXFLAGS. * configure.ac: Add $GMPINC to CFLAGS/CXXFLAGS.
* configure: Regenerate. * configure: Regenerate.
...@@ -4988,6 +4988,19 @@ vectorizable_load (gimple stmt, gimple_stmt_iterator *gsi, gimple *vec_stmt, ...@@ -4988,6 +4988,19 @@ vectorizable_load (gimple stmt, gimple_stmt_iterator *gsi, gimple *vec_stmt,
/* Record the mapping between SSA_NAMEs and statements. */ /* Record the mapping between SSA_NAMEs and statements. */
vect_record_grouped_load_vectors (stmt, dr_chain); vect_record_grouped_load_vectors (stmt, dr_chain);
} }
/* Handle invariant-load. */
else if (inv_p && !bb_vinfo)
{
gimple_stmt_iterator gsi2 = *gsi;
gcc_assert (!grouped_load && !slp_perm);
gsi_next (&gsi2);
new_temp = vect_init_vector (stmt, scalar_dest,
vectype, &gsi2);
new_stmt = SSA_NAME_DEF_STMT (new_temp);
/* Store vector loads in the corresponding SLP_NODE. */
if (slp)
SLP_TREE_VEC_STMTS (slp_node).quick_push (new_stmt);
}
else else
{ {
for (i = 0; i < vec_num; i++) for (i = 0; i < vec_num; i++)
...@@ -5135,17 +5148,6 @@ vectorizable_load (gimple stmt, gimple_stmt_iterator *gsi, gimple *vec_stmt, ...@@ -5135,17 +5148,6 @@ vectorizable_load (gimple stmt, gimple_stmt_iterator *gsi, gimple *vec_stmt,
} }
} }
/* 4. Handle invariant-load. */
if (inv_p && !bb_vinfo)
{
gimple_stmt_iterator gsi2 = *gsi;
gcc_assert (!grouped_load);
gsi_next (&gsi2);
new_temp = vect_init_vector (stmt, scalar_dest,
vectype, &gsi2);
new_stmt = SSA_NAME_DEF_STMT (new_temp);
}
if (negative) if (negative)
{ {
tree perm_mask = perm_mask_for_reverse (vectype); tree perm_mask = perm_mask_for_reverse (vectype);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment