From: hubicka Date: Tue, 30 Oct 2012 16:50:05 +0000 (+0000) Subject: * tree-ssa-loop-niter.c (number_of_iterations_exit): New parameter X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=cbe26b293dd751e67e598be62cf5df40e1268992;p=thirdparty%2Fgcc.git * tree-ssa-loop-niter.c (number_of_iterations_exit): New parameter EVERY_ITERATION with implicit value of true. (record_estimate): Check dominance relationship of the basic block we are estimating on instead of relying on UPPER to be false. (struct ilb_data): Drop RELIABLE. (idx_infer_loop_bounds): Update. (infer_loop_bounds_from_ref): Drop parameter RELIABLE. (infer_loop_bounds_from_array): Drop parameter RELIABLE. (infer_loop_bounds_from_undefined): Update comments and handling of RELIABLE. (estimate_numbers_of_iterations_loop): Record all bounds. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@192990 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/tree-flow.h b/gcc/tree-flow.h index 15c14654b220..0d9edad6f750 100644 --- a/gcc/tree-flow.h +++ b/gcc/tree-flow.h @@ -627,7 +627,8 @@ bool parallelize_loops (void); bool loop_only_exit_p (const struct loop *, const_edge); bool number_of_iterations_exit (struct loop *, edge, - struct tree_niter_desc *niter, bool); + struct tree_niter_desc *niter, bool, + bool every_iteration = true); tree find_loop_niter (struct loop *, edge *); tree loop_niter_by_eval (struct loop *, edge); tree find_loop_niter_by_eval (struct loop *, edge *);