aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2001-02-13 21:01:27 +0100
committerJan Hubicka <hubicka@gcc.gnu.org>2001-02-13 20:01:27 +0000
commitb1675dbd664a6f1ac664bb902f8f7a5779761a1b (patch)
treeaae603d2c3ce3f585daef7613284d78e51792151 /gcc
parentf3b43865acd32bed18eb7316eb8f9916bf8bfc9e (diff)
downloadgcc-b1675dbd664a6f1ac664bb902f8f7a5779761a1b.zip
gcc-b1675dbd664a6f1ac664bb902f8f7a5779761a1b.tar.gz
gcc-b1675dbd664a6f1ac664bb902f8f7a5779761a1b.tar.bz2
* i386.md (fixsfsi2, fixdfdi2): Fix previous patch.
From-SVN: r39642
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/config/i386/i386.md12
2 files changed, 12 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 1f99f98..7876cc4 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+Tue Feb 13 20:59:22 CET 2001 Jan Hubicka <jh@suse.cz>
+
+ * i386.md (fixsfsi2, fixdfdi2): Fix previous patch.
+
Tue Feb 13 16:32:20 CET 2001 Jan Hubicka <jh@suse.cz>
* i386.md (fixsfsi2, fixdfdi2): Force operand to register
diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md
index 84c91e5..d9e79ba 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