refactor mode_b lowerer to have a create_set callback
[libfirm] / ir / be / becopyopt.c
index b92b32d..cde32cd 100644 (file)
@@ -171,8 +171,10 @@ static int nodes_interfere(const be_chordal_env_t *env, const ir_node *a, const
 {
        if (env->ifg)
                return be_ifg_connected(env->ifg, a, b);
-       else
-               return be_values_interfere(env->birg->lv, a, b);
+       else {
+               be_lv_t *lv = be_get_irg_liveness(env->irg);
+               return be_values_interfere(lv, a, b);
+       }
 }
 
 
@@ -272,8 +274,9 @@ int co_get_costs_exec_freq(const copy_opt_t *co, ir_node *root, ir_node* arg, in
        int res;
        ir_node *root_bl = get_nodes_block(root);
        ir_node *copy_bl = is_Phi(root) ? get_Block_cfgpred_block(root_bl, pos) : root_bl;
+       ir_exec_freq *exec_freq = be_get_irg_exec_freq(co->cenv->irg);
        (void) arg;
-       res = get_block_execfreq_ulong(co->cenv->birg->exec_freq, copy_bl);
+       res = get_block_execfreq_ulong(exec_freq, copy_bl);
 
        /* don't allow values smaller than one. */
        return res < 1 ? 1 : res;
@@ -855,8 +858,6 @@ void co_free_graph_structure(copy_opt_t *co)
        co->nodes = NULL;
 }
 
-/* co_solve_ilp1() co_solve_ilp2() are implemented in becopyilpX.c */
-
 int co_gs_is_optimizable(copy_opt_t *co, ir_node *irn)
 {
        affinity_node_t new_node, *n;
@@ -1012,7 +1013,7 @@ static const char *get_dot_color_name(size_t col)
        return col < sizeof(names)/sizeof(names[0]) ? names[col] : "white";
 }
 
-typedef struct _co_ifg_dump_t {
+typedef struct co_ifg_dump_t {
        const copy_opt_t *co;
        unsigned flags;
 } co_ifg_dump_t;
@@ -1127,10 +1128,11 @@ static FILE *my_open(const be_chordal_env_t *env, const char *prefix, const char
        char buf[1024];
        size_t i, n;
        char *tu_name;
+       const char *cup_name = be_get_irg_main_env(env->irg)->cup_name;
 
-       n = strlen(env->birg->main_env->cup_name);
+       n = strlen(cup_name);
        tu_name = XMALLOCN(char, n + 1);
-       strcpy(tu_name, env->birg->main_env->cup_name);
+       strcpy(tu_name, cup_name);
        for (i = 0; i < n; ++i)
                if (tu_name[i] == '.')
                        tu_name[i] = '_';