X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fcommon%2Ffirm.c;h=0034aa4602c08db83775f694f464a8123aeadd73;hb=ea68f3f7a13e0b7742bfaa643e109302bc023e9c;hp=97569391f924109e5a94c225b7fb21ced9c593a2;hpb=ea75e9d38674b468f602a0699fb64b9c01254797;p=libfirm diff --git a/ir/common/firm.c b/ir/common/firm.c index 97569391f..0034aa460 100644 --- a/ir/common/firm.c +++ b/ir/common/firm.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved. + * Copyright (C) 1995-2011 University of Karlsruhe. All right reserved. * * This file is part of libFirm. * @@ -21,7 +21,6 @@ * @file * @brief Central firm functionality. * @author Martin Trapp, Christian Schaefer, Goetz Lindenmaier - * @version $Id$ */ #include "config.h" @@ -55,6 +54,7 @@ #include "debugger.h" #include "be_t.h" #include "irtools.h" +#include "execfreq_t.h" /* returns the firm root */ lc_opt_entry_t *firm_opt_get_root(void) @@ -65,33 +65,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(def_params.id_if, 1024); - /* enhanced statistics, need idents and hooks */ - firm_init_stat(def_params.enable_statistics); + init_ident(); /* Edges need hooks. */ init_edges(); /* create the type kinds. */ @@ -104,14 +86,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 */ - firm_init_cons(def_params.initialize_local_func); /* initialize reassociation */ firm_init_reassociation(); /* initialize function call optimization */ @@ -123,10 +103,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. */ - firm_init_type(def_params.cc_mask); - /* initialize the entity module */ - firm_init_entity(); /* class cast optimization */ firm_init_class_casts_opt(); /* memory disambiguation */ @@ -134,10 +110,9 @@ void ir_init(const firm_parameter_t *param) firm_init_loop_opt(); /* Init architecture dependent optimizations. */ - arch_dep_init(arch_dep_default_factory); - arch_dep_set_opts(0); + arch_dep_set_opts(arch_dep_none); - init_irnode(); + init_execfreq(); #ifdef DEBUG_libfirm /* integrated debugger extension */ @@ -147,28 +122,19 @@ void ir_init(const firm_parameter_t *param) void ir_finish(void) { - int i; - - for (i = get_irp_n_irgs() - 1; i >= 0; --i) - free_ir_graph(get_irp_irg(i)); - for (i = get_irp_n_pseudo_irgs() - 1; i >= 0; --i) - free_ir_graph(get_irp_pseudo_irg(i)); - - free_type_entities(get_glob_type()); - for (i = get_irp_n_types() - 1; i >= 0; --i) - free_type_entities(get_irp_type(i)); - - for (i = get_irp_n_types() - 1; i >= 0; --i) - free_type(get_irp_type(i)); +#ifdef DEBUG_libfirm + firm_finish_debugger(); +#endif + exit_execfreq(); + firm_be_finish(); free_ir_prog(); - + firm_finish_op(); finish_tarval(); finish_mode(); finish_tpop(); + firm_finish_mangle(); finish_ident(); - - firm_be_finish(); } unsigned ir_get_version_major(void)