aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeff Law <law@gcc.gnu.org>1997-12-22 01:55:49 -0700
committerJeff Law <law@gcc.gnu.org>1997-12-22 01:55:49 -0700
commit04029ca2457cdda7ac485532588705a219b2f980 (patch)
tree1adccd06465441c3df1e33d4d90f4aa01b6071f5
parent1d88b804fba46e810605ca44dd51a709cfe90c34 (diff)
downloadgcc-04029ca2457cdda7ac485532588705a219b2f980.zip
gcc-04029ca2457cdda7ac485532588705a219b2f980.tar.gz
gcc-04029ca2457cdda7ac485532588705a219b2f980.tar.bz2
haifa-sched.c (create_reg_dead_note): Detect and handle another case where we kill more regs after sched than were...
* haifa-sched.c (create_reg_dead_note): Detect and handle another case where we kill more regs after sched than were killed before sched. * sched.c (create_reg_dead_note): Similarly. From-SVN: r17183
-rw-r--r--gcc/haifa-sched.c17
-rw-r--r--gcc/sched.c6
2 files changed, 23 insertions, 0 deletions
diff --git a/gcc/haifa-sched.c b/gcc/haifa-sched.c
index b2545a2..02350e1 100644
--- a/gcc/haifa-sched.c
+++ b/gcc/haifa-sched.c
@@ -4467,6 +4467,23 @@ create_reg_dead_note (reg, insn)
while (reg_note_regs < regs_killed)
{
link = XEXP (link, 1);
+
+ /* LINK might be zero if we killed more registers after scheduling
+ than before, and the last hard register we kill is actually
+ multiple hard regs.
+
+ This is normal for interblock scheduling, so deal with it in
+ that case, else abort. */
+ if (link == NULL_RTX && current_nr_blocks <= 1)
+ abort ();
+ else if (link == NULL_RTX)
+ {
+ link = rtx_alloc (EXPR_LIST);
+ PUT_REG_NOTE_KIND (link, REG_DEAD);
+ XEXP (link, 0) = gen_rtx (REG, word_mode, 0);
+ XEXP (link, 1) = NULL_RTX;
+ }
+
reg_note_regs += (REGNO (XEXP (link, 0)) >= FIRST_PSEUDO_REGISTER ? 1
: HARD_REGNO_NREGS (REGNO (XEXP (link, 0)),
GET_MODE (XEXP (link, 0))));
diff --git a/gcc/sched.c b/gcc/sched.c
index b7aa75d..64b785f 100644
--- a/gcc/sched.c
+++ b/gcc/sched.c
@@ -2218,6 +2218,12 @@ create_reg_dead_note (reg, insn)
GET_MODE (XEXP (link, 0))));
while (reg_note_regs < regs_killed)
{
+ /* LINK might be zero if we killed more registers after scheduling
+ than before, and the last hard register we kill is actually
+ multiple hard regs. */
+ if (link == NULL_RTX)
+ abort ();
+
link = XEXP (link, 1);
reg_note_regs += (REGNO (XEXP (link, 0)) >= FIRST_PSEUDO_REGISTER ? 1
: HARD_REGNO_NREGS (REGNO (XEXP (link, 0)),