mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-05 13:51:00 +08:00
expr.c (convert_move): Use emit_store_flag instead of "emulating" it.
2009-04-07 Paolo Bonzini <bonzini@gnu.org> * expr.c (convert_move): Use emit_store_flag instead of "emulating" it. From-SVN: r145666
This commit is contained in:
parent
67b8f1c149
commit
9a53bc17c4
@ -1,3 +1,8 @@
|
||||
2009-04-07 Paolo Bonzini <bonzini@gnu.org>
|
||||
|
||||
* expr.c (convert_move): Use emit_store_flag instead of
|
||||
"emulating" it.
|
||||
|
||||
2009-04-07 Paolo Bonzini <bonzini@gnu.org>
|
||||
|
||||
* config/i386/i386.c (ix86_compare_emitted): Remove.
|
||||
|
24
gcc/expr.c
24
gcc/expr.c
@ -588,27 +588,9 @@ convert_move (rtx to, rtx from, int unsignedp)
|
||||
if (unsignedp)
|
||||
fill_value = const0_rtx;
|
||||
else
|
||||
{
|
||||
#ifdef HAVE_slt
|
||||
if (HAVE_slt
|
||||
&& insn_data[(int) CODE_FOR_slt].operand[0].mode == word_mode
|
||||
&& STORE_FLAG_VALUE == -1)
|
||||
{
|
||||
emit_cmp_insn (lowfrom, const0_rtx, NE, NULL_RTX,
|
||||
lowpart_mode, 0);
|
||||
fill_value = gen_reg_rtx (word_mode);
|
||||
emit_insn (gen_slt (fill_value));
|
||||
}
|
||||
else
|
||||
#endif
|
||||
{
|
||||
fill_value
|
||||
= expand_shift (RSHIFT_EXPR, lowpart_mode, lowfrom,
|
||||
size_int (GET_MODE_BITSIZE (lowpart_mode) - 1),
|
||||
NULL_RTX, 0);
|
||||
fill_value = convert_to_mode (word_mode, fill_value, 1);
|
||||
}
|
||||
}
|
||||
fill_value = emit_store_flag (gen_reg_rtx (word_mode),
|
||||
LT, lowfrom, const0_rtx,
|
||||
VOIDmode, 0, -1);
|
||||
|
||||
/* Fill the remaining words. */
|
||||
for (i = GET_MODE_SIZE (lowpart_mode) / UNITS_PER_WORD; i < nwords; i++)
|
||||
|
Loading…
x
Reference in New Issue
Block a user