diff options
Diffstat (limited to 'llvm/test/CodeGen/X86/avx2-intrinsics-x86-upgrade.ll')
-rw-r--r-- | llvm/test/CodeGen/X86/avx2-intrinsics-x86-upgrade.ll | 147 |
1 files changed, 81 insertions, 66 deletions
diff --git a/llvm/test/CodeGen/X86/avx2-intrinsics-x86-upgrade.ll b/llvm/test/CodeGen/X86/avx2-intrinsics-x86-upgrade.ll index dff56955c21..52cae06d84b 100644 --- a/llvm/test/CodeGen/X86/avx2-intrinsics-x86-upgrade.ll +++ b/llvm/test/CodeGen/X86/avx2-intrinsics-x86-upgrade.ll @@ -1,12 +1,14 @@ ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py -; RUN: llc < %s -mtriple=i686-apple-darwin -mattr=avx2 | FileCheck %s --check-prefix=CHECK --check-prefix=AVX2 -; RUN: llc < %s -mtriple=i686-apple-darwin -mattr=+avx512f,+avx512bw,+avx512vl | FileCheck %s --check-prefix=CHECK --check-prefix=AVX512 +; RUN: llc < %s -mtriple=i686-apple-darwin -mattr=avx2 | FileCheck %s --check-prefix=CHECK --check-prefix=AVX2 --check-prefix=X86 --check-prefix=X86-AVX2 +; RUN: llc < %s -mtriple=i686-apple-darwin -mattr=+avx512f,+avx512bw,+avx512vl | FileCheck %s --check-prefix=CHECK --check-prefix=AVX512 --check-prefix=X86 --check-prefix=X86-AVX512 +; RUN: llc < %s -mtriple=x86_64-apple-darwin -mattr=avx2 | FileCheck %s --check-prefix=CHECK --check-prefix=AVX2 --check-prefix=X64 --check-prefix=X64-AVX2 +; RUN: llc < %s -mtriple=x86_64-apple-darwin -mattr=+avx512f,+avx512bw,+avx512vl | FileCheck %s --check-prefix=CHECK --check-prefix=AVX512 --check-prefix=X64 --check-prefix=X64-AVX512 define <16 x i16> @test_x86_avx2_pblendw(<16 x i16> %a0, <16 x i16> %a1) { ; CHECK-LABEL: test_x86_avx2_pblendw: ; CHECK: ## BB#0: ; CHECK-NEXT: vpblendw {{.*#+}} ymm0 = ymm1[0,1,2],ymm0[3,4,5,6,7],ymm1[8,9,10],ymm0[11,12,13,14,15] -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pblendw(<16 x i16> %a0, <16 x i16> %a1, i32 7) ; <<16 x i16>> [#uses=1] ret <16 x i16> %res } @@ -17,7 +19,7 @@ define <4 x i32> @test_x86_avx2_pblendd_128(<4 x i32> %a0, <4 x i32> %a1) { ; CHECK-LABEL: test_x86_avx2_pblendd_128: ; CHECK: ## BB#0: ; CHECK-NEXT: vblendps {{.*#+}} xmm0 = xmm1[0,1,2],xmm0[3] -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i32> @llvm.x86.avx2.pblendd.128(<4 x i32> %a0, <4 x i32> %a1, i32 7) ; <<4 x i32>> [#uses=1] ret <4 x i32> %res } @@ -28,7 +30,7 @@ define <8 x i32> @test_x86_avx2_pblendd_256(<8 x i32> %a0, <8 x i32> %a1) { ; CHECK-LABEL: test_x86_avx2_pblendd_256: ; CHECK: ## BB#0: ; CHECK-NEXT: vblendps {{.*#+}} ymm0 = ymm1[0,1,2],ymm0[3,4,5,6,7] -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pblendd.256(<8 x i32> %a0, <8 x i32> %a1, i32 7) ; <<8 x i32>> [#uses=1] ret <8 x i32> %res } @@ -36,11 +38,16 @@ declare <8 x i32> @llvm.x86.avx2.pblendd.256(<8 x i32>, <8 x i32>, i32) nounwind define <4 x i64> @test_x86_avx2_movntdqa(i8* %a0) { -; CHECK-LABEL: test_x86_avx2_movntdqa: -; CHECK: ## BB#0: -; CHECK-NEXT: movl {{[0-9]+}}(%esp), %eax -; CHECK-NEXT: vmovntdqa (%eax), %ymm0 -; CHECK-NEXT: retl +; X86-LABEL: test_x86_avx2_movntdqa: +; X86: ## BB#0: +; X86-NEXT: movl {{[0-9]+}}(%esp), %eax +; X86-NEXT: vmovntdqa (%eax), %ymm0 +; X86-NEXT: ret{{[l|q]}} +; +; X64-LABEL: test_x86_avx2_movntdqa: +; X64: ## BB#0: +; X64-NEXT: vmovntdqa (%rdi), %ymm0 +; X64-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.movntdqa(i8* %a0) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -51,7 +58,7 @@ define <16 x i16> @test_x86_avx2_mpsadbw(<32 x i8> %a0, <32 x i8> %a1) { ; CHECK-LABEL: test_x86_avx2_mpsadbw: ; CHECK: ## BB#0: ; CHECK-NEXT: vmpsadbw $7, %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.mpsadbw(<32 x i8> %a0, <32 x i8> %a1, i32 7) ; <<16 x i16>> [#uses=1] ret <16 x i16> %res } @@ -62,7 +69,7 @@ define <4 x i64> @test_x86_avx2_psll_dq_bs(<4 x i64> %a0) { ; CHECK-LABEL: test_x86_avx2_psll_dq_bs: ; CHECK: ## BB#0: ; CHECK-NEXT: vpslldq {{.*#+}} ymm0 = zero,zero,zero,zero,zero,zero,zero,ymm0[0,1,2,3,4,5,6,7,8],zero,zero,zero,zero,zero,zero,zero,ymm0[16,17,18,19,20,21,22,23,24] -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.psll.dq.bs(<4 x i64> %a0, i32 7) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -73,7 +80,7 @@ define <4 x i64> @test_x86_avx2_psrl_dq_bs(<4 x i64> %a0) { ; CHECK-LABEL: test_x86_avx2_psrl_dq_bs: ; CHECK: ## BB#0: ; CHECK-NEXT: vpsrldq {{.*#+}} ymm0 = ymm0[7,8,9,10,11,12,13,14,15],zero,zero,zero,zero,zero,zero,zero,ymm0[23,24,25,26,27,28,29,30,31],zero,zero,zero,zero,zero,zero,zero -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.psrl.dq.bs(<4 x i64> %a0, i32 7) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -84,7 +91,7 @@ define <4 x i64> @test_x86_avx2_psll_dq(<4 x i64> %a0) { ; CHECK-LABEL: test_x86_avx2_psll_dq: ; CHECK: ## BB#0: ; CHECK-NEXT: vpslldq {{.*#+}} ymm0 = zero,ymm0[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14],zero,ymm0[16,17,18,19,20,21,22,23,24,25,26,27,28,29,30] -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.psll.dq(<4 x i64> %a0, i32 8) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -95,7 +102,7 @@ define <4 x i64> @test_x86_avx2_psrl_dq(<4 x i64> %a0) { ; CHECK-LABEL: test_x86_avx2_psrl_dq: ; CHECK: ## BB#0: ; CHECK-NEXT: vpsrldq {{.*#+}} ymm0 = ymm0[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15],zero,ymm0[17,18,19,20,21,22,23,24,25,26,27,28,29,30,31],zero -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.psrl.dq(<4 x i64> %a0, i32 8) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -107,7 +114,7 @@ define <2 x i64> @test_x86_avx2_vextracti128(<4 x i64> %a0) { ; CHECK: ## BB#0: ; CHECK-NEXT: vextractf128 $1, %ymm0, %xmm0 ; CHECK-NEXT: vzeroupper -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <2 x i64> @llvm.x86.avx2.vextracti128(<4 x i64> %a0, i8 7) ret <2 x i64> %res } @@ -118,7 +125,7 @@ define <4 x i64> @test_x86_avx2_vinserti128(<4 x i64> %a0, <2 x i64> %a1) { ; CHECK-LABEL: test_x86_avx2_vinserti128: ; CHECK: ## BB#0: ; CHECK-NEXT: vinsertf128 $1, %xmm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.vinserti128(<4 x i64> %a0, <2 x i64> %a1, i8 7) ret <4 x i64> %res } @@ -129,7 +136,7 @@ define <4 x double> @test_x86_avx2_vbroadcast_sd_pd_256(<2 x double> %a0) { ; CHECK-LABEL: test_x86_avx2_vbroadcast_sd_pd_256: ; CHECK: ## BB#0: ; CHECK-NEXT: vbroadcastsd %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x double> @llvm.x86.avx2.vbroadcast.sd.pd.256(<2 x double> %a0) ret <4 x double> %res } @@ -140,7 +147,7 @@ define <4 x float> @test_x86_avx2_vbroadcast_ss_ps(<4 x float> %a0) { ; CHECK-LABEL: test_x86_avx2_vbroadcast_ss_ps: ; CHECK: ## BB#0: ; CHECK-NEXT: vbroadcastss %xmm0, %xmm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x float> @llvm.x86.avx2.vbroadcast.ss.ps(<4 x float> %a0) ret <4 x float> %res } @@ -151,7 +158,7 @@ define <8 x float> @test_x86_avx2_vbroadcast_ss_ps_256(<4 x float> %a0) { ; CHECK-LABEL: test_x86_avx2_vbroadcast_ss_ps_256: ; CHECK: ## BB#0: ; CHECK-NEXT: vbroadcastss %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x float> @llvm.x86.avx2.vbroadcast.ss.ps.256(<4 x float> %a0) ret <8 x float> %res } @@ -162,7 +169,7 @@ define <16 x i8> @test_x86_avx2_pbroadcastb_128(<16 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pbroadcastb_128: ; CHECK: ## BB#0: ; CHECK-NEXT: vpbroadcastb %xmm0, %xmm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i8> @llvm.x86.avx2.pbroadcastb.128(<16 x i8> %a0) ret <16 x i8> %res } @@ -173,7 +180,7 @@ define <32 x i8> @test_x86_avx2_pbroadcastb_256(<16 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pbroadcastb_256: ; CHECK: ## BB#0: ; CHECK-NEXT: vpbroadcastb %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <32 x i8> @llvm.x86.avx2.pbroadcastb.256(<16 x i8> %a0) ret <32 x i8> %res } @@ -184,7 +191,7 @@ define <8 x i16> @test_x86_avx2_pbroadcastw_128(<8 x i16> %a0) { ; CHECK-LABEL: test_x86_avx2_pbroadcastw_128: ; CHECK: ## BB#0: ; CHECK-NEXT: vpbroadcastw %xmm0, %xmm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i16> @llvm.x86.avx2.pbroadcastw.128(<8 x i16> %a0) ret <8 x i16> %res } @@ -195,7 +202,7 @@ define <16 x i16> @test_x86_avx2_pbroadcastw_256(<8 x i16> %a0) { ; CHECK-LABEL: test_x86_avx2_pbroadcastw_256: ; CHECK: ## BB#0: ; CHECK-NEXT: vpbroadcastw %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pbroadcastw.256(<8 x i16> %a0) ret <16 x i16> %res } @@ -206,7 +213,7 @@ define <4 x i32> @test_x86_avx2_pbroadcastd_128(<4 x i32> %a0) { ; CHECK-LABEL: test_x86_avx2_pbroadcastd_128: ; CHECK: ## BB#0: ; CHECK-NEXT: vbroadcastss %xmm0, %xmm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i32> @llvm.x86.avx2.pbroadcastd.128(<4 x i32> %a0) ret <4 x i32> %res } @@ -217,7 +224,7 @@ define <8 x i32> @test_x86_avx2_pbroadcastd_256(<4 x i32> %a0) { ; CHECK-LABEL: test_x86_avx2_pbroadcastd_256: ; CHECK: ## BB#0: ; CHECK-NEXT: vbroadcastss %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pbroadcastd.256(<4 x i32> %a0) ret <8 x i32> %res } @@ -228,7 +235,7 @@ define <2 x i64> @test_x86_avx2_pbroadcastq_128(<2 x i64> %a0) { ; CHECK-LABEL: test_x86_avx2_pbroadcastq_128: ; CHECK: ## BB#0: ; CHECK-NEXT: vpbroadcastq %xmm0, %xmm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <2 x i64> @llvm.x86.avx2.pbroadcastq.128(<2 x i64> %a0) ret <2 x i64> %res } @@ -239,7 +246,7 @@ define <4 x i64> @test_x86_avx2_pbroadcastq_256(<2 x i64> %a0) { ; CHECK-LABEL: test_x86_avx2_pbroadcastq_256: ; CHECK: ## BB#0: ; CHECK-NEXT: vbroadcastsd %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.pbroadcastq.256(<2 x i64> %a0) ret <4 x i64> %res } @@ -250,7 +257,7 @@ define <8 x i32> @test_x86_avx2_pmovsxbd(<16 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovsxbd: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovsxbd %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pmovsxbd(<16 x i8> %a0) ; <<8 x i32>> [#uses=1] ret <8 x i32> %res } @@ -261,7 +268,7 @@ define <4 x i64> @test_x86_avx2_pmovsxbq(<16 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovsxbq: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovsxbq %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.pmovsxbq(<16 x i8> %a0) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -272,7 +279,7 @@ define <16 x i16> @test_x86_avx2_pmovsxbw(<16 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovsxbw: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovsxbw %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pmovsxbw(<16 x i8> %a0) ; <<8 x i16>> [#uses=1] ret <16 x i16> %res } @@ -283,7 +290,7 @@ define <4 x i64> @test_x86_avx2_pmovsxdq(<4 x i32> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovsxdq: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovsxdq %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.pmovsxdq(<4 x i32> %a0) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -294,7 +301,7 @@ define <8 x i32> @test_x86_avx2_pmovsxwd(<8 x i16> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovsxwd: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovsxwd %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pmovsxwd(<8 x i16> %a0) ; <<8 x i32>> [#uses=1] ret <8 x i32> %res } @@ -305,7 +312,7 @@ define <4 x i64> @test_x86_avx2_pmovsxwq(<8 x i16> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovsxwq: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovsxwq %xmm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.pmovsxwq(<8 x i16> %a0) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -316,7 +323,7 @@ define <8 x i32> @test_x86_avx2_pmovzxbd(<16 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovzxbd: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovzxbd {{.*#+}} ymm0 = xmm0[0],zero,zero,zero,xmm0[1],zero,zero,zero,xmm0[2],zero,zero,zero,xmm0[3],zero,zero,zero,xmm0[4],zero,zero,zero,xmm0[5],zero,zero,zero,xmm0[6],zero,zero,zero,xmm0[7],zero,zero,zero -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pmovzxbd(<16 x i8> %a0) ; <<8 x i32>> [#uses=1] ret <8 x i32> %res } @@ -327,7 +334,7 @@ define <4 x i64> @test_x86_avx2_pmovzxbq(<16 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovzxbq: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovzxbq {{.*#+}} ymm0 = xmm0[0],zero,zero,zero,zero,zero,zero,zero,xmm0[1],zero,zero,zero,zero,zero,zero,zero,xmm0[2],zero,zero,zero,zero,zero,zero,zero,xmm0[3],zero,zero,zero,zero,zero,zero,zero -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.pmovzxbq(<16 x i8> %a0) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -338,7 +345,7 @@ define <16 x i16> @test_x86_avx2_pmovzxbw(<16 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovzxbw: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovzxbw {{.*#+}} ymm0 = xmm0[0],zero,xmm0[1],zero,xmm0[2],zero,xmm0[3],zero,xmm0[4],zero,xmm0[5],zero,xmm0[6],zero,xmm0[7],zero,xmm0[8],zero,xmm0[9],zero,xmm0[10],zero,xmm0[11],zero,xmm0[12],zero,xmm0[13],zero,xmm0[14],zero,xmm0[15],zero -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pmovzxbw(<16 x i8> %a0) ; <<16 x i16>> [#uses=1] ret <16 x i16> %res } @@ -349,7 +356,7 @@ define <4 x i64> @test_x86_avx2_pmovzxdq(<4 x i32> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovzxdq: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovzxdq {{.*#+}} ymm0 = xmm0[0],zero,xmm0[1],zero,xmm0[2],zero,xmm0[3],zero -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.pmovzxdq(<4 x i32> %a0) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -360,7 +367,7 @@ define <8 x i32> @test_x86_avx2_pmovzxwd(<8 x i16> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovzxwd: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovzxwd {{.*#+}} ymm0 = xmm0[0],zero,xmm0[1],zero,xmm0[2],zero,xmm0[3],zero,xmm0[4],zero,xmm0[5],zero,xmm0[6],zero,xmm0[7],zero -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pmovzxwd(<8 x i16> %a0) ; <<8 x i32>> [#uses=1] ret <8 x i32> %res } @@ -371,7 +378,7 @@ define <4 x i64> @test_x86_avx2_pmovzxwq(<8 x i16> %a0) { ; CHECK-LABEL: test_x86_avx2_pmovzxwq: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmovzxwq {{.*#+}} ymm0 = xmm0[0],zero,zero,zero,xmm0[1],zero,zero,zero,xmm0[2],zero,zero,zero,xmm0[3],zero,zero,zero -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.pmovzxwq(<8 x i16> %a0) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } @@ -380,14 +387,22 @@ declare <4 x i64> @llvm.x86.avx2.pmovzxwq(<8 x i16>) nounwind readnone ; This is checked here because the execution dependency fix pass makes it hard to test in AVX mode since we don't have 256-bit integer instructions define void @test_x86_avx_storeu_dq_256(i8* %a0, <32 x i8> %a1) { ; add operation forces the execution domain. -; CHECK-LABEL: test_x86_avx_storeu_dq_256: -; CHECK: ## BB#0: -; CHECK-NEXT: movl {{[0-9]+}}(%esp), %eax -; CHECK-NEXT: vpcmpeqd %ymm1, %ymm1, %ymm1 -; CHECK-NEXT: vpsubb %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: vmovdqu %ymm0, (%eax) -; CHECK-NEXT: vzeroupper -; CHECK-NEXT: retl +; X86-LABEL: test_x86_avx_storeu_dq_256: +; X86: ## BB#0: +; X86-NEXT: movl {{[0-9]+}}(%esp), %eax +; X86-NEXT: vpcmpeqd %ymm1, %ymm1, %ymm1 +; X86-NEXT: vpsubb %ymm1, %ymm0, %ymm0 +; X86-NEXT: vmovdqu %ymm0, (%eax) +; X86-NEXT: vzeroupper +; X86-NEXT: ret{{[l|q]}} +; +; X64-LABEL: test_x86_avx_storeu_dq_256: +; X64: ## BB#0: +; X64-NEXT: vpcmpeqd %ymm1, %ymm1, %ymm1 +; X64-NEXT: vpsubb %ymm1, %ymm0, %ymm0 +; X64-NEXT: vmovdqu %ymm0, (%rdi) +; X64-NEXT: vzeroupper +; X64-NEXT: ret{{[l|q]}} %a2 = add <32 x i8> %a1, <i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1> call void @llvm.x86.avx.storeu.dq.256(i8* %a0, <32 x i8> %a2) ret void @@ -398,7 +413,7 @@ define <32 x i8> @mm256_max_epi8(<32 x i8> %a0, <32 x i8> %a1) { ; CHECK-LABEL: mm256_max_epi8: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmaxsb %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <32 x i8> @llvm.x86.avx2.pmaxs.b(<32 x i8> %a0, <32 x i8> %a1) ret <32 x i8> %res } @@ -408,7 +423,7 @@ define <16 x i16> @mm256_max_epi16(<16 x i16> %a0, <16 x i16> %a1) { ; CHECK-LABEL: mm256_max_epi16: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmaxsw %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pmaxs.w(<16 x i16> %a0, <16 x i16> %a1) ret <16 x i16> %res } @@ -418,7 +433,7 @@ define <8 x i32> @mm256_max_epi32(<8 x i32> %a0, <8 x i32> %a1) { ; CHECK-LABEL: mm256_max_epi32: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmaxsd %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pmaxs.d(<8 x i32> %a0, <8 x i32> %a1) ret <8 x i32> %res } @@ -428,7 +443,7 @@ define <32 x i8> @mm256_max_epu8(<32 x i8> %a0, <32 x i8> %a1) { ; CHECK-LABEL: mm256_max_epu8: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmaxub %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <32 x i8> @llvm.x86.avx2.pmaxu.b(<32 x i8> %a0, <32 x i8> %a1) ret <32 x i8> %res } @@ -438,7 +453,7 @@ define <16 x i16> @mm256_max_epu16(<16 x i16> %a0, <16 x i16> %a1) { ; CHECK-LABEL: mm256_max_epu16: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmaxuw %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pmaxu.w(<16 x i16> %a0, <16 x i16> %a1) ret <16 x i16> %res } @@ -448,7 +463,7 @@ define <8 x i32> @mm256_max_epu32(<8 x i32> %a0, <8 x i32> %a1) { ; CHECK-LABEL: mm256_max_epu32: ; CHECK: ## BB#0: ; CHECK-NEXT: vpmaxud %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pmaxu.d(<8 x i32> %a0, <8 x i32> %a1) ret <8 x i32> %res } @@ -458,7 +473,7 @@ define <32 x i8> @mm256_min_epi8(<32 x i8> %a0, <32 x i8> %a1) { ; CHECK-LABEL: mm256_min_epi8: ; CHECK: ## BB#0: ; CHECK-NEXT: vpminsb %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <32 x i8> @llvm.x86.avx2.pmins.b(<32 x i8> %a0, <32 x i8> %a1) ret <32 x i8> %res } @@ -468,7 +483,7 @@ define <16 x i16> @mm256_min_epi16(<16 x i16> %a0, <16 x i16> %a1) { ; CHECK-LABEL: mm256_min_epi16: ; CHECK: ## BB#0: ; CHECK-NEXT: vpminsw %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pmins.w(<16 x i16> %a0, <16 x i16> %a1) ret <16 x i16> %res } @@ -478,7 +493,7 @@ define <8 x i32> @mm256_min_epi32(<8 x i32> %a0, <8 x i32> %a1) { ; CHECK-LABEL: mm256_min_epi32: ; CHECK: ## BB#0: ; CHECK-NEXT: vpminsd %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pmins.d(<8 x i32> %a0, <8 x i32> %a1) ret <8 x i32> %res } @@ -488,7 +503,7 @@ define <32 x i8> @mm256_min_epu8(<32 x i8> %a0, <32 x i8> %a1) { ; CHECK-LABEL: mm256_min_epu8: ; CHECK: ## BB#0: ; CHECK-NEXT: vpminub %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <32 x i8> @llvm.x86.avx2.pminu.b(<32 x i8> %a0, <32 x i8> %a1) ret <32 x i8> %res } @@ -498,7 +513,7 @@ define <16 x i16> @mm256_min_epu16(<16 x i16> %a0, <16 x i16> %a1) { ; CHECK-LABEL: mm256_min_epu16: ; CHECK: ## BB#0: ; CHECK-NEXT: vpminuw %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pminu.w(<16 x i16> %a0, <16 x i16> %a1) ret <16 x i16> %res } @@ -508,7 +523,7 @@ define <8 x i32> @mm256_min_epu32(<8 x i32> %a0, <8 x i32> %a1) { ; CHECK-LABEL: mm256_min_epu32: ; CHECK: ## BB#0: ; CHECK-NEXT: vpminud %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pminu.d(<8 x i32> %a0, <8 x i32> %a1) ret <8 x i32> %res } @@ -518,7 +533,7 @@ define <32 x i8> @mm256_avg_epu8(<32 x i8> %a0, <32 x i8> %a1) { ; CHECK-LABEL: mm256_avg_epu8: ; CHECK: ## BB#0: ; CHECK-NEXT: vpavgb %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <32 x i8> @llvm.x86.avx2.pavg.b(<32 x i8> %a0, <32 x i8> %a1) ; <<32 x i8>> [#uses=1] ret <32 x i8> %res } @@ -528,7 +543,7 @@ define <16 x i16> @mm256_avg_epu16(<16 x i16> %a0, <16 x i16> %a1) { ; CHECK-LABEL: mm256_avg_epu16: ; CHECK: ## BB#0: ; CHECK-NEXT: vpavgw %ymm1, %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pavg.w(<16 x i16> %a0, <16 x i16> %a1) ; <<16 x i16>> [#uses=1] ret <16 x i16> %res } @@ -538,7 +553,7 @@ define <32 x i8> @test_x86_avx2_pabs_b(<32 x i8> %a0) { ; CHECK-LABEL: test_x86_avx2_pabs_b: ; CHECK: ## BB#0: ; CHECK-NEXT: vpabsb %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <32 x i8> @llvm.x86.avx2.pabs.b(<32 x i8> %a0) ; <<32 x i8>> [#uses=1] ret <32 x i8> %res } @@ -548,7 +563,7 @@ define <8 x i32> @test_x86_avx2_pabs_d(<8 x i32> %a0) { ; CHECK-LABEL: test_x86_avx2_pabs_d: ; CHECK: ## BB#0: ; CHECK-NEXT: vpabsd %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <8 x i32> @llvm.x86.avx2.pabs.d(<8 x i32> %a0) ; <<8 x i32>> [#uses=1] ret <8 x i32> %res } @@ -559,7 +574,7 @@ define <16 x i16> @test_x86_avx2_pabs_w(<16 x i16> %a0) { ; CHECK-LABEL: test_x86_avx2_pabs_w: ; CHECK: ## BB#0: ; CHECK-NEXT: vpabsw %ymm0, %ymm0 -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <16 x i16> @llvm.x86.avx2.pabs.w(<16 x i16> %a0) ; <<16 x i16>> [#uses=1] ret <16 x i16> %res } @@ -570,7 +585,7 @@ define <4 x i64> @test_x86_avx2_vperm2i128(<4 x i64> %a0, <4 x i64> %a1) { ; CHECK-LABEL: test_x86_avx2_vperm2i128: ; CHECK: ## BB#0: ; CHECK-NEXT: vpermpd {{.*#+}} ymm0 = ymm0[2,3,0,1] -; CHECK-NEXT: retl +; CHECK-NEXT: ret{{[l|q]}} %res = call <4 x i64> @llvm.x86.avx2.vperm2i128(<4 x i64> %a0, <4 x i64> %a1, i8 1) ; <<4 x i64>> [#uses=1] ret <4 x i64> %res } |