Commit b010d601 by Jakub Jelinek Committed by Jakub Jelinek

tree-vect-loop.c (vect_is_slp_reduction): Don't set use_stmt twice.

	* tree-vect-loop.c (vect_is_slp_reduction): Don't set
	use_stmt twice.
	(get_initial_def_for_induction, vectorizable_induction): Ignore
	debug stmts when looking for exit_phi.
	(vectorizable_live_operation): Fix up condition.

	* gcc.c-torture/compile/20140213.c: New test.

From-SVN: r207778
parent f2dafb91
2014-02-14 Jakub Jelinek <jakub@redhat.com>
* tree-vect-loop.c (vect_is_slp_reduction): Don't set
use_stmt twice.
(get_initial_def_for_induction, vectorizable_induction): Ignore
debug stmts when looking for exit_phi.
(vectorizable_live_operation): Fix up condition.
2014-02-14 Chung-Ju Wu <jasonwucj@gmail.com> 2014-02-14 Chung-Ju Wu <jasonwucj@gmail.com>
* config/nds32/nds32.c (nds32_asm_function_prologue): Do not use * config/nds32/nds32.c (nds32_asm_function_prologue): Do not use
......
2014-02-14 Jakub Jelinek <jakub@redhat.com>
* gcc.c-torture/compile/20140213.c: New test.
2014-02-13 Jakub Jelinek <jakub@redhat.com> 2014-02-13 Jakub Jelinek <jakub@redhat.com>
PR target/43546 PR target/43546
......
static unsigned short
foo (unsigned char *x, int y)
{
unsigned short r = 0;
int i;
for (i = 0; i < y; i++)
r += x[i];
return r;
}
int baz (int, unsigned short);
void
bar (unsigned char *x, unsigned char *y)
{
int i;
unsigned short key = foo (x, 0x10000);
baz (0, 0);
for (i = 0; i < 0x80000; i++)
y[i] = x[baz (i, key)];
}
...@@ -1968,10 +1968,8 @@ vect_is_slp_reduction (loop_vec_info loop_info, gimple phi, gimple first_stmt) ...@@ -1968,10 +1968,8 @@ vect_is_slp_reduction (loop_vec_info loop_info, gimple phi, gimple first_stmt)
FOR_EACH_IMM_USE_FAST (use_p, imm_iter, lhs) FOR_EACH_IMM_USE_FAST (use_p, imm_iter, lhs)
{ {
gimple use_stmt = USE_STMT (use_p); gimple use_stmt = USE_STMT (use_p);
if (is_gimple_debug (use_stmt)) if (is_gimple_debug (use_stmt))
continue; continue;
use_stmt = USE_STMT (use_p);
/* Check if we got back to the reduction phi. */ /* Check if we got back to the reduction phi. */
if (use_stmt == phi) if (use_stmt == phi)
...@@ -3507,9 +3505,13 @@ get_initial_def_for_induction (gimple iv_phi) ...@@ -3507,9 +3505,13 @@ get_initial_def_for_induction (gimple iv_phi)
exit_phi = NULL; exit_phi = NULL;
FOR_EACH_IMM_USE_FAST (use_p, imm_iter, loop_arg) FOR_EACH_IMM_USE_FAST (use_p, imm_iter, loop_arg)
{ {
if (!flow_bb_inside_loop_p (iv_loop, gimple_bb (USE_STMT (use_p)))) gimple use_stmt = USE_STMT (use_p);
if (is_gimple_debug (use_stmt))
continue;
if (!flow_bb_inside_loop_p (iv_loop, gimple_bb (use_stmt)))
{ {
exit_phi = USE_STMT (use_p); exit_phi = use_stmt;
break; break;
} }
} }
...@@ -5413,10 +5415,13 @@ vectorizable_induction (gimple phi, gimple_stmt_iterator *gsi ATTRIBUTE_UNUSED, ...@@ -5413,10 +5415,13 @@ vectorizable_induction (gimple phi, gimple_stmt_iterator *gsi ATTRIBUTE_UNUSED,
loop_arg = PHI_ARG_DEF_FROM_EDGE (phi, latch_e); loop_arg = PHI_ARG_DEF_FROM_EDGE (phi, latch_e);
FOR_EACH_IMM_USE_FAST (use_p, imm_iter, loop_arg) FOR_EACH_IMM_USE_FAST (use_p, imm_iter, loop_arg)
{ {
if (!flow_bb_inside_loop_p (loop->inner, gimple use_stmt = USE_STMT (use_p);
gimple_bb (USE_STMT (use_p)))) if (is_gimple_debug (use_stmt))
continue;
if (!flow_bb_inside_loop_p (loop->inner, gimple_bb (use_stmt)))
{ {
exit_phi = USE_STMT (use_p); exit_phi = use_stmt;
break; break;
} }
} }
...@@ -5514,7 +5519,7 @@ vectorizable_live_operation (gimple stmt, ...@@ -5514,7 +5519,7 @@ vectorizable_live_operation (gimple stmt,
{ {
gimple use_stmt = USE_STMT (use_p); gimple use_stmt = USE_STMT (use_p);
if (gimple_code (use_stmt) == GIMPLE_PHI if (gimple_code (use_stmt) == GIMPLE_PHI
|| gimple_bb (use_stmt) == merge_bb) && gimple_bb (use_stmt) == merge_bb)
{ {
if (vec_stmt) if (vec_stmt)
{ {
......
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