X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firflag.h;h=fd030fa17dabb26ff9003c89683345bff7a4945e;hb=cb91bddc9cacdab7c28e4336847bd3dc248aa549;hp=09610c29673cbd08ffc3d4eabb66b24f66a2501a;hpb=a7374702e9ec0bc04af3ffc08aa8fd4a94c5b45f;p=libfirm diff --git a/ir/ir/irflag.h b/ir/ir/irflag.h index 09610c296..fd030fa17 100644 --- a/ir/ir/irflag.h +++ b/ir/ir/irflag.h @@ -3,7 +3,7 @@ * File name: ir/ir/irflag.h * Purpose: Flags to control optimizations. * Author: Christian Schaefer, Goetz Lindenmaier - * Modified by: + * Modified by: Michael Beck * Created: * CVS-ID: $Id$ * Copyright: (c) 1999-2003 Universität Karlsruhe @@ -13,9 +13,22 @@ /** * @file irflag.h * - * Optimization flags. + * Flags to customize the behaviour of libfirm. * * @author Christian Schaefer + * + * There are the following groups of flags: + * 1. Optimization flags. + * a) There is a flag, 'optimize' to turn on/off all optimizations. + * b) There are flags for each individual optimization. Some flags turns + * transformations in several algorithms on/off. + * 2. Normalization flags. + * These flags steer transformations of the ir that improve it, as removing + * dump Phi nodes (one predecessor, all preds are equal ...), Ids, Tuples ... + * 3. Verbosity flags. + * a) Flags to steer the level of the information. + * b) Flags to steer in which phase information should be dumped. + * */ #ifndef _IRFLAG_H_ @@ -33,7 +46,17 @@ typedef unsigned optimization_state_t; * Default: optimize == 1. */ void set_optimize (int value); -int get_optimize(void); +int get_optimize(void); + +/** This function enables/disables output of information about phases and + * controls the verbosity level. + * + * 0: no output at all. + * 1: very short output + * >>1: very verbose output. + */ +void set_firm_verbosity (int value); +int get_firm_verbosity (void); /** Enables/Disables constant folding optimization. * @@ -47,6 +70,14 @@ int get_optimize(void); */ void set_opt_constant_folding (int value); +/** Enables/Disables removal of redundant Loads and Stores. + * + * - Remove Store that overwrites a just stored value (WAW). + * - Remove Store if it stores a value just loaded (WAR with the same value). + * - Remove Load that loads a value just saved (RAW with the same value). + */ +void set_opt_redundant_LoadStore(int value); + /** Enables/Disables constant subexpression elimination. * * If opt_cse == 1 perform constant subexpression elimination. @@ -59,13 +90,29 @@ void set_opt_cse (int value); * If opt_global_cse == 1 and opt_cse == 1 perform intra procedure * constant subexpression elimination for floating nodes. Intra * procedure cse gets the graph into state "floating". It is necessary - * to run pre/code motion to get the graph back into state "pinned". + * to run pre/code motion to get the graph back into state "op_pin_state_pinned". * right after a call to local_optimize with global cse turned on. * Default: opt_global_cse == 0. */ void set_opt_global_cse (int value); +/** Enables/Disables strength reduction. + * + * If opt_strength_red == 1 perform strength reduction. + * See strenth_red.h. + * + * Default: opt_strength_red = 1; + */ +void set_opt_strength_red (int value); + +/** Enables/Disables output of information about strength reduction. + */ +void set_opt_strength_red_verbose (int value); + /** Enables/Disables unreachable code elimination. + * + * If set, evaluate conditions of conditional branch and replace the + * branch with a Jmp/Bad Tuple. * * If opt_unreachable_code == 1 replace nodes (except Block, * Phi and Tuple) with a Bad predecessor by the Bad node. @@ -107,6 +154,14 @@ void set_opt_reassociation(int value); * Default: opt_dead_node_elimination == 1. */ void set_opt_dead_node_elimination (int value); +/** Enables/Disables dead method elimination. + * + * If opt_dead_method_elimination == 1 methods never called are + * removed. + * Default: opt_dead_method_elimination == 1. */ +void set_opt_dead_method_elimination (int value); +void set_opt_dead_method_elimination_verbose (int value); + /** Enable/Disables inlining. * * If opt_inline == 1 the inlining transformation is performed. @@ -121,6 +176,15 @@ void set_opt_inline (int value); */ void set_opt_dyn_meth_dispatch (int value); +/** Enable/Disable optimization of tail-recursion calls. + * + * This flag enables/disables the optimization tail-recursion call. + * If the flag is turned on tail-recursion calls are optimized into loops. + */ +void set_opt_tail_recursion(int value); +void set_opt_tail_recursion_verbose(int value); + + /** Enable/Disable normalizations of the firm representation. * * This flag guards transformations that normalize the firm representation @@ -135,6 +199,10 @@ void set_opt_dyn_meth_dispatch (int value); */ void set_opt_normalize (int value); + +/** Enable/Disable precise exception context. */ +void set_opt_precise_exc_context(int value); + /** * Save the current optimization state. */