X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firflag.c;h=21bc81012ca61e10c4ccaf74a0525652abe3d59c;hb=637542932dc27dcdfc7def09b58d9d5d4c34fb77;hp=787bd696edd0eef167859795e730472b36cb46ac;hpb=eba4147619c151d82eaeef60115f61b6696bd6ff;p=libfirm diff --git a/ir/ir/irflag.c b/ir/ir/irflag.c index 787bd696e..21bc81012 100644 --- a/ir/ir/irflag.c +++ b/ir/ir/irflag.c @@ -40,11 +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 = @@ -65,11 +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_IF_CONVERSION) | + DISABLE(OPT_REAL_FUNC_CALL) | 0; /** The Firm verbosity level */ @@ -273,6 +278,38 @@ 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) { @@ -319,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) @@ -327,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) {