projects
/
libfirm
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Do not mark the transformed as visited. It makes no sense at all.
[libfirm]
/
ir
/
common
/
firm.c
diff --git
a/ir/common/firm.c
b/ir/common/firm.c
index
f9f2a5c
..
d1ce4d6
100644
(file)
--- a/
ir/common/firm.c
+++ b/
ir/common/firm.c
@@
-56,18
+56,22
@@
#include "type_t.h"
#include "entity_t.h"
#include "opt_inline_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 "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 "debugger.h"
+#include "be_t.h"
/* 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;
}
@@
-82,6
+86,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) {
@@
-108,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 */
/* 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 */
@@
-129,6
+136,8
@@
void init_firm(const firm_parameter_t *param)
firm_init_funccalls();
/* initialize function inlining */
firm_init_inline();
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();
@@
-138,6
+147,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);
@@
-164,13
+177,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. */