X-Git-Url: http://git.sourceforge.jp/view?p=pf3gnuchains%2Fgcc-fork.git;a=blobdiff_plain;f=gcc%2Ftree-scalar-evolution.h;h=06324972ca541412092eb5d508a54bfa990e22b7;hp=464fe8fc519cc23fc2f4de6d073c1fe936b17eee;hb=43fb76c1c6278d313ae7a273e94951dcc29f1963;hpb=0c3c2e56fcc261364645b2697ef79dd804747376 diff --git a/gcc/tree-scalar-evolution.h b/gcc/tree-scalar-evolution.h index 464fe8fc519..06324972ca5 100644 --- a/gcc/tree-scalar-evolution.h +++ b/gcc/tree-scalar-evolution.h @@ -1,12 +1,12 @@ /* Scalar evolution detector. - Copyright (C) 2003, 2004, 2005 Free Software Foundation, Inc. + Copyright (C) 2003, 2004, 2005, 2007, 2008 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,32 +15,53 @@ 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, 51 Franklin Street, Fifth Floor, Boston, MA -02110-1301, 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_latch_executions (struct loop *); extern tree number_of_exit_cond_executions (struct loop *); -extern tree get_loop_exit_condition (struct loop *); +extern gimple get_loop_exit_condition (const struct loop *); extern void scev_initialize (void); extern void scev_reset (void); extern void scev_finalize (void); extern tree analyze_scalar_evolution (struct loop *, tree); -extern tree instantiate_parameters (struct loop *, tree); +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); unsigned int scev_const_prop (void); -extern bool simple_iv (struct loop *, tree, tree, affine_iv *, bool); +bool expression_expensive_p (tree); +extern bool simple_iv (struct loop *, struct loop *, tree, affine_iv *, bool); + +/* 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 (tree chrec) +get_chrec_loop (const_tree chrec) { return get_loop (CHREC_VARIABLE (chrec)); }