Fix consec_sets_giv bug.
authorBernd Schmidt <bernds@redhat.co.uk>
Tue, 21 Nov 2000 18:24:42 +0000 (18:24 +0000)
committerBernd Schmidt <bernds@gcc.gnu.org>
Tue, 21 Nov 2000 18:24:42 +0000 (18:24 +0000)
From-SVN: r37619

gcc/ChangeLog
gcc/loop.c

index d781a13..3ac3a3f 100644 (file)
@@ -1,5 +1,9 @@
 2000-11-21  Bernd Schmidt  <bernds@redhat.co.uk>
 
+       * loop.c (consec_sets_giv): If the reg we're examining is anything
+       but UNKNOWN_INDUCT, do nothing.
+       Reset the reg's type to UNKNOWN_INDUCT before returning.
+
        Mostly from Vladimir Makarov (vmakarov@redhat.com)
        * ia64.md (attr itanium_class): Define insn types as described in
        Itanium docs.
index 267c469..a514d05 100644 (file)
@@ -6203,8 +6203,12 @@ consec_sets_giv (loop, first_benefit, p, src_reg, dest_reg,
      general_induction_var below, so we can allocate it on our stack.
      If this is a giv, our caller will replace the induct var entry with
      a new induction structure.  */
-  struct induction *v
-    = (struct induction *) alloca (sizeof (struct induction));
+  struct induction *v;
+
+  if (REG_IV_TYPE (ivs, REGNO (dest_reg)) != UNKNOWN_INDUCT)
+    return 0;
+
+  v = (struct induction *) alloca (sizeof (struct induction));
   v->src_reg = src_reg;
   v->mult_val = *mult_val;
   v->add_val = *add_val;
@@ -6265,6 +6269,7 @@ consec_sets_giv (loop, first_benefit, p, src_reg, dest_reg,
        }
     }
 
+  REG_IV_TYPE (ivs, REGNO (dest_reg)) = UNKNOWN_INDUCT;
   *last_consec_insn = p;
   return v->benefit;
 }