X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=ir%2Fir%2Firflag.c;h=f8b2f01d5c3854da12b441d2adb686c17552a31e;hb=6c24754b4ed2e4306f6afc287f1a39662bd7b3b6;hp=21bc81012ca61e10c4ccaf74a0525652abe3d59c;hpb=544082c1d6da1cc2053cf22786c9524a7a2b124c;p=libfirm diff --git a/ir/ir/irflag.c b/ir/ir/irflag.c index 21bc81012..f8b2f01d5 100644 --- a/ir/ir/irflag.c +++ b/ir/ir/irflag.c @@ -23,31 +23,33 @@ #define DISABLE(a) 0 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) | - ENABLE(OPT_UNREACHABLE_CODE) | - ENABLE(OPT_CONTROL_FLOW_STRAIGHTENING) | - ENABLE(OPT_CONTROL_FLOW_WEAK_SIMPLIFICATION) | - ENABLE(OPT_CONTROL_FLOW_STRONG_SIMPLIFICATION) | - ENABLE(OPT_CRITICAL_EDGES) | - ENABLE(OPT_DEAD_NODE_ELIMINATION) | - ENABLE(OPT_DEAD_METHOD_ELIMINATION) | - 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) | + 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) | + ENABLE(OPT_UNREACHABLE_CODE) | + ENABLE(OPT_CONTROL_FLOW_STRAIGHTENING) | + ENABLE(OPT_CONTROL_FLOW_WEAK_SIMPLIFICATION) | + ENABLE(OPT_CONTROL_FLOW_STRONG_SIMPLIFICATION) | + ENABLE(OPT_CRITICAL_EDGES) | + ENABLE(OPT_DEAD_NODE_ELIMINATION) | + ENABLE(OPT_DEAD_METHOD_ELIMINATION) | + 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) | + DISABLE(OPT_REMOVE_CONFIRM) | + ENABLE(OPT_SCALAR_REPLACEMENT) | 0; optimization_state_t libFIRM_verb = @@ -75,6 +77,8 @@ optimization_state_t libFIRM_verb = DISABLE(OPT_FRAGILE_OPS) | DISABLE(OPT_IF_CONVERSION) | DISABLE(OPT_REAL_FUNC_CALL) | + DISABLE(OPT_REMOVE_CONFIRM) | + DISABLE(OPT_SCALAR_REPLACEMENT) | 0; /** The Firm verbosity level */ @@ -374,6 +378,33 @@ void set_opt_real_function_call(int value) libFIRM_opt &= ~OPT_REAL_FUNC_CALL; } +/* Enable/Disable Confirm node removal. */ +void set_opt_remove_Confirm(int value) +{ + if (value) + libFIRM_opt |= OPT_REMOVE_CONFIRM; + else + libFIRM_opt &= ~OPT_REMOVE_CONFIRM; +} + +/* Enable/Disable scalar replacement optimization. */ +void set_opt_scalar_replacement(int value) +{ + if (value) + libFIRM_opt |= OPT_SCALAR_REPLACEMENT; + else + libFIRM_opt &= ~OPT_SCALAR_REPLACEMENT; +} + +/* Set verbosity for scalar relacement */ +void set_opt_scalar_replacement_verbose(int value) +{ + if (value) + libFIRM_verb |= OPT_SCALAR_REPLACEMENT; + else + libFIRM_verb &= ~OPT_SCALAR_REPLACEMENT; +} + /* Save the current optimization state. */ void save_optimization_state(optimization_state_t *state) {