Commit 49fa02d9 by H.J. Lu Committed by Jeff Law

reg-stack.c (subst_stack_regs_pat): Make sure the top of stack is the…

reg-stack.c (subst_stack_regs_pat): Make sure the top of stack is the destination for conditional move insn.

        * reg-stack.c (subst_stack_regs_pat): Make sure the top of
        stack is the destination for conditional move insn.

From-SVN: r20324
parent 52267fcb
Mon Jun 8 02:49:23 1998 H.J. Lu (hjl@gnu.org)
* reg-stack.c (subst_stack_regs_pat): Make sure the top of
stack is the destination for conditional move insn.
Mon Jun 8 01:21:13 1998 Jason Merrill <jason@yorick.cygnus.com> Mon Jun 8 01:21:13 1998 Jason Merrill <jason@yorick.cygnus.com>
* tree.h (TREE_VEC_END): Cast unused value to void. * tree.h (TREE_VEC_END): Cast unused value to void.
......
...@@ -2344,6 +2344,15 @@ subst_stack_regs_pat (insn, regstack, pat) ...@@ -2344,6 +2344,15 @@ subst_stack_regs_pat (insn, regstack, pat)
case IF_THEN_ELSE: case IF_THEN_ELSE:
/* This insn requires the top of stack to be the destination. */ /* This insn requires the top of stack to be the destination. */
/* If the comparison operator is an FP comparison operator,
it is handled correctly by compare_for_stack_reg () who
will move the destination to the top of stack. But if the
comparison operator is not an FP comparison operator, we
have to handle it here. */
if (get_hard_regnum (regstack, *dest) >= FIRST_STACK_REG
&& REGNO (*dest) != regstack->reg[regstack->top])
emit_swap_insn (insn, regstack, *dest);
src1 = get_true_reg (&XEXP (SET_SRC (pat), 1)); src1 = get_true_reg (&XEXP (SET_SRC (pat), 1));
src2 = get_true_reg (&XEXP (SET_SRC (pat), 2)); src2 = get_true_reg (&XEXP (SET_SRC (pat), 2));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment