diff options
author | Jan Hubicka <jh@suse.cz> | 2004-01-28 15:13:35 +0100 |
---|---|---|
committer | Jan Hubicka <hubicka@gcc.gnu.org> | 2004-01-28 14:13:35 +0000 |
commit | a544524ad3321ae5c51ae6d1499fc4363afb353d (patch) | |
tree | 7bd03b1e8d0b5de0cd5fbe0b566210a2be8be1fa /gcc/gcse.c | |
parent | 1b8f8174462a5cb4f09986979950e3d3759611d8 (diff) | |
download | gcc-a544524ad3321ae5c51ae6d1499fc4363afb353d.tar.gz |
gcse.c (bypass_block): Prevent edges to be unified when we are about to emit compenstation code.
* gcse.c (bypass_block): Prevent edges to be unified when we are
about to emit compenstation code.
From-SVN: r76791
Diffstat (limited to 'gcc/gcse.c')
-rw-r--r-- | gcc/gcse.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/gcc/gcse.c b/gcc/gcse.c index 509d465b406..c2d7d5fb841 100644 --- a/gcc/gcse.c +++ b/gcc/gcse.c @@ -4874,6 +4874,21 @@ bypass_block (basic_block bb, rtx setcc, rtx jump) else dest = NULL; + /* Avoid unification of the edge with other edges from original + branch. We would end up emitting the instruction on "both" + edges. */ + + if (dest && setcc && !CC0_P (SET_DEST (pat))) + { + edge e2; + for (e2 = e->src->succ; e2; e2 = e2->succ_next) + if (e2->dest == dest) + { + dest = NULL; + break; + } + } + old_dest = e->dest; if (dest != NULL && dest != old_dest |