diff options
author | Craig Topper <craig.topper@intel.com> | 2017-11-11 21:44:47 +0000 |
---|---|---|
committer | Craig Topper <craig.topper@intel.com> | 2017-11-11 21:44:47 +0000 |
commit | 1a20db210835c3e4b3b1b3c8d8ca93ea2bc77c55 (patch) | |
tree | fb6596cca94fd82def1567ef3b396b536d207f82 | |
parent | 3495440e45a2ce30414c457e12446c5bb5362fbc (diff) | |
download | bcm5719-llvm-1a20db210835c3e4b3b1b3c8d8ca93ea2bc77c55.tar.gz bcm5719-llvm-1a20db210835c3e4b3b1b3c8d8ca93ea2bc77c55.zip |
[X86] Regenerate rounding-ops.ll with update_llc_test_checks.py
llvm-svn: 317987
-rw-r--r-- | llvm/test/CodeGen/X86/rounding-ops.ll | 151 |
1 files changed, 91 insertions, 60 deletions
diff --git a/llvm/test/CodeGen/X86/rounding-ops.ll b/llvm/test/CodeGen/X86/rounding-ops.ll index 15a11d1d6a9..b920be4c887 100644 --- a/llvm/test/CodeGen/X86/rounding-ops.ll +++ b/llvm/test/CodeGen/X86/rounding-ops.ll @@ -1,132 +1,163 @@ +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc < %s -mtriple=x86_64-apple-macosx -mattr=+sse4.1 | FileCheck -check-prefix=CHECK-SSE %s ; RUN: llc < %s -mtriple=x86_64-apple-macosx -mattr=+avx | FileCheck -check-prefix=CHECK-AVX %s define float @test1(float %x) nounwind { - %call = tail call float @floorf(float %x) nounwind readnone - ret float %call - ; CHECK-SSE-LABEL: test1: -; CHECK-SSE: roundss $9 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundss $9, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test1: -; CHECK-AVX: vroundss $9 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundss $9, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call float @floorf(float %x) nounwind readnone + ret float %call } declare float @floorf(float) nounwind readnone define double @test2(double %x) nounwind { - %call = tail call double @floor(double %x) nounwind readnone - ret double %call - ; CHECK-SSE-LABEL: test2: -; CHECK-SSE: roundsd $9 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundsd $9, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test2: -; CHECK-AVX: vroundsd $9 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundsd $9, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call double @floor(double %x) nounwind readnone + ret double %call } declare double @floor(double) nounwind readnone define float @test3(float %x) nounwind { - %call = tail call float @nearbyintf(float %x) nounwind readnone - ret float %call - ; CHECK-SSE-LABEL: test3: -; CHECK-SSE: roundss $12 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundss $12, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test3: -; CHECK-AVX: vroundss $12 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundss $12, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call float @nearbyintf(float %x) nounwind readnone + ret float %call } declare float @nearbyintf(float) nounwind readnone define double @test4(double %x) nounwind { - %call = tail call double @nearbyint(double %x) nounwind readnone - ret double %call - ; CHECK-SSE-LABEL: test4: -; CHECK-SSE: roundsd $12 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundsd $12, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test4: -; CHECK-AVX: vroundsd $12 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundsd $12, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call double @nearbyint(double %x) nounwind readnone + ret double %call } declare double @nearbyint(double) nounwind readnone define float @test5(float %x) nounwind { - %call = tail call float @ceilf(float %x) nounwind readnone - ret float %call - ; CHECK-SSE-LABEL: test5: -; CHECK-SSE: roundss $10 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundss $10, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test5: -; CHECK-AVX: vroundss $10 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundss $10, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call float @ceilf(float %x) nounwind readnone + ret float %call } declare float @ceilf(float) nounwind readnone define double @test6(double %x) nounwind { - %call = tail call double @ceil(double %x) nounwind readnone - ret double %call - ; CHECK-SSE-LABEL: test6: -; CHECK-SSE: roundsd $10 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundsd $10, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test6: -; CHECK-AVX: vroundsd $10 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundsd $10, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call double @ceil(double %x) nounwind readnone + ret double %call } declare double @ceil(double) nounwind readnone define float @test7(float %x) nounwind { - %call = tail call float @rintf(float %x) nounwind readnone - ret float %call - ; CHECK-SSE-LABEL: test7: -; CHECK-SSE: roundss $4 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundss $4, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test7: -; CHECK-AVX: vroundss $4 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundss $4, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call float @rintf(float %x) nounwind readnone + ret float %call } declare float @rintf(float) nounwind readnone define double @test8(double %x) nounwind { - %call = tail call double @rint(double %x) nounwind readnone - ret double %call - ; CHECK-SSE-LABEL: test8: -; CHECK-SSE: roundsd $4 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundsd $4, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test8: -; CHECK-AVX: vroundsd $4 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundsd $4, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call double @rint(double %x) nounwind readnone + ret double %call } declare double @rint(double) nounwind readnone define float @test9(float %x) nounwind { - %call = tail call float @truncf(float %x) nounwind readnone - ret float %call - ; CHECK-SSE-LABEL: test9: -; CHECK-SSE: roundss $11 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundss $11, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test9: -; CHECK-AVX: vroundss $11 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundss $11, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call float @truncf(float %x) nounwind readnone + ret float %call } declare float @truncf(float) nounwind readnone define double @test10(double %x) nounwind { - %call = tail call double @trunc(double %x) nounwind readnone - ret double %call - ; CHECK-SSE-LABEL: test10: -; CHECK-SSE: roundsd $11 - +; CHECK-SSE: ## BB#0: +; CHECK-SSE-NEXT: roundsd $11, %xmm0, %xmm0 +; CHECK-SSE-NEXT: retq +; ; CHECK-AVX-LABEL: test10: -; CHECK-AVX: vroundsd $11 +; CHECK-AVX: ## BB#0: +; CHECK-AVX-NEXT: vroundsd $11, %xmm0, %xmm0, %xmm0 +; CHECK-AVX-NEXT: retq + %call = tail call double @trunc(double %x) nounwind readnone + ret double %call } declare double @trunc(double) nounwind readnone |