From b1675dbd664a6f1ac664bb902f8f7a5779761a1b Mon Sep 17 00:00:00 2001 From: Jan Hubicka Date: Tue, 13 Feb 2001 21:01:27 +0100 Subject: [PATCH] * i386.md (fixsfsi2, fixdfdi2): Fix previous patch. From-SVN: r39642 --- gcc/ChangeLog | 4 ++++ gcc/config/i386/i386.md | 12 ++++++++---- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1f99f980ed1..7876cc4b79d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +Tue Feb 13 20:59:22 CET 2001 Jan Hubicka + + * i386.md (fixsfsi2, fixdfdi2): Fix previous patch. + Tue Feb 13 16:32:20 CET 2001 Jan Hubicka * i386.md (fixsfsi2, fixdfdi2): Force operand to register diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md index 84c91e5a160..d9e79baeeca 100644 --- a/gcc/config/i386/i386.md +++ b/gcc/config/i386/i386.md @@ -4049,8 +4049,10 @@ { if (TARGET_SSE2) { - operands[0] = force_reg (SImode, operands[0]); - emit_insn (gen_fix_truncdfsi_sse (operands[0], operands[1])); + rtx out = force_reg (SImode, operands[0]); + emit_insn (gen_fix_truncdfsi_sse (out, operands[1])); + if (out != operands[0]) + emit_move_insn (operands[0], out); DONE; } else @@ -4071,8 +4073,10 @@ { if (TARGET_SSE2) { - operands[0] = force_reg (SImode, operands[0]); - emit_insn (gen_fix_truncsfsi_sse (operands[0], operands[1])); + rtx out = force_reg (SImode, operands[0]); + emit_insn (gen_fix_truncdfsi_sse (out, operands[1])); + if (out != operands[0]) + emit_move_insn (operands[0], out); DONE; } else -- 2.30.2