diff options
author | hp <hp@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-11-24 22:15:54 +0000 |
---|---|---|
committer | hp <hp@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-11-24 22:15:54 +0000 |
commit | a8d1dae016ad1cbc9604e7b150190f69d46d0ca0 (patch) | |
tree | 7dc842093d9a325576f2a5371a5f79eaf8125394 /gcc/reorg.c | |
parent | 06ffe8d28c052b5b6a3f6683897c2b2d509f7b72 (diff) | |
download | gcc-a8d1dae016ad1cbc9604e7b150190f69d46d0ca0.tar.gz |
* rtlanal.c (label_is_jump_target_p): Return true for a matching
REG_LABEL_TARGET.
* reorg.c (fill_slots_from_thread): Correct last change to use
NULL_RTX, not NULL. Outside of REG_NOTES loop, increase and
decrease LABEL_NUSES for JUMP_LABEL (trial), not XEXP (note, 0).
* jump.c (mark_jump_label_1): Add comment for last change
regarding JUMP_LABEL setting.
* gcse.c (add_label_notes): Remove conditional that the label is
mentioned in insn before adding regnote.
* sched-rgn.c (is_cfg_nonregular): Don't return 1 for a
single_set insn only feeding a label to a jump through a
register that dies there.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@130398 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/reorg.c')
-rw-r--r-- | gcc/reorg.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/gcc/reorg.c b/gcc/reorg.c index 51acaa3d2af..985c118bc8c 100644 --- a/gcc/reorg.c +++ b/gcc/reorg.c @@ -2740,7 +2740,7 @@ fill_slots_from_thread (rtx insn, rtx condition, rtx thread, temporarily increment the use count on any referenced label lest it be deleted by delete_related_insns. */ for (note = REG_NOTES (trial); - note != NULL; + note != NULL_RTX; note = XEXP (note, 1)) if (REG_NOTE_KIND (note) == REG_LABEL_OPERAND || REG_NOTE_KIND (note) == REG_LABEL_TARGET) @@ -2754,12 +2754,12 @@ fill_slots_from_thread (rtx insn, rtx condition, rtx thread, == REG_LABEL_OPERAND); } if (JUMP_P (trial) && JUMP_LABEL (trial)) - LABEL_NUSES (XEXP (note, 0))++; + LABEL_NUSES (JUMP_LABEL (trial))++; delete_related_insns (trial); for (note = REG_NOTES (trial); - note != NULL; + note != NULL_RTX; note = XEXP (note, 1)) if (REG_NOTE_KIND (note) == REG_LABEL_OPERAND || REG_NOTE_KIND (note) == REG_LABEL_TARGET) @@ -2773,7 +2773,7 @@ fill_slots_from_thread (rtx insn, rtx condition, rtx thread, == REG_LABEL_OPERAND); } if (JUMP_P (trial) && JUMP_LABEL (trial)) - LABEL_NUSES (XEXP (note, 0))--; + LABEL_NUSES (JUMP_LABEL (trial))--; } else new_thread = next_active_insn (trial); |