aboutsummaryrefslogtreecommitdiff
path: root/gcc/gcse.c
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2004-01-28 15:13:35 +0100
committerJan Hubicka <hubicka@gcc.gnu.org>2004-01-28 14:13:35 +0000
commita544524ad3321ae5c51ae6d1499fc4363afb353d (patch)
tree7bd03b1e8d0b5de0cd5fbe0b566210a2be8be1fa /gcc/gcse.c
parent1b8f8174462a5cb4f09986979950e3d3759611d8 (diff)
downloadgcc-a544524ad3321ae5c51ae6d1499fc4363afb353d.zip
gcc-a544524ad3321ae5c51ae6d1499fc4363afb353d.tar.gz
gcc-a544524ad3321ae5c51ae6d1499fc4363afb353d.tar.bz2
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.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/gcc/gcse.c b/gcc/gcse.c
index 509d465..c2d7d5f 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