X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firflag.c;h=21bc81012ca61e10c4ccaf74a0525652abe3d59c;hb=637542932dc27dcdfc7def09b58d9d5d4c34fb77;hp=b01ac6fcc0050c1f5f507122ad033937fa3474c1;hpb=8456cab1ff7b43afcf4fcf81bd9037335f1d25bc;p=libfirm diff --git a/ir/ir/irflag.c b/ir/ir/irflag.c index b01ac6fcc..21bc81012 100644 --- a/ir/ir/irflag.c +++ b/ir/ir/irflag.c @@ -11,7 +11,7 @@ */ #ifdef HAVE_CONFIG_H -# include +# include "config.h" #endif #include "firm_common.h" @@ -26,6 +26,7 @@ optimization_state_t libFIRM_opt = ENABLE(OPT_OPTIMIZED) | ENABLE(OPT_CSE) | DISABLE(OPT_GLOBAL_CSE) | + ENABLE(OPT_LOOP_UNROLLING) | ENABLE(OPT_STRENGTH_RED) | ENABLE(OPT_CONSTANT_FOLDING) | ENABLE(OPT_REDUNDANT_LOADSTORE) | @@ -39,16 +40,21 @@ optimization_state_t libFIRM_opt = ENABLE(OPT_REASSOCIATION) | ENABLE(OPT_INLINE) | ENABLE(OPT_DYN_METH_DISPATCH) | + ENABLE(OPT_CLASS_CASTS) | + DISABLE(OPT_SUPPRESS_DOWNCAST_OPT) | ENABLE(OPT_NORMALIZE) | ENABLE(OPT_TAIL_RECURSION) | ENABLE(OPT_PRECISE_EXC_CONTEXT) | DISABLE(OPT_FRAGILE_OPS) | + ENABLE(OPT_IF_CONVERSION) | + ENABLE(OPT_REAL_FUNC_CALL) | 0; optimization_state_t libFIRM_verb = DISABLE(OPT_OPTIMIZED) | DISABLE(OPT_CSE) | DISABLE(OPT_GLOBAL_CSE) | + DISABLE(OPT_LOOP_UNROLLING) | DISABLE(OPT_STRENGTH_RED) | DISABLE(OPT_CONSTANT_FOLDING) | DISABLE(OPT_REDUNDANT_LOADSTORE) | @@ -62,10 +68,13 @@ optimization_state_t libFIRM_verb = DISABLE(OPT_REASSOCIATION) | DISABLE(OPT_INLINE) | DISABLE(OPT_DYN_METH_DISPATCH) | + DISABLE(OPT_CLASS_CASTS) | DISABLE(OPT_NORMALIZE) | DISABLE(OPT_TAIL_RECURSION) | DISABLE(OPT_PRECISE_EXC_CONTEXT) | - DISABLE(OPT_FRAGILE_OPS) | + DISABLE(OPT_FRAGILE_OPS) | + DISABLE(OPT_IF_CONVERSION) | + DISABLE(OPT_REAL_FUNC_CALL) | 0; /** The Firm verbosity level */ @@ -80,6 +89,10 @@ void set_opt_cse (int value) libFIRM_opt &= ~OPT_CSE; } +int (get_opt_cse)(void) { + return _get_opt_cse(); +} + void set_opt_global_cse(int value) { if (value) @@ -88,6 +101,22 @@ void set_opt_global_cse(int value) libFIRM_opt &= ~OPT_GLOBAL_CSE; } +void set_opt_loop_unrolling (int value) +{ + if (value) + libFIRM_opt |= OPT_LOOP_UNROLLING; + else + libFIRM_opt &= ~OPT_LOOP_UNROLLING; +} + +void set_opt_loop_unrolling_verbose (int value) +{ + if (value) + libFIRM_verb |= OPT_LOOP_UNROLLING; + else + libFIRM_verb &= ~OPT_LOOP_UNROLLING; +} + void set_opt_strength_red (int value) { if (value) @@ -245,6 +274,42 @@ void set_opt_dyn_meth_dispatch (int value) libFIRM_opt &= ~OPT_DYN_METH_DISPATCH; } +int (get_opt_dyn_meth_dispatch)(void) { + return _get_opt_dyn_meth_dispatch(); +} + +void set_opt_optimize_class_casts (int value) +{ + if (value) + libFIRM_opt |= OPT_CLASS_CASTS; + else + libFIRM_opt &= ~OPT_CLASS_CASTS; +} +int (get_opt_optimize_class_casts) (void) { + return _get_opt_optimize_class_casts(); +} +void set_opt_optimize_class_casts_verbose (int value) +{ + if (value) + libFIRM_verb |= OPT_CLASS_CASTS; + else + libFIRM_verb &= ~OPT_CLASS_CASTS; +} +int (get_opt_optimize_class_casts_verbose) (void) { + return _get_opt_optimize_class_casts_verbose(); +} +void set_opt_suppress_downcast_optimization(int value) +{ + if (value) + libFIRM_opt |= OPT_SUPPRESS_DOWNCAST_OPT; + else + libFIRM_opt &= ~OPT_SUPPRESS_DOWNCAST_OPT; +} +int (get_opt_suppress_downcast_optimization)(void) { + return _get_opt_suppress_downcast_optimization(); +} + + /* Enable/Disable normalizations of the firm representation. */ void set_opt_normalize(int value) { @@ -291,6 +356,24 @@ void set_opt_fragile_ops(int value) libFIRM_opt &= ~OPT_FRAGILE_OPS; } +/* Enable/Disable if conversion. */ +void set_opt_if_conversion(int value) +{ + if (value) + libFIRM_opt |= OPT_IF_CONVERSION; + else + libFIRM_opt &= ~OPT_IF_CONVERSION; +} + +/* Enable/Disable real function call optimization. */ +void set_opt_real_function_call(int value) +{ + if (value) + libFIRM_opt |= OPT_REAL_FUNC_CALL; + else + libFIRM_opt &= ~OPT_REAL_FUNC_CALL; +} + /* Save the current optimization state. */ void save_optimization_state(optimization_state_t *state) {