aboutsummaryrefslogtreecommitdiff
path: root/gcc/combine.c
diff options
context:
space:
mode:
authorBernd Schmidt <bernds@codesourcery.com>2010-08-25 14:08:23 +0000
committerBernd Schmidt <bernds@gcc.gnu.org>2010-08-25 14:08:23 +0000
commit4942fc569c5ba8ab9bebfad2d9cc9630a69c2579 (patch)
treefe6e7f63b8499ab943985671c66c74d84fb7f753 /gcc/combine.c
parent1cf01301ac5e4b5f1d128dbc735620fe01421f98 (diff)
downloadgcc-4942fc569c5ba8ab9bebfad2d9cc9630a69c2579.zip
gcc-4942fc569c5ba8ab9bebfad2d9cc9630a69c2579.tar.gz
gcc-4942fc569c5ba8ab9bebfad2d9cc9630a69c2579.tar.bz2
re PR middle-end/45355 (FAIL: gcc.c-torture/compile/pr43164.c)
PR middle-end/45355 * combine.c (try_combine): Use reg_overlap_mentioned_p rather than dead_or_set_p when computing i0_feeds_i2_n. From-SVN: r163546
Diffstat (limited to 'gcc/combine.c')
-rw-r--r--gcc/combine.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/combine.c b/gcc/combine.c
index 1f8e970..f144d1e 100644
--- a/gcc/combine.c
+++ b/gcc/combine.c
@@ -2862,7 +2862,7 @@ try_combine (rtx i3, rtx i2, rtx i1, rtx i0, int *new_direct_jump_p)
i1_feeds_i2_n = i1 && insn_a_feeds_b (i1, i2);
i0_feeds_i1_n = i0 && insn_a_feeds_b (i0, i1);
i0_feeds_i2_n = (i0 && (!i0_feeds_i1_n ? insn_a_feeds_b (i0, i2)
- : (!dead_or_set_p (i1, i0dest)
+ : (!reg_overlap_mentioned_p (i1dest, i0dest)
&& reg_overlap_mentioned_p (i0dest, i2src))));
/* Ensure that I3's pattern can be the destination of combines. */