* combine.c (distribute_notes): Don't add REG_LABEL to jump insn.
authorRoman Zippel <zippel@linux-m68k.org>
Thu, 2 Sep 2004 23:55:09 +0000 (23:55 +0000)
committerRichard Henderson <rth@gcc.gnu.org>
Thu, 2 Sep 2004 23:55:09 +0000 (16:55 -0700)
From-SVN: r87002

gcc/ChangeLog
gcc/combine.c

index b6e3cb29d882d562694bbcc68d177c51e246fee5..758a33ac9b979e9dd0824ba5bf027d4d95720af2 100644 (file)
@@ -1,3 +1,7 @@
+2004-09-02  Roman Zippel  <zippel@linux-m68k.org>
+       * combine.c (distribute_notes): Don't add REG_LABEL to jump insn.
+
 2004-09-02  Eric Christopher  <echristo@redhat.com>
 
        * builtins.c (expand_builtin_cabs): Delete.
index 4bd1555b1eda89cd7a5d9b418609b269ab5f0466..be1a08c2d66f9d649f639aae8542cba3c0d61a2e 100644 (file)
@@ -11839,21 +11839,25 @@ distribute_notes (rtx notes, rtx from_insn, rtx i3, rtx i2)
                place = i2;
            }
 
-         /* Don't attach REG_LABEL note to a JUMP_INSN which has
-            JUMP_LABEL already.  Instead, decrement LABEL_NUSES.  */
-         if (place && JUMP_P (place) && JUMP_LABEL (place))
+         /* Don't attach REG_LABEL note to a JUMP_INSN.  Add
+            a JUMP_LABEL instead or decrement LABEL_NUSES.  */
+         if (place && JUMP_P (place))
            {
-             if (JUMP_LABEL (place) != XEXP (note, 0))
+             if (!JUMP_LABEL (place))
+               JUMP_LABEL (place) = XEXP (note, 0);
+             else if (JUMP_LABEL (place) != XEXP (note, 0))
                abort ();
-             if (LABEL_P (JUMP_LABEL (place)))
+             else if (LABEL_P (JUMP_LABEL (place)))
                LABEL_NUSES (JUMP_LABEL (place))--;
              place = 0;
            }
-         if (place2 && JUMP_P (place2) && JUMP_LABEL (place2))
+         if (place2 && JUMP_P (place2))
            {
-             if (JUMP_LABEL (place2) != XEXP (note, 0))
+             if (!JUMP_LABEL (place2))
+               JUMP_LABEL (place2) = XEXP (note, 0);
+             else if (JUMP_LABEL (place2) != XEXP (note, 0))
                abort ();
-             if (LABEL_P (JUMP_LABEL (place2)))
+             else if (LABEL_P (JUMP_LABEL (place2)))
                LABEL_NUSES (JUMP_LABEL (place2))--;
              place2 = 0;
            }