projects
/
libfirm
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
forgot 2 files
[libfirm]
/
ir
/
common
/
firm.c
diff --git
a/ir/common/firm.c
b/ir/common/firm.c
index
79a6ca0
..
105296a
100644
(file)
--- a/
ir/common/firm.c
+++ b/
ir/common/firm.c
@@
-1,5
+1,5
@@
/*
/*
- * Copyright (C) 1995-200
7
University of Karlsruhe. All right reserved.
+ * Copyright (C) 1995-200
8
University of Karlsruhe. All right reserved.
*
* This file is part of libFirm.
*
*
* This file is part of libFirm.
*
@@
-23,16
+23,12
@@
* @author Martin Trapp, Christian Schaefer, Goetz Lindenmaier
* @version $Id$
*/
* @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
#ifdef HAVE_FIRM_REVISION_H
# include "firm_revision.h"
#endif
-#include "firm_config.h"
-
#ifdef HAVE_STRING_H
# include <string.h>
#endif
#ifdef HAVE_STRING_H
# include <string.h>
#endif
@@
-40,9
+36,7
@@
# include <stdio.h>
#endif
# 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 "ident_t.h"
#include "firm.h"
@@
-57,32
+51,30
@@
#include "irgraph_t.h"
#include "type_t.h"
#include "entity_t.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 "firmstat.h"
#include "irarch.h"
#include "reassoc_t.h"
+#include "funccall_t.h"
#include "irhooks.h"
#include "iredges_t.h"
#include "irhooks.h"
#include "iredges_t.h"
+#include "irmemory_t.h"
+#include "tropt.h"
#include "debugger.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;
/* 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;
}
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) {
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
+ /* parse commandline */
+ lc_opt_from_argv(firm_opt_get_root(), arg_prefix, argc, argv, NULL);
}
void init_firm(const firm_parameter_t *param)
}
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;
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) {
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 */
/* 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 */
/* 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 */
/* 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 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();
/* 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);
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);
/* 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));
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();
free_ir_prog();
finish_tarval();
finish_mode();
finish_tpop();
finish_ident();
+
+ firm_be_finish();
}
/* Returns the libFirm version number. */
}
/* Returns the libFirm version number. */