]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
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 d781a13ff4b5c16160b268483e7417038db769d5..3ac3a3fb3a3ed07ebe6048609d6039489f30eb17 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 267c4691afcb4489c1eb940b8dd500f8bf3b7e15..a514d051113f539d06fb0d7eab6b24d8ef5c0f3b 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;
 }