removed wrong const
[libfirm] / ir / common / firm.c
index f741a2c..77ac607 100644 (file)
@@ -72,6 +72,8 @@ init_firm(const firm_parameter_t *param)
   init_tpop();
   /* create an obstack and put all tarvals in a pdeq */
   init_tarval_1();
+  /* Builds a basic program representation, so modes can be added. */
+  init_irprog_1();
   /* initialize all modes an ir node can consist of */
   init_mode();
   /* initialize tarvals, and floating point arithmetic */
@@ -80,7 +82,7 @@ init_firm(const firm_parameter_t *param)
   init_irgraph();
   /* kind of obstack initialization */
   firm_init_mangle();
-  /* initalize all op codes an irnode can consist of */
+  /* 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);
@@ -88,9 +90,9 @@ init_firm(const firm_parameter_t *param)
   firm_init_reassociation();
   /* Builds a construct allowing to access all information to be constructed
      later. */
-  init_irprog();
+  init_irprog_2();
   /* Constructs some idents needed. */
-  init_type();
+  firm_init_type(NULL);
   init_entity();
   /* allocate a hash table. */
   init_type_identify(def_params.ti_if);
@@ -100,21 +102,24 @@ init_firm(const firm_parameter_t *param)
   /* Init architecture dependent optimizations. */
   arch_dep_init(arch_dep_default_factory);
   arch_dep_set_opts(arch_dep_mul_to_shift | arch_dep_div_by_const | arch_dep_mod_by_const);
+
+  firm_archops_init(def_params.arch_op_settings);
 }
 
 
 void free_firm(void) {
   int i;
 
-  for (i = 0; i < get_irp_n_irgs(); i++)
+  for (i = get_irp_n_irgs() - 1; i >= 0; --i)
     free_ir_graph(get_irp_irg(i));
 
-  for (i = 0; i < get_irp_n_types(); i++) {
+  free_type_entities(get_glob_type());
+  for (i = get_irp_n_types() - 1; i >= 0; --i)
     free_type_entities(get_irp_type(i));
+
+  for (i = get_irp_n_types() - 1; i >= 0; --i)
     free_type(get_irp_type(i));
-  }
 
-  free_type_entities(get_glob_type());
   free_ir_prog();
 
   finish_tarval();