OSDN Git Service

* reorg.c (fill_simple_delay_slots): Use stop_search_p to stop the
authorebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 27 Jun 2011 12:59:56 +0000 (12:59 +0000)
committerebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 27 Jun 2011 12:59:56 +0000 (12:59 +0000)
forward scan as well.

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

gcc/ChangeLog
gcc/reorg.c

index 2e1bc76..ff7fe68 100644 (file)
@@ -1,3 +1,8 @@
+2011-06-27  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * reorg.c (fill_simple_delay_slots): Use stop_search_p to stop the
+       forward scan as well.
+
 2011-06-27  Tristan Gingold  <gingold@adacore.com>
 
        PR target/44241
index 28b6c7d..4df9105 100644 (file)
@@ -2152,7 +2152,7 @@ fill_simple_delay_slots (int non_jumps_p)
              /* This must be an INSN or CALL_INSN.  */
              pat = PATTERN (trial);
 
-             /* USE and CLOBBER at this level was just for flow; ignore it.  */
+             /* Stand-alone USE and CLOBBER are just for flow.  */
              if (GET_CODE (pat) == USE || GET_CODE (pat) == CLOBBER)
                continue;
 
@@ -2271,15 +2271,12 @@ fill_simple_delay_slots (int non_jumps_p)
            }
 
          if (target == 0)
-           for (trial = next_nonnote_insn (insn); trial; trial = next_trial)
+           for (trial = next_nonnote_insn (insn); !stop_search_p (trial, 1);
+                trial = next_trial)
              {
                next_trial = next_nonnote_insn (trial);
 
-               if (LABEL_P (trial)
-                   || BARRIER_P (trial))
-                 break;
-
-               /* We must have an INSN, JUMP_INSN, or CALL_INSN.  */
+               /* This must be an INSN or CALL_INSN.  */
                pat = PATTERN (trial);
 
                /* Stand-alone USE and CLOBBER are just for flow.  */
@@ -2293,7 +2290,7 @@ fill_simple_delay_slots (int non_jumps_p)
                else
                  trial_delay = trial;
 
-               /* Stop our search when seeing an unconditional jump.  */
+               /* Stop our search when seeing a jump.  */
                if (JUMP_P (trial_delay))
                  break;