aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrey Belevantsev <abel@ispras.ru>2019-03-18 10:51:06 +0300
committerAndrey Belevantsev <abel@gcc.gnu.org>2019-03-18 10:51:06 +0300
commit4e3f3c46d716eda472f6bcb6918b3ab69d981328 (patch)
treecfc7a2f92be6bd6b1ba9a60456d43f21cbe896a0
parent7e703f019b351ceb6c68da23bde1e1754746e1f2 (diff)
downloadgcc-4e3f3c46d716eda472f6bcb6918b3ab69d981328.zip
gcc-4e3f3c46d716eda472f6bcb6918b3ab69d981328.tar.gz
gcc-4e3f3c46d716eda472f6bcb6918b3ab69d981328.tar.bz2
re PR rtl-optimization/89676 (Redundant moves for long long shift on 32bit x86)
PR middle-end/89676 * sel-sched.c (compute_av_set_at_bb_end): When we have an ineligible successor, use NULL as its av set. From-SVN: r269751
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/sel-sched.c6
2 files changed, 10 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 67dc0bf..b66cb5d 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2019-03-18 Andrey Belevantsev <abel@ispras.ru>
+
+ PR middle-end/89676
+ * sel-sched.c (compute_av_set_at_bb_end): When we have an ineligible
+ successor, use NULL as its av set.
+
2019-03-15 Segher Boessenkool <segher@kernel.crashing.org>
PR rtl-optimization/89721
diff --git a/gcc/sel-sched.c b/gcc/sel-sched.c
index 315f2c0..338d7c0 100644
--- a/gcc/sel-sched.c
+++ b/gcc/sel-sched.c
@@ -2820,10 +2820,12 @@ compute_av_set_at_bb_end (insn_t insn, ilist_t p, int ws)
FOR_EACH_VEC_ELT (sinfo->succs_ok, is, succ)
{
basic_block succ_bb = BLOCK_FOR_INSN (succ);
+ av_set_t av_succ = (is_ineligible_successor (succ, p)
+ ? NULL
+ : BB_AV_SET (succ_bb));
gcc_assert (BB_LV_SET_VALID_P (succ_bb));
- mark_unavailable_targets (av1, BB_AV_SET (succ_bb),
- BB_LV_SET (succ_bb));
+ mark_unavailable_targets (av1, av_succ, BB_LV_SET (succ_bb));
}
/* Finally, check liveness restrictions on paths leaving the region. */