X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=ir%2Fcommon%2Ffirm.c;h=df3ef9cf87dc8d39dc84778930962d52007ac3c1;hb=b07b1ff301a0e24921468bd8da04bc0a36a9d721;hp=2c5fb69e13be0427c81382a786263cc3adbc7bf1;hpb=1a3b7d363474ab544c13093a2f0b578718d37c7a;p=libfirm diff --git a/ir/common/firm.c b/ir/common/firm.c index 2c5fb69e1..df3ef9cf8 100644 --- a/ir/common/firm.c +++ b/ir/common/firm.c @@ -21,7 +21,6 @@ * @file * @brief Central firm functionality. * @author Martin Trapp, Christian Schaefer, Goetz Lindenmaier - * @version $Id$ */ #include "config.h" @@ -55,6 +54,8 @@ #include "debugger.h" #include "be_t.h" #include "irtools.h" +#include "execfreq_t.h" +#include "firmstat_t.h" /* returns the firm root */ lc_opt_entry_t *firm_opt_get_root(void) @@ -65,34 +66,15 @@ lc_opt_entry_t *firm_opt_get_root(void) return grp; } -void ir_init(const firm_parameter_t *param) +void ir_init(void) { - firm_parameter_t def_params; - unsigned int size; - /* for historical reasons be_init must be run first */ firm_be_init(); - memset(&def_params, 0, sizeof(def_params)); - - if (param) { - /* check for reasonable size */ - assert(param->size <= sizeof(def_params) && (param->size & 3) == 0 && - "parameter struct not initialized ???"); - size = sizeof(def_params); - if (param->size < size) - size = param->size; - - memcpy(&def_params, param, size); - } - /* initialize firm flags */ firm_init_flags(); /* initialize all ident stuff */ init_ident(); - /* enhanced statistics, need idents and hooks */ - if (def_params.enable_statistics != 0) - firm_init_stat(def_params.enable_statistics); /* Edges need hooks. */ init_edges(); /* create the type kinds. */ @@ -105,16 +87,12 @@ void ir_init(const firm_parameter_t *param) init_mode(); /* initialize tarvals, and floating point arithmetic */ init_tarval_2(); + /* initialize node opcodes */ + firm_init_op(); /* init graph construction */ firm_init_irgraph(); /* kind of obstack initialization */ firm_init_mangle(); - /* initialize all op codes an irnode can consist of */ - init_op(); - /* called once for each run of this library */ - if (def_params.initialize_local_func != NULL) - ir_set_uninitialized_local_variable_func( - def_params.initialize_local_func); /* initialize reassociation */ firm_init_reassociation(); /* initialize function call optimization */ @@ -126,10 +104,6 @@ void ir_init(const firm_parameter_t *param) /* Builds a construct allowing to access all information to be constructed later. */ init_irprog_2(); - /* Initialize the type module and construct some idents needed. */ - ir_init_type(); - /* initialize the entity module */ - ir_init_entity(); /* class cast optimization */ firm_init_class_casts_opt(); /* memory disambiguation */ @@ -139,7 +113,9 @@ void ir_init(const firm_parameter_t *param) /* Init architecture dependent optimizations. */ arch_dep_set_opts(arch_dep_none); - init_irnode(); + init_execfreq(); + + init_stat(); #ifdef DEBUG_libfirm /* integrated debugger extension */ @@ -149,31 +125,19 @@ void ir_init(const firm_parameter_t *param) void ir_finish(void) { - size_t i; - - /* must iterate backwards here */ - for (i = get_irp_n_irgs(); i > 0;) - free_ir_graph(get_irp_irg(--i)); - - free_type_entities(get_glob_type()); - /* must iterate backwards here */ - for (i = get_irp_n_types(); i > 0;) - free_type_entities(get_irp_type(--i)); - - for (i = get_irp_n_types(); i > 0;) - free_type(get_irp_type(--i)); +#ifdef DEBUG_libfirm + firm_finish_debugger(); +#endif + exit_execfreq(); + firm_be_finish(); free_ir_prog(); - - ir_finish_entity(); - ir_finish_type(); - + firm_finish_op(); finish_tarval(); finish_mode(); finish_tpop(); + firm_finish_mangle(); finish_ident(); - - firm_be_finish(); } unsigned ir_get_version_major(void)