X-Git-Url: http://git.sourceforge.jp/view?a=blobdiff_plain;f=gcc%2Ftree-scalar-evolution.h;h=e09e19ae5f59d742be41d2e31c3d9ba6955ff12e;hb=17899c24b6ceb3ad7f0c833397a86008e3776810;hp=e8d2eb453fbd9065d20e2f13b984fbab159df63e;hpb=c2c3fd2498db32a99024a8de72f2d8e01b630b56;p=pf3gnuchains%2Fgcc-fork.git diff --git a/gcc/tree-scalar-evolution.h b/gcc/tree-scalar-evolution.h index e8d2eb453fb..e09e19ae5f5 100644 --- a/gcc/tree-scalar-evolution.h +++ b/gcc/tree-scalar-evolution.h @@ -1,12 +1,12 @@ /* Scalar evolution detector. - Copyright (C) 2003, 2004 Free Software Foundation, Inc. + Copyright (C) 2003, 2004, 2005, 2007, 2008, 2009 Free Software Foundation, Inc. Contributed by Sebastian Pop This file is part of GCC. GCC is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free -Software Foundation; either version 2, or (at your option) any later +Software Foundation; either version 3, or (at your option) any later version. GCC is distributed in the hope that it will be useful, but WITHOUT ANY @@ -15,24 +15,56 @@ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License -along with GCC; see the file COPYING. If not, write to the Free -Software Foundation, 59 Temple Place - Suite 330, Boston, MA -02111-1307, USA. */ +along with GCC; see the file COPYING3. If not see +. */ #ifndef GCC_TREE_SCALAR_EVOLUTION_H #define GCC_TREE_SCALAR_EVOLUTION_H -extern tree number_of_iterations_in_loop (struct loop *); -extern tree get_loop_exit_condition (struct loop *); +extern tree number_of_latch_executions (struct loop *); +extern tree number_of_exit_cond_executions (struct loop *); +extern gimple get_loop_exit_condition (const struct loop *); -extern void scev_initialize (struct loops *loops); +extern void scev_initialize (void); extern void scev_reset (void); +extern void scev_reset_htab (void); extern void scev_finalize (void); extern tree analyze_scalar_evolution (struct loop *, tree); -extern tree instantiate_parameters (struct loop *, tree); -extern void eliminate_redundant_checks (void); +extern tree instantiate_scev (basic_block, struct loop *, tree); +extern tree resolve_mixers (struct loop *, tree); extern void gather_stats_on_scev_database (void); extern void scev_analysis (void); -extern bool simple_iv (struct loop *, tree, tree, tree *, tree *); +extern unsigned int scev_const_prop (void); +extern bool expression_expensive_p (tree); +extern bool simple_iv (struct loop *, struct loop *, tree, affine_iv *, bool); +extern tree compute_overall_effect_of_inner_loop (struct loop *, tree); + +/* Returns the basic block preceding LOOP or ENTRY_BLOCK_PTR when the + loop is function's body. */ + +static inline basic_block +block_before_loop (loop_p loop) +{ + edge preheader = loop_preheader_edge (loop); + return (preheader ? preheader->src : ENTRY_BLOCK_PTR); +} + +/* Analyze all the parameters of the chrec that were left under a + symbolic form. LOOP is the loop in which symbolic names have to + be analyzed and instantiated. */ + +static inline tree +instantiate_parameters (struct loop *loop, tree chrec) +{ + return instantiate_scev (block_before_loop (loop), loop, chrec); +} + +/* Returns the loop of the polynomial chrec CHREC. */ + +static inline struct loop * +get_chrec_loop (const_tree chrec) +{ + return get_loop (CHREC_VARIABLE (chrec)); +} #endif /* GCC_TREE_SCALAR_EVOLUTION_H */