remove #ifdef HAVE_CONFIG_Hs
[libfirm] / ir / common / firm.c
index 79a6ca0..2084a0b 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1995-2007 University of Karlsruhe.  All right reserved.
+ * Copyright (C) 1995-2008 University of Karlsruhe.  All right reserved.
  *
  * This file is part of libFirm.
  *
  * @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 <string.h>
 #endif
@@ -40,9 +36,7 @@
 # include <stdio.h>
 #endif
 
-#ifdef WITH_LIBCORE
-# include <libcore/lc_opts.h>
-#endif
+#include "lc_opts.h"
 
 #include "ident_t.h"
 #include "firm.h"
 #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 "debugger.h"
+#include "be_t.h"
 
-#ifdef WITH_LIBCORE
 /* returns the firm root */
 lc_opt_entry_t *firm_opt_get_root(void) {
        static lc_opt_entry_t *grp = NULL;
-       if(!grp)
+       if (!grp)
                grp = lc_opt_get_grp(lc_opt_root_grp(), "firm");
        return grp;
 }
-#endif
 
 void firm_init_options(const char *arg_prefix, int argc, const char **argv) {
-#ifdef LIBCORE
        /* parse any init files for firm */
        lc_opts_init("firm", firm_opt_get_root(), arg_prefix, argc, argv);
-#else
-       (void) arg_prefix;
-       (void) argc;
-       (void) argv;
-#endif
 }
 
 void init_firm(const firm_parameter_t *param)
@@ -90,6 +82,9 @@ void init_firm(const firm_parameter_t *param)
        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) {
@@ -116,7 +111,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 */
@@ -130,9 +125,15 @@ void init_firm(const firm_parameter_t *param)
        /* initialize all op codes an irnode can consist of */
        init_op();
        /* called once for each run of this library */
-       init_cons(def_params.initialize_local_func);
+       firm_init_cons(def_params.initialize_local_func);
        /* initialize reassociation */
        firm_init_reassociation();
+       /* initialize function call optimization */
+       firm_init_funccalls();
+       /* initialize function inlining */
+       firm_init_inline();
+       /* initialize scalar replacement */
+       firm_init_scalar_replace();
        /* Builds a construct allowing to access all information to be constructed
           later. */
        init_irprog_2();
@@ -142,6 +143,10 @@ void init_firm(const firm_parameter_t *param)
        firm_init_entity();
        /* allocate a hash table. */
        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);
@@ -168,13 +173,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. */