diff options
author | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-09-02 16:38:46 +0000 |
---|---|---|
committer | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-09-02 16:38:46 +0000 |
commit | 740dc6f200c1d7150ed279a32dd8634c1a0f6823 (patch) | |
tree | e13f53eedbfc35d709913b15313275edf461ef35 /gcc/reload1.c | |
parent | be0dd0a3dbce669d1c12ca58553221ed2e63f0c6 (diff) | |
download | gcc-740dc6f200c1d7150ed279a32dd8634c1a0f6823.tar.gz |
* reload1.c (fixup_abnormal_edges): Allow NOTEs in the sequence.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@45358 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/reload1.c')
-rw-r--r-- | gcc/reload1.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/gcc/reload1.c b/gcc/reload1.c index bf66c00c51c..c4059810b04 100644 --- a/gcc/reload1.c +++ b/gcc/reload1.c @@ -9497,7 +9497,7 @@ fixup_abnormal_edges () } if (e && GET_CODE (bb->end) != CALL_INSN && !can_throw_internal (bb->end)) { - rtx insn = bb->end; + rtx insn = bb->end, stop = NEXT_INSN (bb->end); rtx next; for (e = bb->succ; e; e = e->succ_next) if (e->flags & EDGE_FALLTHRU) @@ -9513,11 +9513,14 @@ fixup_abnormal_edges () bb->end = insn; inserted = true; insn = NEXT_INSN (insn); - while (insn && GET_CODE (insn) == INSN) + while (insn && insn != stop) { next = NEXT_INSN (insn); - insert_insn_on_edge (PATTERN (insn), e); - flow_delete_insn (insn); + if (INSN_P (insn)) + { + insert_insn_on_edge (PATTERN (insn), e); + flow_delete_insn (insn); + } insn = next; } } |