summaryrefslogtreecommitdiff
path: root/lib/Target/X86/X86InstrMMX.td
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2009-08-03 02:45:34 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2009-08-03 02:45:34 +0000
commitdef390a30aa8c3eb94796a062b161762330fdbe4 (patch)
tree3ef19bacf36cf203f7f78a4aeb024397ce332194 /lib/Target/X86/X86InstrMMX.td
parenta8e8984ee4c197634839cf228f5b1d79a77fa4b9 (diff)
downloadllvm-def390a30aa8c3eb94796a062b161762330fdbe4.tar.gz
llvm-def390a30aa8c3eb94796a062b161762330fdbe4.tar.bz2
llvm-def390a30aa8c3eb94796a062b161762330fdbe4.tar.xz
Use movq to move 64 bits in and out of mmx registers.
Fixes PR4669 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@77940 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86/X86InstrMMX.td')
-rw-r--r--lib/Target/X86/X86InstrMMX.td10
1 files changed, 7 insertions, 3 deletions
diff --git a/lib/Target/X86/X86InstrMMX.td b/lib/Target/X86/X86InstrMMX.td
index e7fea06d17..0033d837bb 100644
--- a/lib/Target/X86/X86InstrMMX.td
+++ b/lib/Target/X86/X86InstrMMX.td
@@ -163,10 +163,14 @@ def MMX_MOVD64to64rr : MMXRI<0x6E, MRMSrcReg, (outs VR64:$dst), (ins GR64:$src),
"movd\t{$src, $dst|$dst, $src}",
[]>;
-let neverHasSideEffects = 1 in
-def MMX_MOVD64from64rr : MMXRI<0x7E, MRMDestReg,
+let neverHasSideEffects = 1 in {
+def MMX_MOVD64from64rr : MMXRI<0x7F, MRMDestReg,
(outs GR64:$dst), (ins VR64:$src),
- "movd\t{$src, $dst|$dst, $src}", []>;
+ "movq\t{$src, $dst|$dst, $src}", []>;
+def MMX_MOVD64rrv164 : MMXI<0x6F, MRMSrcReg, (outs VR64:$dst), (ins GR64:$src),
+ "movq\t{$src, $dst|$dst, $src}",
+ [(set VR64:$dst, (v1i64 (scalar_to_vector GR64:$src)))]>;
+}
let neverHasSideEffects = 1 in
def MMX_MOVQ64rr : MMXI<0x6F, MRMSrcReg, (outs VR64:$dst), (ins VR64:$src),