X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firflag.c;h=21880847f476e873f9b9e1a4296359221aea52fa;hb=bc35052031be38b7243401b37fe1d791728c7df2;hp=feec4beac8abaceb21b4e75b76fec0f85e214a93;hpb=eb08138c6b80c169945568e4414f491a9bc20388;p=libfirm diff --git a/ir/ir/irflag.c b/ir/ir/irflag.c index feec4beac..21880847f 100644 --- a/ir/ir/irflag.c +++ b/ir/ir/irflag.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 1995-2007 University of Karlsruhe. All right reserved. + * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved. * * This file is part of libFirm. * @@ -17,26 +17,17 @@ * PURPOSE. */ -/* - * Project: libFIRM - * File name: ir/ir/irflag.c - * Purpose: Flags to control optimizations. - * Author: Christian Schaefer, Goetz Lindenmaier - * Modified by: - * Created: - * CVS-ID: $Id$ - * Copyright: (c) 1999-2003 Universität Karlsruhe +/** + * @file + * @brief Flags to control optimizations. + * @author Michael Beck, Sebastian Hack + * @version $Id$ */ - -#ifdef HAVE_CONFIG_H -# include "config.h" -#endif +#include "config.h" #include -#ifdef WITH_LIBCORE -#include -#endif +#include "lc_opts.h" #include "firm_common.h" #include "irtools.h" @@ -47,9 +38,10 @@ #define ON (-1) #define OFF (0) -#define FLAG(name, value, def) (irf_##name & def) | -#define E_FLAG(name, value, def) FLAG(name, value, def) -#define I_FLAG(name, value, def) FLAG(name, value, def) +#define FLAG(name, value, def) (irf_##name & def) | +#define E_FLAG(name, value, def) FLAG(name, value, def) +#define I_FLAG(name, value, def) FLAG(name, value, def) +#define R_FLAG(name, value) optimization_state_t libFIRM_opt = #include "irflag_t.def" @@ -58,14 +50,14 @@ optimization_state_t libFIRM_opt = #undef FLAG #undef E_FLAG #undef I_FLAG +#undef R_FLAG +/** The bitset of currently running phases. */ +optimization_state_t libFIRM_running = 0; /* verbose is always off on default */ optimization_state_t libFIRM_verb = 0; -/** The Firm verbosity level */ -int firm_verbosity_level; - /* an external flag can be set and get from outside */ #define E_FLAG(name, value, def) \ void set_opt_##name(int flag) { \ @@ -91,91 +83,81 @@ void set_opt_##name##_verbose(int flag) { \ else libFIRM_verb &= ~irf_##name; \ } +#define R_FLAG(name, value) + /* generate them */ #include "irflag_t.def" #undef I_FLAG #undef E_FLAG +#undef R_FLAG /* for compatibility reasons */ void set_optimize(int value) { - if (value) libFIRM_opt |= irf_optimize; - else libFIRM_opt &= ~irf_optimize; + if (value) libFIRM_opt |= irf_optimize; + else libFIRM_opt &= ~irf_optimize; } int (get_optimize)(void) { - return get_opt_optimize(); + return get_opt_optimize(); } -void set_opt_control_flow(int value) -{ - set_opt_control_flow_straightening(value); - set_opt_control_flow_weak_simplification(value); - set_opt_control_flow_strong_simplification(value); -} - -void set_firm_verbosity (int value) { - firm_verbosity_level = value; -} - -int (get_firm_verbosity) (void) { - return _get_firm_verbosity(); +void set_opt_control_flow(int value) { + set_opt_control_flow_straightening(value); + set_opt_control_flow_weak_simplification(value); + set_opt_control_flow_strong_simplification(value); } /* Save the current optimization state. */ -void save_optimization_state(optimization_state_t *state) -{ - *state = libFIRM_opt; +void save_optimization_state(optimization_state_t *state) { + *state = libFIRM_opt; } /* Restore the current optimization state. */ -void restore_optimization_state(const optimization_state_t *state) -{ - libFIRM_opt = *state; +void restore_optimization_state(const optimization_state_t *state) { + libFIRM_opt = *state; } /* Switches ALL optimizations off */ -void all_optimizations_off(void) -{ - libFIRM_opt = 0; +void all_optimizations_off(void) { + libFIRM_opt = 0; } #ifdef _DEBUG /* only for debugging */ void firm_show_flags(FILE *f) { - if (! f) - f = stdout; - printf("Firm optimization state:\n"); + if (! f) + f = stdout; + printf("Firm optimization state:\n"); #define E_FLAG(name, value, def) printf(" %-20s = %s\n", #name, get_opt_##name() ? "ON" : "OFF"); #define I_FLAG(name, value, def) printf(" %-20s = %s\n", #name, get_opt_##name() ? "ON" : "OFF"); +#define R_FLAG(name, value) printf(" %-20s = %s\n", #name, is_##name##_running() ? "is running" : "not running"); #include "irflag_t.def" #undef I_FLAG #undef E_FLAG - printf("\n"); +#undef R_FLAG + printf("\n"); } #endif -#ifdef WITH_LIBCORE static const lc_opt_table_entry_t firm_flags[] = { #define I_FLAG(name, val, def) LC_OPT_ENT_BIT(#name, #name, &libFIRM_opt, (1 << val)), #define E_FLAG(name, val, def) LC_OPT_ENT_BIT(#name, #name, &libFIRM_opt, (1 << val)), +#define R_FLAG(name, val) #include "irflag_t.def" #undef I_FLAG #undef E_FLAG - { NULL } +#undef R_FLAG + LC_OPT_LAST }; -#endif -void firm_init_flags(void) -{ -#ifdef WITH_LIBCORE +void firm_init_flags(void) { lc_opt_entry_t *grp = lc_opt_get_grp(firm_opt_get_root(), "opt"); lc_opt_add_table(grp, firm_flags); -#endif } firm_verification_t opt_do_node_verification = FIRM_VERIFICATION_ON; void do_node_verification(firm_verification_t mode) { - opt_do_node_verification = mode; + opt_do_node_verification = mode; }