summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@intel.com>2018-03-26 02:17:13 +0000
committerCraig Topper <craig.topper@intel.com>2018-03-26 02:17:13 +0000
commit659f85af144d076f650972b02fd3314b08eec036 (patch)
treedc599d5a738e3dd5468ffbbf8b9ae51de6ebc7b7
parent4bf23eddafe47b7fe55b294844b4503f81022e03 (diff)
downloadbcm5719-llvm-659f85af144d076f650972b02fd3314b08eec036.tar.gz
bcm5719-llvm-659f85af144d076f650972b02fd3314b08eec036.zip
[X86] Swap the itineraries on the memory and register forms of CVTDQ2PD.
They were backwards. llvm-svn: 328469
-rw-r--r--llvm/lib/Target/X86/X86InstrSSE.td4
-rw-r--r--llvm/test/CodeGen/X86/sse2-schedule.ll7
2 files changed, 6 insertions, 5 deletions
diff --git a/llvm/lib/Target/X86/X86InstrSSE.td b/llvm/lib/Target/X86/X86InstrSSE.td
index 2ec2f902750..99915e7c00a 100644
--- a/llvm/lib/Target/X86/X86InstrSSE.td
+++ b/llvm/lib/Target/X86/X86InstrSSE.td
@@ -2040,12 +2040,12 @@ def CVTDQ2PDrm : S2SI<0xE6, MRMSrcMem, (outs VR128:$dst), (ins i64mem:$src),
"cvtdq2pd\t{$src, $dst|$dst, $src}",
[(set VR128:$dst,
(v2f64 (X86VSintToFP (bc_v4i32 (loadv2i64 addr:$src)))))],
- IIC_SSE_CVT_PD_RR>, Sched<[WriteCvtI2FLd]>;
+ IIC_SSE_CVT_PD_RM>, Sched<[WriteCvtI2FLd]>;
def CVTDQ2PDrr : S2SI<0xE6, MRMSrcReg, (outs VR128:$dst), (ins VR128:$src),
"cvtdq2pd\t{$src, $dst|$dst, $src}",
[(set VR128:$dst,
(v2f64 (X86VSintToFP (v4i32 VR128:$src))))],
- IIC_SSE_CVT_PD_RM>, Sched<[WriteCvtI2F]>;
+ IIC_SSE_CVT_PD_RR>, Sched<[WriteCvtI2F]>;
// AVX register conversion intrinsics
let Predicates = [HasAVX, NoVLX] in {
diff --git a/llvm/test/CodeGen/X86/sse2-schedule.ll b/llvm/test/CodeGen/X86/sse2-schedule.ll
index db6d7a5c198..7174b8709a4 100644
--- a/llvm/test/CodeGen/X86/sse2-schedule.ll
+++ b/llvm/test/CodeGen/X86/sse2-schedule.ll
@@ -1090,9 +1090,10 @@ define <2 x double> @test_cvtdq2pd(<4 x i32> %a0, <4 x i32> *%a1) {
;
; ATOM-LABEL: test_cvtdq2pd:
; ATOM: # %bb.0:
-; ATOM-NEXT: cvtdq2pd %xmm0, %xmm1 # sched: [8:4.00]
-; ATOM-NEXT: cvtdq2pd (%rdi), %xmm0 # sched: [7:3.50]
-; ATOM-NEXT: addpd %xmm1, %xmm0 # sched: [6:3.00]
+; ATOM-NEXT: cvtdq2pd (%rdi), %xmm1 # sched: [8:4.00]
+; ATOM-NEXT: cvtdq2pd %xmm0, %xmm0 # sched: [7:3.50]
+; ATOM-NEXT: addpd %xmm0, %xmm1 # sched: [6:3.00]
+; ATOM-NEXT: movapd %xmm1, %xmm0 # sched: [1:0.50]
; ATOM-NEXT: retq # sched: [79:39.50]
;
; SLM-LABEL: test_cvtdq2pd:
OpenPOWER on IntegriCloud