+2016-06-03 Alan Hayward <alan.hayward@arm.com>
+
+ * tree-vect-stmts.c (vect_stmt_relevant_p): Do not vectorize non live
+ relevant stmts which are simple and invariant.
+ * tree-vect-loop.c (vectorizable_live_operation): Check relevance
+ instead of simple and invariant
+
2016-06-03 Alan Hayward <alan.hayward@arm.com>
* tree-vect-loop.c (vect_analyze_loop_operations): Allow live stmts.
+2016-06-03 Alan Hayward <alan.hayward@arm.com>
+
+ * gcc.dg/vect/vect-live-slp-5.c: Remove dg check.
+
2016-06-03 Alan Hayward <alan.hayward@arm.com>
* gcc.dg/tree-ssa/pr64183.c: Ensure test does not vectorize.
}
/* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */
-/* { dg-final { scan-tree-dump-times "vec_stmt_relevant_p: stmt live but not relevant" 1 "vect" } } */
-/* { dg-final { scan-tree-dump "statement is simple and uses invariant. Leaving in place" "vect" } } */
+/* { dg-final { scan-tree-dump-not "vec_stmt_relevant_p: stmt live but not relevant" "vect" } } */
if (nested_in_vect_loop_p (loop, stmt))
return false;
- /* If STMT is a simple assignment and its inputs are invariant, then it can
- remain in place, unvectorized. The original last scalar value that it
- computes will be used. */
- if (is_simple_and_all_uses_invariant (stmt, loop_vinfo))
+ /* If STMT is not relevant and it is a simple assignment and its inputs are
+ invariant then it can remain in place, unvectorized. The original last
+ scalar value that it computes will be used. */
+ if (!STMT_VINFO_RELEVANT_P (stmt_info))
{
+ gcc_assert (is_simple_and_all_uses_invariant (stmt, loop_vinfo));
if (dump_enabled_p ())
dump_printf_loc (MSG_NOTE, vect_location,
"statement is simple and uses invariant. Leaving in "
}
}
- if (*live_p && *relevant == vect_unused_in_scope)
+ if (*live_p && *relevant == vect_unused_in_scope
+ && !is_simple_and_all_uses_invariant (stmt, loop_vinfo))
{
if (dump_enabled_p ())
dump_printf_loc (MSG_NOTE, vect_location,