X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fcommon%2Ffirm.c;h=162ac0cecbf4259efadd73842283b32ce1e1eba1;hb=73218d02f521d48156b8b10df1c0655a6279003c;hp=2084a0bd76bd9b53f4fb6fda2369f806c7e16dd3;hpb=0fbcef83aa6060534172bb13e71cdadb04428806;p=libfirm diff --git a/ir/common/firm.c b/ir/common/firm.c index 2084a0bd7..162ac0cec 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. * @@ -29,19 +29,14 @@ # include "firm_revision.h" #endif -#ifdef HAVE_STRING_H -# include -#endif -#ifdef HAVE_STDIO_H -# include -#endif +#include +#include #include "lc_opts.h" #include "ident_t.h" #include "firm.h" #include "irflag_t.h" -/* init functions are not public */ #include "tv_t.h" #include "tpop_t.h" #include "irprog_t.h" @@ -51,61 +46,34 @@ #include "irgraph_t.h" #include "type_t.h" #include "entity_t.h" -#include "opt_inline_t.h" -#include "scalar_replace.h" #include "firmstat.h" #include "irarch.h" -#include "reassoc_t.h" -#include "funccall_t.h" #include "irhooks.h" #include "iredges_t.h" #include "irmemory_t.h" -#include "tropt.h" +#include "opt_init.h" #include "debugger.h" #include "be_t.h" +#include "irtools.h" /* returns the firm root */ -lc_opt_entry_t *firm_opt_get_root(void) { +lc_opt_entry_t *firm_opt_get_root(void) +{ static lc_opt_entry_t *grp = NULL; if (!grp) grp = lc_opt_get_grp(lc_opt_root_grp(), "firm"); return grp; } -void firm_init_options(const char *arg_prefix, int argc, const char **argv) { - /* parse any init files for firm */ - lc_opts_init("firm", firm_opt_get_root(), arg_prefix, argc, argv); -} - -void init_firm(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); - /* initialize Firm hooks */ - firm_init_hooks(); - /* enhanced statistics, need idents and hooks */ - firm_init_stat(def_params.enable_statistics); + init_ident(); /* Edges need hooks. */ init_edges(); /* create the type kinds. */ @@ -124,8 +92,6 @@ void init_firm(const firm_parameter_t *param) 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 */ @@ -138,21 +104,19 @@ void init_firm(const firm_parameter_t *param) later. */ init_irprog_2(); /* Initialize the type module and construct some idents needed. */ - firm_init_type(def_params.builtin_dbg, def_params.cc_mask); + ir_init_type(); /* initialize the entity module */ - firm_init_entity(); - /* allocate a hash table. */ - init_type_identify(def_params.ti_if); + ir_init_entity(); /* class cast optimization */ firm_init_class_casts_opt(); /* memory disambiguation */ firm_init_memory_disambiguator(); + 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); - firm_archops_init(def_params.arch_op_settings); + init_irnode(); #ifdef DEBUG_libfirm /* integrated debugger extension */ @@ -160,21 +124,27 @@ void init_firm(const firm_parameter_t *param) #endif } -void free_firm(void) { - int i; +void ir_finish(void) +{ + size_t i; - for (i = get_irp_n_irgs() - 1; i >= 0; --i) - free_ir_graph(get_irp_irg(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()); - for (i = get_irp_n_types() - 1; i >= 0; --i) - free_type_entities(get_irp_type(i)); + /* 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() - 1; i >= 0; --i) - free_type(get_irp_type(i)); + for (i = get_irp_n_types(); i > 0;) + free_type(get_irp_type(--i)); free_ir_prog(); + ir_finish_entity(); + ir_finish_type(); + finish_tarval(); finish_mode(); finish_tpop(); @@ -183,14 +153,26 @@ void free_firm(void) { firm_be_finish(); } -/* Returns the libFirm version number. */ -void firm_get_version(firm_version_t *version) { - version->major = libfirm_VERSION_MAJOR; - version->minor = libfirm_VERSION_MINOR; +unsigned ir_get_version_major(void) +{ + return libfirm_VERSION_MAJOR; +} + +unsigned ir_get_version_minor(void) +{ + return libfirm_VERSION_MINOR; +} + +const char *ir_get_version_revision(void) +{ #ifdef libfirm_VERSION_REVISION - version->revision = libfirm_VERSION_REVISION; + return libfirm_VERSION_REVISION; #else - version->revision = ""; + return ""; #endif - version->build = ""; +} + +const char *ir_get_version_build(void) +{ + return ""; }