]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR target/21716 (ICE in reg-stack.c's swap_rtx_condition)
authorJakub Jelinek <jakub@redhat.com>
Thu, 26 May 2005 09:05:04 +0000 (11:05 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Thu, 26 May 2005 09:05:04 +0000 (11:05 +0200)
PR target/21716
* reg-stack.c (swap_rtx_condition): Don't crash if %ax user was not
found in the basic block and last insn in the basic block is not
INSN_P.  Remove explicit unspec numbers that are no longer valid
from comments.

From-SVN: r100200

gcc/ChangeLog
gcc/reg-stack.c

index 3dc4aef291061ff2c2dbcdd1208d54654feb9509..016f62a619c264c91d4cc6c2e1487c0e1cca8950 100644 (file)
@@ -1,3 +1,11 @@
+2005-05-26  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/21716
+       * reg-stack.c (swap_rtx_condition): Don't crash if %ax user was not
+       found in the basic block and last insn in the basic block is not
+       INSN_P.  Remove explicit unspec numbers that are no longer valid
+       from comments.
+
 2005-05-25  Roger Sayle  <roger@eyesopen.com>
 
        PR middle-end/21709
index 0f284ac5c53cf6b6e144d8be0e21cbecf1e50926..84dc1d9495d299f5bf9c06901b1780faadaa9834 100644 (file)
@@ -1231,9 +1231,9 @@ swap_rtx_condition (rtx insn)
       pat = PATTERN (insn);
     }
 
-  /* See if this is, or ends in, a fnstsw, aka unspec 9.  If so, we're
-     not doing anything with the cc value right now.  We may be able to
-     search for one though.  */
+  /* See if this is, or ends in, a fnstsw.  If so, we're not doing anything
+     with the cc value right now.  We may be able to search for one
+     though.  */
 
   if (GET_CODE (pat) == SET
       && GET_CODE (SET_SRC (pat)) == UNSPEC
@@ -1252,9 +1252,13 @@ swap_rtx_condition (rtx insn)
            return 0;
        }
 
+      /* We haven't found it.  */
+      if (insn == BB_END (current_block))
+       return 0;
+
       /* So we've found the insn using this value.  If it is anything
-        other than sahf, aka unspec 10, or the value does not die
-        (meaning we'd have to search further), then we must give up.  */
+        other than sahf or the value does not die (meaning we'd have
+        to search further), then we must give up.  */
       pat = PATTERN (insn);
       if (GET_CODE (pat) != SET
          || GET_CODE (SET_SRC (pat)) != UNSPEC