X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firflag.c;h=21bc81012ca61e10c4ccaf74a0525652abe3d59c;hb=637542932dc27dcdfc7def09b58d9d5d4c34fb77;hp=ab759f236d62a3367a20d6db38965dada97e8d1d;hpb=15a59fd1453ab23be5d08f59b4a8d3a90656b572;p=libfirm diff --git a/ir/ir/irflag.c b/ir/ir/irflag.c index ab759f236..21bc81012 100644 --- a/ir/ir/irflag.c +++ b/ir/ir/irflag.c @@ -40,10 +40,14 @@ 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 = @@ -64,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 */ @@ -267,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) { @@ -313,6 +356,7 @@ 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) @@ -321,6 +365,15 @@ void set_opt_if_conversion(int value) 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) {