diff options
author | davem <davem@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-04-27 00:07:16 +0000 |
---|---|---|
committer | davem <davem@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-04-27 00:07:16 +0000 |
commit | 55427c62a8ae7021dea5047c21ee822bceac0d78 (patch) | |
tree | ee797cc837442e06493fadc89e7aa4beaf581294 /gcc/reorg.c | |
parent | 364730256d41b15e14dc2acc2c1362a161aa5547 (diff) | |
download | gcc-55427c62a8ae7021dea5047c21ee822bceac0d78.tar.gz |
2002-04-25 David S. Miller <davem@redhat.com>
PR target/6422
* reorg.c (optimize_skip): Do not allow exception causing
instructions to be considered for delay slots.
(fill_simply_delay_slots, fill_slots_from_thread): Likewise.
(relax_delay_slots): Do not try to consider exception causing
instructions as redundant.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@52822 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/reorg.c')
-rw-r--r-- | gcc/reorg.c | 29 |
1 files changed, 18 insertions, 11 deletions
diff --git a/gcc/reorg.c b/gcc/reorg.c index f4c484bcf71..659fc007590 100644 --- a/gcc/reorg.c +++ b/gcc/reorg.c @@ -750,7 +750,8 @@ optimize_skip (insn) || GET_CODE (PATTERN (trial)) == SEQUENCE || recog_memoized (trial) < 0 || (! eligible_for_annul_false (insn, 0, trial, flags) - && ! eligible_for_annul_true (insn, 0, trial, flags))) + && ! eligible_for_annul_true (insn, 0, trial, flags)) + || can_throw_internal (trial)) return 0; /* There are two cases where we are just executing one insn (we assume @@ -2127,7 +2128,8 @@ fill_simple_delay_slots (non_jumps_p) && GET_CODE (trial) == JUMP_INSN && simplejump_p (trial) && eligible_for_delay (insn, slots_filled, trial, flags) - && no_labels_between_p (insn, trial)) + && no_labels_between_p (insn, trial) + && ! can_throw_internal (trial)) { rtx *tmp; slots_filled++; @@ -2197,7 +2199,7 @@ fill_simple_delay_slots (non_jumps_p) /* Can't separate set of cc0 from its use. */ && ! (reg_mentioned_p (cc0_rtx, pat) && ! sets_cc0_p (pat)) #endif - ) + && ! can_throw_internal (trial)) { trial = try_split (pat, trial, 1); next_trial = prev_nonnote_insn (trial); @@ -2273,7 +2275,7 @@ fill_simple_delay_slots (non_jumps_p) Presumably, we should also check to see if we could get back to this function via `setjmp'. */ - && !can_throw_internal (insn) + && ! can_throw_internal (insn) && (GET_CODE (insn) != JUMP_INSN || ((condjump_p (insn) || condjump_in_parallel_p (insn)) && ! simplejump_p (insn) @@ -2340,7 +2342,8 @@ fill_simple_delay_slots (non_jumps_p) #endif && ! (maybe_never && may_trap_p (pat)) && (trial = try_split (pat, trial, 0)) - && eligible_for_delay (insn, slots_filled, trial, flags)) + && eligible_for_delay (insn, slots_filled, trial, flags) + && ! can_throw_internal(trial)) { next_trial = next_nonnote_insn (trial); delay_list = add_to_delay_list (trial, delay_list); @@ -2392,7 +2395,8 @@ fill_simple_delay_slots (non_jumps_p) #endif && ! (maybe_never && may_trap_p (PATTERN (next_trial))) && (next_trial = try_split (PATTERN (next_trial), next_trial, 0)) - && eligible_for_delay (insn, slots_filled, next_trial, flags)) + && eligible_for_delay (insn, slots_filled, next_trial, flags) + && ! can_throw_internal (trial)) { rtx new_label = next_active_insn (next_trial); @@ -2496,7 +2500,7 @@ fill_simple_delay_slots (non_jumps_p) /* Don't want to mess with cc0 here. */ && ! reg_mentioned_p (cc0_rtx, pat) #endif - ) + && ! can_throw_internal (trial)) { trial = try_split (pat, trial, 1); if (ELIGIBLE_FOR_EPILOGUE_DELAY (trial, slots_filled)) @@ -2637,7 +2641,7 @@ fill_slots_from_thread (insn, condition, thread, opposite_thread, likely, && ! (reg_mentioned_p (cc0_rtx, pat) && (! own_thread || ! sets_cc0_p (pat))) #endif - ) + && ! can_throw_internal (trial)) { rtx prior_insn; @@ -2874,8 +2878,10 @@ fill_slots_from_thread (insn, condition, thread, opposite_thread, likely, trial = new_thread; pat = PATTERN (trial); - if (GET_CODE (trial) != INSN || GET_CODE (pat) != SET - || ! eligible_for_delay (insn, 0, trial, flags)) + if (GET_CODE (trial) != INSN + || GET_CODE (pat) != SET + || ! eligible_for_delay (insn, 0, trial, flags) + || can_throw_internal (trial)) return 0; dest = SET_DEST (pat), src = SET_SRC (pat); @@ -3286,7 +3292,8 @@ relax_delay_slots (first) insn, redirect the jump to the following insn process again. */ trial = next_active_insn (target_label); if (trial && GET_CODE (PATTERN (trial)) != SEQUENCE - && redundant_insn (trial, insn, 0)) + && redundant_insn (trial, insn, 0) + && ! can_throw_internal (trial)) { rtx tmp; |