diff options
Diffstat (limited to 'llvm/test/CodeGen/X86/vector-reduce-xor-bool.ll')
-rw-r--r-- | llvm/test/CodeGen/X86/vector-reduce-xor-bool.ll | 89 |
1 files changed, 34 insertions, 55 deletions
diff --git a/llvm/test/CodeGen/X86/vector-reduce-xor-bool.ll b/llvm/test/CodeGen/X86/vector-reduce-xor-bool.ll index 03861ffd261..059c0422b0a 100644 --- a/llvm/test/CodeGen/X86/vector-reduce-xor-bool.ll +++ b/llvm/test/CodeGen/X86/vector-reduce-xor-bool.ll @@ -118,29 +118,17 @@ define i1 @trunc_v4i32_v4i1(<4 x i32>) { } define i1 @trunc_v8i16_v8i1(<8 x i8>) { -; SSE2-LABEL: trunc_v8i16_v8i1: -; SSE2: # %bb.0: -; SSE2-NEXT: punpcklbw {{.*#+}} xmm0 = xmm0[0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7] -; SSE2-NEXT: psllw $15, %xmm0 -; SSE2-NEXT: packsswb %xmm0, %xmm0 -; SSE2-NEXT: pmovmskb %xmm0, %eax -; SSE2-NEXT: xorb $0, %al -; SSE2-NEXT: setnp %al -; SSE2-NEXT: retq -; -; SSE41-LABEL: trunc_v8i16_v8i1: -; SSE41: # %bb.0: -; SSE41-NEXT: pmovzxbw {{.*#+}} xmm0 = xmm0[0],zero,xmm0[1],zero,xmm0[2],zero,xmm0[3],zero,xmm0[4],zero,xmm0[5],zero,xmm0[6],zero,xmm0[7],zero -; SSE41-NEXT: psllw $15, %xmm0 -; SSE41-NEXT: packsswb %xmm0, %xmm0 -; SSE41-NEXT: pmovmskb %xmm0, %eax -; SSE41-NEXT: xorb $0, %al -; SSE41-NEXT: setnp %al -; SSE41-NEXT: retq +; SSE-LABEL: trunc_v8i16_v8i1: +; SSE: # %bb.0: +; SSE-NEXT: psllw $15, %xmm0 +; SSE-NEXT: packsswb %xmm0, %xmm0 +; SSE-NEXT: pmovmskb %xmm0, %eax +; SSE-NEXT: xorb $0, %al +; SSE-NEXT: setnp %al +; SSE-NEXT: retq ; ; AVX-LABEL: trunc_v8i16_v8i1: ; AVX: # %bb.0: -; AVX-NEXT: vpmovzxbw {{.*#+}} xmm0 = xmm0[0],zero,xmm0[1],zero,xmm0[2],zero,xmm0[3],zero,xmm0[4],zero,xmm0[5],zero,xmm0[6],zero,xmm0[7],zero ; AVX-NEXT: vpsllw $15, %xmm0, %xmm0 ; AVX-NEXT: vpacksswb %xmm0, %xmm0, %xmm0 ; AVX-NEXT: vpmovmskb %xmm0, %eax @@ -150,9 +138,9 @@ define i1 @trunc_v8i16_v8i1(<8 x i8>) { ; ; AVX512F-LABEL: trunc_v8i16_v8i1: ; AVX512F: # %bb.0: -; AVX512F-NEXT: vpmovsxbd %xmm0, %zmm0 -; AVX512F-NEXT: vpslld $31, %zmm0, %zmm0 -; AVX512F-NEXT: vptestmd %zmm0, %zmm0, %k0 +; AVX512F-NEXT: vpmovsxwq %xmm0, %zmm0 +; AVX512F-NEXT: vpsllq $63, %zmm0, %zmm0 +; AVX512F-NEXT: vptestmq %zmm0, %zmm0, %k0 ; AVX512F-NEXT: kmovw %k0, %eax ; AVX512F-NEXT: xorb $0, %al ; AVX512F-NEXT: setnp %al @@ -161,8 +149,8 @@ define i1 @trunc_v8i16_v8i1(<8 x i8>) { ; ; AVX512BW-LABEL: trunc_v8i16_v8i1: ; AVX512BW: # %bb.0: -; AVX512BW-NEXT: vpsllw $7, %xmm0, %xmm0 -; AVX512BW-NEXT: vpmovb2m %zmm0, %k0 +; AVX512BW-NEXT: vpsllw $15, %xmm0, %xmm0 +; AVX512BW-NEXT: vpmovw2m %zmm0, %k0 ; AVX512BW-NEXT: kmovd %k0, %eax ; AVX512BW-NEXT: xorb $0, %al ; AVX512BW-NEXT: setnp %al @@ -171,8 +159,8 @@ define i1 @trunc_v8i16_v8i1(<8 x i8>) { ; ; AVX512VL-LABEL: trunc_v8i16_v8i1: ; AVX512VL: # %bb.0: -; AVX512VL-NEXT: vpsllw $7, %xmm0, %xmm0 -; AVX512VL-NEXT: vpmovb2m %xmm0, %k0 +; AVX512VL-NEXT: vpsllw $15, %xmm0, %xmm0 +; AVX512VL-NEXT: vpmovw2m %xmm0, %k0 ; AVX512VL-NEXT: kmovd %k0, %eax ; AVX512VL-NEXT: xorb $0, %al ; AVX512VL-NEXT: setnp %al @@ -1170,33 +1158,22 @@ define i1 @icmp_v4i32_v4i1(<4 x i32>) { } define i1 @icmp_v8i16_v8i1(<8 x i8>) { -; SSE2-LABEL: icmp_v8i16_v8i1: -; SSE2: # %bb.0: -; SSE2-NEXT: pxor %xmm1, %xmm1 -; SSE2-NEXT: pcmpeqb %xmm0, %xmm1 -; SSE2-NEXT: punpcklbw {{.*#+}} xmm0 = xmm0[0],xmm1[0],xmm0[1],xmm1[1],xmm0[2],xmm1[2],xmm0[3],xmm1[3],xmm0[4],xmm1[4],xmm0[5],xmm1[5],xmm0[6],xmm1[6],xmm0[7],xmm1[7] -; SSE2-NEXT: packsswb %xmm0, %xmm0 -; SSE2-NEXT: pmovmskb %xmm0, %eax -; SSE2-NEXT: xorb $0, %al -; SSE2-NEXT: setnp %al -; SSE2-NEXT: retq -; -; SSE41-LABEL: icmp_v8i16_v8i1: -; SSE41: # %bb.0: -; SSE41-NEXT: pxor %xmm1, %xmm1 -; SSE41-NEXT: pcmpeqb %xmm0, %xmm1 -; SSE41-NEXT: pmovsxbw %xmm1, %xmm0 -; SSE41-NEXT: packsswb %xmm0, %xmm0 -; SSE41-NEXT: pmovmskb %xmm0, %eax -; SSE41-NEXT: xorb $0, %al -; SSE41-NEXT: setnp %al -; SSE41-NEXT: retq +; SSE-LABEL: icmp_v8i16_v8i1: +; SSE: # %bb.0: +; SSE-NEXT: pand {{.*}}(%rip), %xmm0 +; SSE-NEXT: pxor %xmm1, %xmm1 +; SSE-NEXT: pcmpeqw %xmm0, %xmm1 +; SSE-NEXT: packsswb %xmm0, %xmm1 +; SSE-NEXT: pmovmskb %xmm1, %eax +; SSE-NEXT: xorb $0, %al +; SSE-NEXT: setnp %al +; SSE-NEXT: retq ; ; AVX-LABEL: icmp_v8i16_v8i1: ; AVX: # %bb.0: +; AVX-NEXT: vpand {{.*}}(%rip), %xmm0, %xmm0 ; AVX-NEXT: vpxor %xmm1, %xmm1, %xmm1 -; AVX-NEXT: vpcmpeqb %xmm1, %xmm0, %xmm0 -; AVX-NEXT: vpmovsxbw %xmm0, %xmm0 +; AVX-NEXT: vpcmpeqw %xmm1, %xmm0, %xmm0 ; AVX-NEXT: vpacksswb %xmm0, %xmm0, %xmm0 ; AVX-NEXT: vpmovmskb %xmm0, %eax ; AVX-NEXT: xorb $0, %al @@ -1205,10 +1182,11 @@ define i1 @icmp_v8i16_v8i1(<8 x i8>) { ; ; AVX512F-LABEL: icmp_v8i16_v8i1: ; AVX512F: # %bb.0: +; AVX512F-NEXT: vpand {{.*}}(%rip), %xmm0, %xmm0 ; AVX512F-NEXT: vpxor %xmm1, %xmm1, %xmm1 -; AVX512F-NEXT: vpcmpeqb %xmm1, %xmm0, %xmm0 -; AVX512F-NEXT: vpmovsxbd %xmm0, %zmm0 -; AVX512F-NEXT: vptestmd %zmm0, %zmm0, %k0 +; AVX512F-NEXT: vpcmpeqw %xmm1, %xmm0, %xmm0 +; AVX512F-NEXT: vpmovsxwq %xmm0, %zmm0 +; AVX512F-NEXT: vptestmq %zmm0, %zmm0, %k0 ; AVX512F-NEXT: kmovw %k0, %eax ; AVX512F-NEXT: xorb $0, %al ; AVX512F-NEXT: setnp %al @@ -1218,7 +1196,8 @@ define i1 @icmp_v8i16_v8i1(<8 x i8>) { ; AVX512BW-LABEL: icmp_v8i16_v8i1: ; AVX512BW: # %bb.0: ; AVX512BW-NEXT: # kill: def $xmm0 killed $xmm0 def $zmm0 -; AVX512BW-NEXT: vptestnmb %zmm0, %zmm0, %k0 +; AVX512BW-NEXT: vmovdqa {{.*#+}} xmm1 = [255,0,255,0,255,0,255,0,255,0,255,0,255,0,255,0] +; AVX512BW-NEXT: vptestnmw %zmm1, %zmm0, %k0 ; AVX512BW-NEXT: kmovd %k0, %eax ; AVX512BW-NEXT: xorb $0, %al ; AVX512BW-NEXT: setnp %al @@ -1227,7 +1206,7 @@ define i1 @icmp_v8i16_v8i1(<8 x i8>) { ; ; AVX512VL-LABEL: icmp_v8i16_v8i1: ; AVX512VL: # %bb.0: -; AVX512VL-NEXT: vptestnmb %xmm0, %xmm0, %k0 +; AVX512VL-NEXT: vptestnmw {{.*}}(%rip), %xmm0, %k0 ; AVX512VL-NEXT: kmovd %k0, %eax ; AVX512VL-NEXT: xorb $0, %al ; AVX512VL-NEXT: setnp %al |