X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fcommon%2Ffirm.c;h=fbe300ce0bb4a34fc1fad3624ee9be7b44de4886;hb=9aa71a8178ac70333e0aa30ea064d1a734fc1d28;hp=9db53d9e94c312520d341c71cd3f2f5979e239e8;hpb=40953331c994a0f01fa825d6219cbafe3313add8;p=libfirm diff --git a/ir/common/firm.c b/ir/common/firm.c index 9db53d9e9..fbe300ce0 100644 --- a/ir/common/firm.c +++ b/ir/common/firm.c @@ -23,22 +23,14 @@ * @author Martin Trapp, Christian Schaefer, Goetz Lindenmaier * @version $Id$ */ -#ifdef HAVE_CONFIG_H -# include "config.h" -#endif +#include "config.h" #ifdef HAVE_FIRM_REVISION_H # include "firm_revision.h" #endif -#include "firm_config.h" - -#ifdef HAVE_STRING_H -# include -#endif -#ifdef HAVE_STDIO_H -# include -#endif +#include +#include #include "lc_opts.h" @@ -55,32 +47,25 @@ #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 "tropt.h" +#include "irmemory_t.h" +#include "opt_init.h" #include "debugger.h" #include "be_t.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(const firm_parameter_t *param) { firm_parameter_t def_params; unsigned int size; @@ -105,8 +90,6 @@ void init_firm(const firm_parameter_t *param) 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); /* Edges need hooks. */ @@ -114,7 +97,7 @@ void init_firm(const firm_parameter_t *param) /* create the type kinds. */ init_tpop(); /* create an obstack and put all tarvals in a pdeq */ - init_tarval_1(0l); + init_tarval_1(0l, /* support_quad_precision */0); /* Builds a basic program representation, so modes can be added. */ init_irprog_1(); /* initialize all modes an ir node can consist of */ @@ -148,24 +131,28 @@ void init_firm(const firm_parameter_t *param) init_type_identify(def_params.ti_if); /* 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); - firm_archops_init(def_params.arch_op_settings); - #ifdef DEBUG_libfirm /* integrated debugger extension */ firm_init_debugger(); #endif } -void free_firm(void) { +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) @@ -174,7 +161,6 @@ void free_firm(void) { for (i = get_irp_n_types() - 1; i >= 0; --i) free_type(get_irp_type(i)); - finish_op(); free_ir_prog(); finish_tarval(); @@ -185,14 +171,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 ""; }