Commit 7a88cc84 by Tom de Vries Committed by Tom de Vries

Handle 3-arg phi in copy_bb_and_scalar_dependences

2016-05-31  Tom de Vries  <tom@codesourcery.com>

	PR tree-optimization/69068
	* graphite-isl-ast-to-gimple.c (copy_bb_and_scalar_dependences): Handle
	phis with more than two args.

	* gcc.dg/graphite/pr69068.c: New test.

From-SVN: r236907
parent cc10916f
2016-05-31 Tom de Vries <tom@codesourcery.com>
PR tree-optimization/69068
* graphite-isl-ast-to-gimple.c (copy_bb_and_scalar_dependences): Handle
phis with more than two args.
2016-05-30 Andreas Tobler <andreast@gcc.gnu.org> 2016-05-30 Andreas Tobler <andreast@gcc.gnu.org>
* config.gcc: Move hard float support for arm*hf*-*-freebsd* into * config.gcc: Move hard float support for arm*hf*-*-freebsd* into
......
...@@ -1075,9 +1075,7 @@ bb_contains_loop_close_phi_nodes (basic_block bb) ...@@ -1075,9 +1075,7 @@ bb_contains_loop_close_phi_nodes (basic_block bb)
static bool static bool
bb_contains_loop_phi_nodes (basic_block bb) bb_contains_loop_phi_nodes (basic_block bb)
{ {
gcc_assert (EDGE_COUNT (bb->preds) <= 2); if (EDGE_COUNT (bb->preds) != 2)
if (bb->preds->length () == 1)
return false; return false;
unsigned depth = loop_depth (bb->loop_father); unsigned depth = loop_depth (bb->loop_father);
...@@ -2480,13 +2478,14 @@ copy_cond_phi_nodes (basic_block bb, basic_block new_bb, vec<tree> iv_map) ...@@ -2480,13 +2478,14 @@ copy_cond_phi_nodes (basic_block bb, basic_block new_bb, vec<tree> iv_map)
gcc_assert (!bb_contains_loop_close_phi_nodes (bb)); gcc_assert (!bb_contains_loop_close_phi_nodes (bb));
/* TODO: Handle cond phi nodes with more than 2 predecessors. */
if (EDGE_COUNT (bb->preds) != 2)
return false;
if (dump_file) if (dump_file)
fprintf (dump_file, "[codegen] copying cond phi nodes in bb_%d.\n", fprintf (dump_file, "[codegen] copying cond phi nodes in bb_%d.\n",
new_bb->index); new_bb->index);
/* Cond phi nodes should have exactly two arguments. */
gcc_assert (2 == EDGE_COUNT (bb->preds));
for (gphi_iterator psi = gsi_start_phis (bb); !gsi_end_p (psi); for (gphi_iterator psi = gsi_start_phis (bb); !gsi_end_p (psi);
gsi_next (&psi)) gsi_next (&psi))
{ {
......
2016-05-31 Tom de Vries <tom@codesourcery.com>
PR tree-optimization/69068
* gcc.dg/graphite/pr69068.c: New test.
2016-05-27 Martin Sebor <msebor@redhat.com> 2016-05-27 Martin Sebor <msebor@redhat.com>
PR c++/71306 PR c++/71306
......
/* { dg-do compile } */
/* { dg-options "-O1 -fgraphite-identity" } */
int qo;
int zh[2];
void
td (void)
{
int ly, en;
for (ly = 0; ly < 2; ++ly)
for (en = 0; en < 2; ++en)
zh[en] = ((qo == 0) || (((qo * 2) != 0))) ? 1 : -1;
}
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