fehler109
[libfirm] / ir / be / beflags.c
index 2c8f679..1adde1a 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1995-2007 University of Karlsruhe.  All right reserved.
+ * Copyright (C) 1995-2008 University of Karlsruhe.  All right reserved.
  *
  * This file is part of libFirm.
  *
@@ -201,7 +201,7 @@ static void fix_flags_walker(ir_node *block, void *env)
        ir_node *node;
        ir_node *flags_needed   = NULL;
        ir_node *flag_consumers = NULL;
-       int      pn;
+       int      pn = -1;
        (void) env;
 
        sched_foreach_reverse(block, node) {
@@ -217,7 +217,7 @@ static void fix_flags_walker(ir_node *block, void *env)
                        flag_consumers = NULL;
                }
 
-               /* test wether node destroys the flags */
+               /* test whether node destroys the flags */
                if(flags_needed != NULL && is_modify_flags(node)) {
                        /* rematerialize */
                        rematerialize_or_move(flags_needed, node, flag_consumers, pn);
@@ -225,10 +225,9 @@ static void fix_flags_walker(ir_node *block, void *env)
                        flag_consumers = NULL;
                }
 
-               /* test wether the current node needs flags */
+               /* test whether the current node needs flags */
                arity = get_irn_arity(node);
                for(i = 0; i < arity; ++i) {
-                       //ir_node *in = get_irn_n(node, i);
                        const arch_register_class_t *cls
                                = arch_get_irn_reg_class(arch_env, node, i);
                        if(cls == flag_class) {
@@ -242,7 +241,8 @@ static void fix_flags_walker(ir_node *block, void *env)
 
                /* spiller can't (correctly) remat flag consumers at the moment */
                assert(!arch_irn_is(arch_env, node, rematerializable));
-               if(new_flags_needed != flags_needed) {
+
+               if(skip_Proj(new_flags_needed) != flags_needed) {
                        if(flags_needed != NULL) {
                                /* rematerialize node */
                                rematerialize_or_move(flags_needed, node, flag_consumers, pn);
@@ -251,7 +251,7 @@ static void fix_flags_walker(ir_node *block, void *env)
                        }
 
                        flags_needed = new_flags_needed;
-                                       arch_set_irn_register(arch_env, flags_needed, flags_reg);
+                       arch_set_irn_register(arch_env, flags_needed, flags_reg);
                        if(is_Proj(flags_needed)) {
                                pn           = get_Proj_proj(flags_needed);
                                flags_needed = get_Proj_pred(flags_needed);