X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firflag.c;h=745ae0d936e51201ab3769455c78715564a80c82;hb=8f355cb9b3d20c10f71d1b1e17cbf59a51ced83b;hp=30b98ce9776023b8f1ab9703b680264dbb2f7786;hpb=a142727aca4ef56cf754045fc0129b6d1b840a63;p=libfirm diff --git a/ir/ir/irflag.c b/ir/ir/irflag.c index 30b98ce97..745ae0d93 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. * @@ -42,9 +42,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" @@ -53,7 +54,10 @@ 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; @@ -86,11 +90,14 @@ 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) { @@ -143,9 +150,11 @@ void firm_show_flags(FILE *f) { 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 +#undef R_FLAG printf("\n"); } #endif @@ -154,15 +163,16 @@ void firm_show_flags(FILE *f) { 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) -{ +void firm_init_flags(void) { #ifdef WITH_LIBCORE lc_opt_entry_t *grp = lc_opt_get_grp(firm_opt_get_root(), "opt"); lc_opt_add_table(grp, firm_flags);