OSDN Git Service

* loop-invariant.c (move_loop_invariants): Fix a thinko in the
authorsteven <steven@138bc75d-0d04-0410-961f-82ee72b054a4>
Sat, 12 Nov 2005 00:09:48 +0000 (00:09 +0000)
committersteven <steven@138bc75d-0d04-0410-961f-82ee72b054a4>
Sat, 12 Nov 2005 00:09:48 +0000 (00:09 +0000)
previous checkin.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@106809 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/loop-invariant.c

index 5a7d54f..2851015 100644 (file)
@@ -1,3 +1,8 @@
+2005-11-11  Steven Bosscher  <stevenb@suse.de>
+
+       * loop-invariant.c (move_loop_invariants): Fix a thinko in the
+       previous checkin.
+
 2005-11-11  Daniel Jacobowitz  <dan@codesourcery.com>
 
        * tree-ssa-dse.c (struct address_walk_data, memory_ssa_name_same)
index dc35ace..a909e64 100644 (file)
@@ -796,9 +796,22 @@ move_invariant_reg (struct loop *loop, unsigned invno, struct df *df)
   reg = gen_reg_rtx (GET_MODE (SET_DEST (set)));
   df_pattern_emit_after (df, gen_move_insn (SET_DEST (set), reg),
                         BLOCK_FOR_INSN (inv->insn), inv->insn);
-  df_pattern_emit_after (df, gen_move_insn (reg, SET_SRC (set)),
-                        preheader, BB_END (preheader));
-  df_insn_delete (df, BLOCK_FOR_INSN (inv->insn), inv->insn);
+
+  /* If the SET_DEST of the invariant insn is a reg, we can just move
+     the insn out of the loop.  Otherwise, we have to use gen_move_insn
+     to let emit_move_insn produce a valid instruction stream.  */
+  if (REG_P (SET_DEST (set)))
+    {
+      SET_DEST (set) = reg;
+      reorder_insns (inv->insn, inv->insn, BB_END (preheader));
+      df_insn_modify (df, preheader, inv->insn);
+    }
+  else
+    {
+      df_pattern_emit_after (df, gen_move_insn (reg, SET_SRC (set)),
+                            preheader, BB_END (preheader));
+      df_insn_delete (df, BLOCK_FOR_INSN (inv->insn), inv->insn);
+    }
 
   /* Replace the uses we know to be dominated.  It saves work for copy
      propagation, and also it is necessary so that dependent invariants