+2015-03-18 Richard Biener <rguenther@suse.de>
+
+ * tree-ssa-loop-ch.c (pass_data_ch): Remove TODO_cleanup_cfg.
+ (pass_ch::execute): Cleanup the CFG only if we did sth.
+ * tree-vect-generic.c (pass_data_lower_vector): Remove TODO_cleanup_cfg.
+
2015-03-18 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
* expmed.c (synth_mult): Use std::swap instead of manually
0, /* properties_provided */
0, /* properties_destroyed */
0, /* todo_flags_start */
- TODO_cleanup_cfg, /* todo_flags_finish */
+ 0, /* todo_flags_finish */
};
class pass_ch : public gimple_opt_pass
basic_block *bbs, *copied_bbs;
unsigned n_bbs;
unsigned bbs_size;
+ bool changed = false;
loop_optimizer_init (LOOPS_HAVE_PREHEADERS
| LOOPS_HAVE_SIMPLE_LATCHES);
are not now, since there was the loop exit condition. */
split_edge (loop_preheader_edge (loop));
split_edge (loop_latch_edge (loop));
+
+ changed = true;
}
update_ssa (TODO_update_ssa);
free (copied_bbs);
loop_optimizer_finalize ();
- return 0;
+ return changed ? TODO_cleanup_cfg : 0;
}
} // anon namespace
PROP_gimple_lvec, /* properties_provided */
0, /* properties_destroyed */
0, /* todo_flags_start */
- ( TODO_update_ssa
- | TODO_cleanup_cfg ), /* todo_flags_finish */
+ TODO_update_ssa, /* todo_flags_finish */
};
class pass_lower_vector : public gimple_opt_pass