if-to-switch: fix also virtual phis

gcc/ChangeLog:

	PR tree-optimization/98455
	* gimple-if-to-switch.cc (condition_info::record_phi_mapping):
	Record also virtual PHIs.
	(pass_if_to_switch::execute): Return TODO_cleanup_cfg only
	conditionally.

gcc/testsuite/ChangeLog:

	PR tree-optimization/98455
	* gcc.dg/tree-ssa/pr98455.c: New test.
This commit is contained in:
Martin Liska 2021-01-12 13:40:44 +01:00
parent 0db5f48848
commit 7875e8dc83
2 changed files with 23 additions and 7 deletions

View File

@ -91,11 +91,8 @@ condition_info::record_phi_mapping (edge e, mapping_vec *vec)
gsi_next (&gsi))
{
gphi *phi = gsi.phi ();
if (!virtual_operand_p (gimple_phi_result (phi)))
{
tree arg = PHI_ARG_DEF_FROM_EDGE (phi, e);
vec->safe_push (std::make_pair (phi, arg));
}
tree arg = PHI_ARG_DEF_FROM_EDGE (phi, e);
vec->safe_push (std::make_pair (phi, arg));
}
}
@ -470,7 +467,7 @@ const pass_data pass_data_if_to_switch =
0, /* properties_provided */
0, /* properties_destroyed */
0, /* todo_flags_start */
TODO_cleanup_cfg | TODO_update_ssa /* todo_flags_finish */
TODO_update_ssa /* todo_flags_finish */
};
class pass_if_to_switch : public gimple_opt_pass
@ -575,7 +572,7 @@ pass_if_to_switch::execute (function *fun)
if (!all_candidates.is_empty ())
{
free_dominance_info (CDI_DOMINATORS);
mark_virtual_operands_for_renaming (fun);
return TODO_cleanup_cfg;
}
return 0;

View File

@ -0,0 +1,19 @@
/* PR tree-optimization/98455 */
/* { dg-do compile } */
/* { dg-options "-O1 -fno-tree-dce --param case-values-threshold=1" } */
void
n4 (int io, int vb)
{
double uc[2] = { 1.0, 2.0, };
if (io == 0)
uc[0] = 0.0;
for (;;)
if (io == 0)
if (vb == 0)
uc[0] = uc[1];
else if (vb == 1)
uc[1] = 0.0;
}