X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firflag.c;h=dd4490ff0da6490e1649ab74c8c9baf9d420398b;hb=efb58316e745bcec4fa46f76c8f2c69208a44928;hp=69101501269814fd6f3efeef0f15b5901a35f3b3;hpb=969f52a3743dd60803f8fd5122aa8c714d17ae32;p=libfirm diff --git a/ir/ir/irflag.c b/ir/ir/irflag.c index 691015012..dd4490ff0 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. * @@ -20,18 +20,13 @@ /** * @file * @brief Flags to control optimizations. - * @author Christian Schaefer, Goetz Lindenmaier - * @version $Id$ + * @author Michael Beck, Sebastian Hack */ -#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" @@ -39,8 +34,8 @@ /* DISABLE - don't do this optimization ENABLE - lets see, if there is a better graph */ -#define ON (-1) -#define OFF (0) +#define ON -1 +#define OFF 0 #define FLAG(name, value, def) (irf_##name & def) | #define E_FLAG(name, value, def) FLAG(name, value, def) @@ -56,14 +51,11 @@ optimization_state_t libFIRM_opt = #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; +void set_opt_optimize(int value); /* an external flag can be set and get from outside */ #define E_FLAG(name, value, def) \ @@ -71,12 +63,8 @@ void set_opt_##name(int flag) { \ if (flag) libFIRM_opt |= irf_##name; \ else libFIRM_opt &= ~irf_##name; \ } \ -void set_opt_##name##_verbose(int flag) { \ - if (flag) libFIRM_verb |= irf_##name; \ - else libFIRM_verb &= ~irf_##name; \ -} \ int (get_opt_##name)(void) { \ - return _get_opt_##name(); \ + return get_opt_##name##_(); \ } /* an internal flag can only be set from outside */ @@ -85,10 +73,6 @@ void set_opt_##name(int flag) { \ if (flag) libFIRM_opt |= irf_##name; \ else libFIRM_opt &= ~irf_##name; \ } \ -void set_opt_##name##_verbose(int flag) { \ - if (flag) libFIRM_verb |= irf_##name; \ - else libFIRM_verb &= ~irf_##name; \ -} #define R_FLAG(name, value) @@ -99,55 +83,37 @@ void set_opt_##name##_verbose(int 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; -} - -int (get_optimize)(void) { - return get_opt_optimize(); -} - -void set_opt_control_flow(int value) +void set_optimize(int value) { - set_opt_control_flow_straightening(value); - set_opt_control_flow_weak_simplification(value); - set_opt_control_flow_strong_simplification(value); + set_opt_optimize(value); } -void set_firm_verbosity (int value) { - firm_verbosity_level = value; -} - -int (get_firm_verbosity) (void) { - return _get_firm_verbosity(); +int (get_optimize)(void) +{ + return get_opt_optimize(); } -/* Save the current optimization state. */ void save_optimization_state(optimization_state_t *state) { - *state = libFIRM_opt; + *state = libFIRM_opt; } -/* Restore the current optimization state. */ void restore_optimization_state(const optimization_state_t *state) { - libFIRM_opt = *state; + libFIRM_opt = *state; } -/* Switches ALL optimizations off */ void all_optimizations_off(void) { - libFIRM_opt = 0; + libFIRM_opt = 0; } #ifdef _DEBUG -/* only for debugging */ -void firm_show_flags(FILE *f) { - if (! f) - f = stdout; - printf("Firm optimization state:\n"); +void firm_show_flags(FILE *f) +{ + 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"); @@ -155,11 +121,10 @@ void firm_show_flags(FILE *f) { #undef I_FLAG #undef E_FLAG #undef R_FLAG - printf("\n"); + 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)), @@ -170,17 +135,16 @@ static const lc_opt_table_entry_t firm_flags[] = { #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; +void do_node_verification(firm_verification_t mode) +{ + opt_do_node_verification = mode; }