aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/gcse.c26
2 files changed, 10 insertions, 20 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 5ecb07a..43c2417 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+2003-02-25 Kazu Hirata <kazu@cs.umass.edu>
+
+ * gcse.c (cprop_jump): Revert the 2003-02-23 change.
+
2003-02-25 Vladimir Makarov <vmakarov@toke.toronto.redhat.com>
Richard Henderson <rth@redhat.com>
diff --git a/gcc/gcse.c b/gcc/gcse.c
index 27dcc71..f5bb66d 100644
--- a/gcc/gcse.c
+++ b/gcc/gcse.c
@@ -4058,33 +4058,19 @@ cprop_jump (bb, setcc, jump, from, src)
&& !modified_between_p (src, setcc, jump))
{
rtx setcc_set = single_set (setcc);
- rtx note = find_reg_equal_equiv_note (setcc);
- /* Use REG_EQUAL note if available. */
- rtx setcc_set_src = (note == 0) ? SET_SRC (setcc_set) : XEXP (note, 0);
-
new_set = simplify_replace_rtx (SET_SRC (set),
SET_DEST (setcc_set),
- setcc_set_src);
+ SET_SRC (setcc_set));
}
else
new_set = set;
- /* If NEW_SET is simplified down to either a label or a no-op, we
- don't have to replace FROM with SRC, but we still have to either
- turn JUMP to an unconditional branch or remove the no-op. This
- can happen if JUMP is simplified using the REG_EQUAL note in
- SETCC. */
- if (GET_CODE (new_set) == LABEL_REF || new_set == pc_rtx)
- new = new_set;
- else
- {
- new = simplify_replace_rtx (new_set, from, src);
+ new = simplify_replace_rtx (new_set, from, src);
- /* If no simplification can be made, then try the next
- register. */
- if (rtx_equal_p (new, new_set) || rtx_equal_p (new, SET_SRC (set)))
- return 0;
- }
+ /* If no simplification can be made, then try the next
+ register. */
+ if (rtx_equal_p (new, new_set) || rtx_equal_p (new, SET_SRC (set)))
+ return 0;
/* If this is now a no-op delete it, otherwise this must be a valid insn. */
if (new == pc_rtx)