diff options
author | Simon Pilgrim <llvm-dev@redking.me.uk> | 2022-11-13 14:13:30 +0300 |
---|---|---|
committer | Simon Pilgrim <llvm-dev@redking.me.uk> | 2022-11-13 14:13:30 +0300 |
commit | e19cb9c57fea7981c206fcbaf9807870de6001a0 (patch) | |
tree | 0f5ed90b68e85d2dd2e0dd948cd1dd04544600e6 | |
parent | 4e0d2f8e6f140573fbe527b65be99f3347b94155 (diff) |
[X86] Cleanup CVTPD2PS schedule values
The znver1/znver2 schedules for CVTPD2PS were incorrectly double pumping the xmm-load variant instead of the ymm variants (znver1 only)
Also, the xmm-load variant was incorrectly using FP03 instead of just FP3
Confirmed by the AMD SoG 17h tables, Agner + uops.info
Another step towards removing a lot of unnecessary overrides from all the x86 scheduler models - these should hopefully be convertible into regular WriteCvtPD2I classes soon.
-rw-r--r-- | llvm/lib/Target/X86/X86ScheduleZnver1.td | 8 | ||||
-rw-r--r-- | llvm/lib/Target/X86/X86ScheduleZnver2.td | 3 | ||||
-rw-r--r-- | llvm/test/tools/llvm-mca/X86/Znver1/resources-avx1.s | 18 | ||||
-rw-r--r-- | llvm/test/tools/llvm-mca/X86/Znver1/resources-sse2.s | 10 | ||||
-rw-r--r-- | llvm/test/tools/llvm-mca/X86/Znver2/resources-avx1.s | 10 | ||||
-rw-r--r-- | llvm/test/tools/llvm-mca/X86/Znver2/resources-sse2.s | 10 |
6 files changed, 30 insertions, 29 deletions
diff --git a/llvm/lib/Target/X86/X86ScheduleZnver1.td b/llvm/lib/Target/X86/X86ScheduleZnver1.td index 1185d5f5ca07..f8161a286015 100644 --- a/llvm/lib/Target/X86/X86ScheduleZnver1.td +++ b/llvm/lib/Target/X86/X86ScheduleZnver1.td @@ -1144,6 +1144,8 @@ def ZnWriteCVTPD2PSr: SchedWriteRes<[ZnFPU3]> { } def ZnWriteCVTPD2PSYr: SchedWriteRes<[ZnFPU3]> { let Latency = 5; + let NumMicroOps = 2; + let ResourceCycles = [2]; } // CVTPD2PS. @@ -1154,10 +1156,8 @@ def : SchedAlias<WriteCvtPD2PSY, ZnWriteCVTPD2PSYr>; // z,z. defm : X86WriteResUnsupported<WriteCvtPD2PSZ>; -def ZnWriteCVTPD2PSLd: SchedWriteRes<[ZnAGU,ZnFPU03]> { +def ZnWriteCVTPD2PSLd: SchedWriteRes<[ZnAGU,ZnFPU3]> { let Latency = 11; - let NumMicroOps = 2; - let ResourceCycles = [1,2]; } // x,m128. def : SchedAlias<WriteCvtPD2PSLd, ZnWriteCVTPD2PSLd>; @@ -1165,6 +1165,8 @@ def : SchedAlias<WriteCvtPD2PSLd, ZnWriteCVTPD2PSLd>; // x,m256. def ZnWriteCVTPD2PSYLd : SchedWriteRes<[ZnAGU, ZnFPU3]> { let Latency = 11; + let NumMicroOps = 2; + let ResourceCycles = [1,2]; } def : SchedAlias<WriteCvtPD2PSYLd, ZnWriteCVTPD2PSYLd>; // z,m512 diff --git a/llvm/lib/Target/X86/X86ScheduleZnver2.td b/llvm/lib/Target/X86/X86ScheduleZnver2.td index 87a953cef33a..cc0f0ec84060 100644 --- a/llvm/lib/Target/X86/X86ScheduleZnver2.td +++ b/llvm/lib/Target/X86/X86ScheduleZnver2.td @@ -1169,9 +1169,8 @@ def : SchedAlias<WriteCvtPD2PSY, Zn2WriteCVTPD2PSYr>; // z,z. defm : X86WriteResUnsupported<WriteCvtPD2PSZ>; -def Zn2WriteCVTPD2PSLd: SchedWriteRes<[Zn2AGU,Zn2FPU03]> { +def Zn2WriteCVTPD2PSLd: SchedWriteRes<[Zn2AGU,Zn2FPU3]> { let Latency = 10; - let NumMicroOps = 2; } // x,m128. def : SchedAlias<WriteCvtPD2PSLd, Zn2WriteCVTPD2PSLd>; diff --git a/llvm/test/tools/llvm-mca/X86/Znver1/resources-avx1.s b/llvm/test/tools/llvm-mca/X86/Znver1/resources-avx1.s index 7b1ac220e8b8..cfddb93e5d98 100644 --- a/llvm/test/tools/llvm-mca/X86/Znver1/resources-avx1.s +++ b/llvm/test/tools/llvm-mca/X86/Znver1/resources-avx1.s @@ -1127,9 +1127,9 @@ vzeroupper # CHECK-NEXT: 1 5 1.00 vcvtpd2dq %ymm0, %xmm2 # CHECK-NEXT: 2 12 1.00 * vcvtpd2dqy (%rax), %xmm2 # CHECK-NEXT: 1 4 1.00 vcvtpd2ps %xmm0, %xmm2 -# CHECK-NEXT: 2 11 1.00 * vcvtpd2psx (%rax), %xmm2 -# CHECK-NEXT: 1 5 1.00 vcvtpd2ps %ymm0, %xmm2 -# CHECK-NEXT: 1 11 1.00 * vcvtpd2psy (%rax), %xmm2 +# CHECK-NEXT: 1 11 1.00 * vcvtpd2psx (%rax), %xmm2 +# CHECK-NEXT: 2 5 2.00 vcvtpd2ps %ymm0, %xmm2 +# CHECK-NEXT: 2 11 2.00 * vcvtpd2psy (%rax), %xmm2 # CHECK-NEXT: 1 5 1.00 vcvtps2dq %xmm0, %xmm2 # CHECK-NEXT: 1 12 1.00 * vcvtps2dq (%rax), %xmm2 # CHECK-NEXT: 1 5 1.00 vcvtps2dq %ymm0, %ymm2 @@ -1143,7 +1143,7 @@ vzeroupper # CHECK-NEXT: 1 12 1.00 * vcvtsd2si (%rax), %ecx # CHECK-NEXT: 1 12 1.00 * vcvtsd2si (%rax), %rcx # CHECK-NEXT: 1 4 1.00 vcvtsd2ss %xmm0, %xmm1, %xmm2 -# CHECK-NEXT: 2 11 1.00 * vcvtsd2ss (%rax), %xmm1, %xmm2 +# CHECK-NEXT: 1 11 1.00 * vcvtsd2ss (%rax), %xmm1, %xmm2 # CHECK-NEXT: 1 5 1.00 vcvtsi2sd %ecx, %xmm0, %xmm2 # CHECK-NEXT: 1 5 1.00 vcvtsi2sd %rcx, %xmm0, %xmm2 # CHECK-NEXT: 1 12 1.00 * vcvtsi2sdl (%rax), %xmm0, %xmm2 @@ -1738,7 +1738,7 @@ vzeroupper # CHECK: Resource pressure per iteration: # CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] -# CHECK-NEXT: 175.00 175.00 - - - - - 146.25 227.25 223.75 313.75 - +# CHECK-NEXT: 175.00 175.00 - - - - - 144.25 227.25 223.75 315.75 - # CHECK: Resource pressure by instruction: # CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] Instructions: @@ -1839,9 +1839,9 @@ vzeroupper # CHECK-NEXT: - - - - - - - - 0.50 0.50 1.00 - vcvtpd2dq %ymm0, %xmm2 # CHECK-NEXT: 0.50 0.50 - - - - - - 0.50 0.50 1.00 - vcvtpd2dqy (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - 1.00 - vcvtpd2ps %xmm0, %xmm2 -# CHECK-NEXT: 0.50 0.50 - - - - - 1.00 - - 1.00 - vcvtpd2psx (%rax), %xmm2 -# CHECK-NEXT: - - - - - - - - - - 1.00 - vcvtpd2ps %ymm0, %xmm2 -# CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - vcvtpd2psy (%rax), %xmm2 +# CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - vcvtpd2psx (%rax), %xmm2 +# CHECK-NEXT: - - - - - - - - - - 2.00 - vcvtpd2ps %ymm0, %xmm2 +# CHECK-NEXT: 0.50 0.50 - - - - - - - - 2.00 - vcvtpd2psy (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - 1.00 - vcvtps2dq %xmm0, %xmm2 # CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - vcvtps2dq (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - 1.00 - vcvtps2dq %ymm0, %ymm2 @@ -1855,7 +1855,7 @@ vzeroupper # CHECK-NEXT: 0.50 0.50 - - - - - - - 1.00 1.00 - vcvtsd2si (%rax), %ecx # CHECK-NEXT: 0.50 0.50 - - - - - - - 1.00 1.00 - vcvtsd2si (%rax), %rcx # CHECK-NEXT: - - - - - - - - - - 1.00 - vcvtsd2ss %xmm0, %xmm1, %xmm2 -# CHECK-NEXT: 0.50 0.50 - - - - - 1.00 - - 1.00 - vcvtsd2ss (%rax), %xmm1, %xmm2 +# CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - vcvtsd2ss (%rax), %xmm1, %xmm2 # CHECK-NEXT: - - - - - - - 0.33 0.33 - 1.33 - vcvtsi2sd %ecx, %xmm0, %xmm2 # CHECK-NEXT: - - - - - - - 0.33 0.33 - 1.33 - vcvtsi2sd %rcx, %xmm0, %xmm2 # CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - vcvtsi2sdl (%rax), %xmm0, %xmm2 diff --git a/llvm/test/tools/llvm-mca/X86/Znver1/resources-sse2.s b/llvm/test/tools/llvm-mca/X86/Znver1/resources-sse2.s index c6bfe9a12137..d724bc8638c4 100644 --- a/llvm/test/tools/llvm-mca/X86/Znver1/resources-sse2.s +++ b/llvm/test/tools/llvm-mca/X86/Znver1/resources-sse2.s @@ -431,7 +431,7 @@ xorpd (%rax), %xmm2 # CHECK-NEXT: 1 4 1.00 cvtpd2pi %xmm0, %mm2 # CHECK-NEXT: 1 12 1.00 * cvtpd2pi (%rax), %mm2 # CHECK-NEXT: 1 4 1.00 cvtpd2ps %xmm0, %xmm2 -# CHECK-NEXT: 2 11 1.00 * cvtpd2ps (%rax), %xmm2 +# CHECK-NEXT: 1 11 1.00 * cvtpd2ps (%rax), %xmm2 # CHECK-NEXT: 1 3 1.00 cvtpi2pd %mm0, %xmm2 # CHECK-NEXT: 1 12 1.00 * cvtpi2pd (%rax), %xmm2 # CHECK-NEXT: 1 5 1.00 cvtps2dq %xmm0, %xmm2 @@ -443,7 +443,7 @@ xorpd (%rax), %xmm2 # CHECK-NEXT: 1 12 1.00 * cvtsd2si (%rax), %ecx # CHECK-NEXT: 1 12 1.00 * cvtsd2si (%rax), %rcx # CHECK-NEXT: 1 4 1.00 cvtsd2ss %xmm0, %xmm2 -# CHECK-NEXT: 2 11 1.00 * cvtsd2ss (%rax), %xmm2 +# CHECK-NEXT: 1 11 1.00 * cvtsd2ss (%rax), %xmm2 # CHECK-NEXT: 1 5 1.00 cvtsi2sd %ecx, %xmm2 # CHECK-NEXT: 1 5 1.00 cvtsi2sd %rcx, %xmm2 # CHECK-NEXT: 1 12 1.00 * cvtsi2sdl (%rax), %xmm2 @@ -691,7 +691,7 @@ xorpd (%rax), %xmm2 # CHECK: Resource pressure per iteration: # CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] -# CHECK-NEXT: 66.50 66.50 - - - - - 52.92 59.42 76.75 121.92 - +# CHECK-NEXT: 66.50 66.50 - - - - - 50.92 59.42 76.75 121.92 - # CHECK: Resource pressure by instruction: # CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] Instructions: @@ -719,7 +719,7 @@ xorpd (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - 1.00 - cvtpd2pi %xmm0, %mm2 # CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - cvtpd2pi (%rax), %mm2 # CHECK-NEXT: - - - - - - - - - - 1.00 - cvtpd2ps %xmm0, %xmm2 -# CHECK-NEXT: 0.50 0.50 - - - - - 1.00 - - 1.00 - cvtpd2ps (%rax), %xmm2 +# CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - cvtpd2ps (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - 1.00 - cvtpi2pd %mm0, %xmm2 # CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - cvtpi2pd (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - 1.00 - cvtps2dq %xmm0, %xmm2 @@ -731,7 +731,7 @@ xorpd (%rax), %xmm2 # CHECK-NEXT: 0.50 0.50 - - - - - - - 1.00 1.00 - cvtsd2si (%rax), %ecx # CHECK-NEXT: 0.50 0.50 - - - - - - - 1.00 1.00 - cvtsd2si (%rax), %rcx # CHECK-NEXT: - - - - - - - - - - 1.00 - cvtsd2ss %xmm0, %xmm2 -# CHECK-NEXT: 0.50 0.50 - - - - - 1.00 - - 1.00 - cvtsd2ss (%rax), %xmm2 +# CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - cvtsd2ss (%rax), %xmm2 # CHECK-NEXT: - - - - - - - 0.33 0.33 - 1.33 - cvtsi2sd %ecx, %xmm2 # CHECK-NEXT: - - - - - - - 0.33 0.33 - 1.33 - cvtsi2sd %rcx, %xmm2 # CHECK-NEXT: 0.50 0.50 - - - - - - - - 1.00 - cvtsi2sdl (%rax), %xmm2 diff --git a/llvm/test/tools/llvm-mca/X86/Znver2/resources-avx1.s b/llvm/test/tools/llvm-mca/X86/Znver2/resources-avx1.s index 7400d04b23a2..dac2f1fc0ea0 100644 --- a/llvm/test/tools/llvm-mca/X86/Znver2/resources-avx1.s +++ b/llvm/test/tools/llvm-mca/X86/Znver2/resources-avx1.s @@ -1127,7 +1127,7 @@ vzeroupper # CHECK-NEXT: 1 3 1.00 vcvtpd2dq %ymm0, %xmm2 # CHECK-NEXT: 2 10 1.00 * vcvtpd2dqy (%rax), %xmm2 # CHECK-NEXT: 1 3 1.00 vcvtpd2ps %xmm0, %xmm2 -# CHECK-NEXT: 2 10 0.50 * vcvtpd2psx (%rax), %xmm2 +# CHECK-NEXT: 1 10 1.00 * vcvtpd2psx (%rax), %xmm2 # CHECK-NEXT: 1 3 1.00 vcvtpd2ps %ymm0, %xmm2 # CHECK-NEXT: 1 10 1.00 * vcvtpd2psy (%rax), %xmm2 # CHECK-NEXT: 1 3 1.00 vcvtps2dq %xmm0, %xmm2 @@ -1143,7 +1143,7 @@ vzeroupper # CHECK-NEXT: 1 11 1.00 * vcvtsd2si (%rax), %ecx # CHECK-NEXT: 1 11 1.00 * vcvtsd2si (%rax), %rcx # CHECK-NEXT: 1 3 1.00 vcvtsd2ss %xmm0, %xmm1, %xmm2 -# CHECK-NEXT: 2 10 0.50 * vcvtsd2ss (%rax), %xmm1, %xmm2 +# CHECK-NEXT: 1 10 1.00 * vcvtsd2ss (%rax), %xmm1, %xmm2 # CHECK-NEXT: 1 3 1.00 vcvtsi2sd %ecx, %xmm0, %xmm2 # CHECK-NEXT: 1 3 1.00 vcvtsi2sd %rcx, %xmm0, %xmm2 # CHECK-NEXT: 1 12 1.00 * vcvtsi2sdl (%rax), %xmm0, %xmm2 @@ -1739,7 +1739,7 @@ vzeroupper # CHECK: Resource pressure per iteration: # CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] -# CHECK-NEXT: 117.00 117.00 117.00 0.25 0.25 0.25 0.25 - 127.58 192.58 196.75 304.08 - +# CHECK-NEXT: 117.00 117.00 117.00 0.25 0.25 0.25 0.25 - 126.58 192.58 196.75 305.08 - # CHECK: Resource pressure by instruction: # CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] Instructions: @@ -1840,7 +1840,7 @@ vzeroupper # CHECK-NEXT: - - - - - - - - - 0.50 0.50 1.00 - vcvtpd2dq %ymm0, %xmm2 # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - 0.50 0.50 1.00 - vcvtpd2dqy (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - - 1.00 - vcvtpd2ps %xmm0, %xmm2 -# CHECK-NEXT: 0.33 0.33 0.33 - - - - - 0.50 - - 0.50 - vcvtpd2psx (%rax), %xmm2 +# CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - vcvtpd2psx (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - - 1.00 - vcvtpd2ps %ymm0, %xmm2 # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - vcvtpd2psy (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - 0.50 0.50 1.00 - vcvtps2dq %xmm0, %xmm2 @@ -1856,7 +1856,7 @@ vzeroupper # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - 1.00 1.00 - vcvtsd2si (%rax), %ecx # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - 1.00 1.00 - vcvtsd2si (%rax), %rcx # CHECK-NEXT: - - - - - - - - - - - 1.00 - vcvtsd2ss %xmm0, %xmm1, %xmm2 -# CHECK-NEXT: 0.33 0.33 0.33 - - - - - 0.50 - - 0.50 - vcvtsd2ss (%rax), %xmm1, %xmm2 +# CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - vcvtsd2ss (%rax), %xmm1, %xmm2 # CHECK-NEXT: - - - - - - - - 0.33 0.33 - 1.33 - vcvtsi2sd %ecx, %xmm0, %xmm2 # CHECK-NEXT: - - - - - - - - 0.33 0.33 - 1.33 - vcvtsi2sd %rcx, %xmm0, %xmm2 # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - vcvtsi2sdl (%rax), %xmm0, %xmm2 diff --git a/llvm/test/tools/llvm-mca/X86/Znver2/resources-sse2.s b/llvm/test/tools/llvm-mca/X86/Znver2/resources-sse2.s index 9a465802f8b1..cd86c2c3c69e 100644 --- a/llvm/test/tools/llvm-mca/X86/Znver2/resources-sse2.s +++ b/llvm/test/tools/llvm-mca/X86/Znver2/resources-sse2.s @@ -431,7 +431,7 @@ xorpd (%rax), %xmm2 # CHECK-NEXT: 1 4 1.00 cvtpd2pi %xmm0, %mm2 # CHECK-NEXT: 1 12 1.00 * cvtpd2pi (%rax), %mm2 # CHECK-NEXT: 1 3 1.00 cvtpd2ps %xmm0, %xmm2 -# CHECK-NEXT: 2 10 0.50 * cvtpd2ps (%rax), %xmm2 +# CHECK-NEXT: 1 10 1.00 * cvtpd2ps (%rax), %xmm2 # CHECK-NEXT: 1 3 1.00 cvtpi2pd %mm0, %xmm2 # CHECK-NEXT: 1 12 1.00 * cvtpi2pd (%rax), %xmm2 # CHECK-NEXT: 1 3 1.00 cvtps2dq %xmm0, %xmm2 @@ -443,7 +443,7 @@ xorpd (%rax), %xmm2 # CHECK-NEXT: 1 11 1.00 * cvtsd2si (%rax), %ecx # CHECK-NEXT: 1 11 1.00 * cvtsd2si (%rax), %rcx # CHECK-NEXT: 1 3 1.00 cvtsd2ss %xmm0, %xmm2 -# CHECK-NEXT: 2 10 0.50 * cvtsd2ss (%rax), %xmm2 +# CHECK-NEXT: 1 10 1.00 * cvtsd2ss (%rax), %xmm2 # CHECK-NEXT: 1 3 1.00 cvtsi2sd %ecx, %xmm2 # CHECK-NEXT: 1 3 1.00 cvtsi2sd %rcx, %xmm2 # CHECK-NEXT: 1 12 1.00 * cvtsi2sdl (%rax), %xmm2 @@ -692,7 +692,7 @@ xorpd (%rax), %xmm2 # CHECK: Resource pressure per iteration: # CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] -# CHECK-NEXT: 44.33 44.33 44.33 - - - - - 51.92 60.92 78.25 132.92 - +# CHECK-NEXT: 44.33 44.33 44.33 - - - - - 50.92 60.92 78.25 133.92 - # CHECK: Resource pressure by instruction: # CHECK-NEXT: [0] [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] Instructions: @@ -720,7 +720,7 @@ xorpd (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - - 1.00 - cvtpd2pi %xmm0, %mm2 # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - cvtpd2pi (%rax), %mm2 # CHECK-NEXT: - - - - - - - - - - - 1.00 - cvtpd2ps %xmm0, %xmm2 -# CHECK-NEXT: 0.33 0.33 0.33 - - - - - 0.50 - - 0.50 - cvtpd2ps (%rax), %xmm2 +# CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - cvtpd2ps (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - - - 1.00 - cvtpi2pd %mm0, %xmm2 # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - cvtpi2pd (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - - 0.50 0.50 1.00 - cvtps2dq %xmm0, %xmm2 @@ -732,7 +732,7 @@ xorpd (%rax), %xmm2 # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - 1.00 1.00 - cvtsd2si (%rax), %ecx # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - 1.00 1.00 - cvtsd2si (%rax), %rcx # CHECK-NEXT: - - - - - - - - - - - 1.00 - cvtsd2ss %xmm0, %xmm2 -# CHECK-NEXT: 0.33 0.33 0.33 - - - - - 0.50 - - 0.50 - cvtsd2ss (%rax), %xmm2 +# CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - cvtsd2ss (%rax), %xmm2 # CHECK-NEXT: - - - - - - - - 0.33 0.33 - 1.33 - cvtsi2sd %ecx, %xmm2 # CHECK-NEXT: - - - - - - - - 0.33 0.33 - 1.33 - cvtsi2sd %rcx, %xmm2 # CHECK-NEXT: 0.33 0.33 0.33 - - - - - - - - 1.00 - cvtsi2sdl (%rax), %xmm2 |