fixed precedence constraint
[libfirm] / ir / be / bespillmorgan.c
index b321d80..a629a9f 100644 (file)
@@ -63,7 +63,7 @@ typedef struct loop_attr {
        bitset_t *livethrough_unused;
 } loop_attr_t;
 
-typedef struct block_attr {
+typedef struct morgan_block_attr {
        const ir_node *block;
        /** set of all values that are live in the block but not used in the block */
        bitset_t *livethrough_unused;
@@ -433,7 +433,7 @@ static void spill_values(morgan_env_t *env, const loop_attr_t *loop_attr, int sp
                DBG((dbg, DBG_CHOOSE, "Spilling %+F ", to_spill));
 
                for(edge = set_first(loop_attr->out_edges); edge != NULL; edge = set_next(loop_attr->out_edges)) {
-                       be_add_reload_on_edge(env->senv, to_spill, edge->block, edge->pos, env->cls);
+                       be_add_reload_on_edge(env->senv, to_spill, edge->block, edge->pos, env->cls, 1);
                }
        }
 }
@@ -603,15 +603,10 @@ void be_spill_morgan(be_irg_t *birg, const arch_register_class_t *cls) {
        obstack_free(&env.obst, NULL);
 }
 
-static void be_spill_morgan_oldinterface(const be_chordal_env_t *cenv)
-{
-       be_spill_morgan(cenv->birg, cenv->cls);
-}
-
 void be_init_spillmorgan(void)
 {
        static be_spiller_t morgan_spiller = {
-               be_spill_morgan_oldinterface
+               be_spill_morgan
        };
 
        be_register_spiller("morgan", &morgan_spiller);