X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fcommon%2Ffirm.c;h=d1ce4d61036c453a3807e878190591a26c32a533;hb=0cc8bfc863da28d3799e9eca1d1765d564b6e573;hp=2328583ea67f787fd7643cd9af9453af4dbdf064;hpb=82d3ed00d32d2d72f72c574590c403fb722b81b7;p=libfirm diff --git a/ir/common/firm.c b/ir/common/firm.c index 2328583ea..d1ce4d610 100644 --- a/ir/common/firm.c +++ b/ir/common/firm.c @@ -63,6 +63,7 @@ #include "funccall_t.h" #include "irhooks.h" #include "iredges_t.h" +#include "irmemory_t.h" #include "tropt.h" #include "debugger.h" #include "be_t.h" @@ -114,7 +115,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,6 +149,8 @@ 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(); /* Init architecture dependent optimizations. */ arch_dep_init(arch_dep_default_factory); @@ -174,13 +177,14 @@ 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(); finish_mode(); finish_tpop(); finish_ident(); + + firm_be_finish(); } /* Returns the libFirm version number. */