forked from OSchip/llvm-project
[X86] Update VBMI2 vshld/vshrd tests to use an immediate that doesn't require a modulo.
Planning to replace these with funnel shift intrinsics which would mask out the extra bits. This will help minimize test diffs. llvm-svn: 350504
This commit is contained in:
parent
363ac68374
commit
1ac0839098
|
@ -308,16 +308,16 @@ define <8 x i64> @test_mm512_mask_shldi_epi64(<8 x i64> %__S, i8 zeroext %__U, <
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldq $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X86-NEXT: vpshldq $47, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_mask_shldi_epi64:
|
; X64-LABEL: test_mm512_mask_shldi_epi64:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldq $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X64-NEXT: vpshldq $47, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = tail call <8 x i64> @llvm.x86.avx512.vpshld.q.512(<8 x i64> %__A, <8 x i64> %__B, i32 127)
|
%0 = tail call <8 x i64> @llvm.x86.avx512.vpshld.q.512(<8 x i64> %__A, <8 x i64> %__B, i32 47)
|
||||||
%1 = bitcast i8 %__U to <8 x i1>
|
%1 = bitcast i8 %__U to <8 x i1>
|
||||||
%2 = select <8 x i1> %1, <8 x i64> %0, <8 x i64> %__S
|
%2 = select <8 x i1> %1, <8 x i64> %0, <8 x i64> %__S
|
||||||
ret <8 x i64> %2
|
ret <8 x i64> %2
|
||||||
|
@ -384,18 +384,18 @@ define <8 x i64> @test_mm512_maskz_shldi_epi32(i16 zeroext %__U, <8 x i64> %__A,
|
||||||
; X86-LABEL: test_mm512_maskz_shldi_epi32:
|
; X86-LABEL: test_mm512_maskz_shldi_epi32:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshldd $63, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
; X86-NEXT: vpshldd $15, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_maskz_shldi_epi32:
|
; X64-LABEL: test_mm512_maskz_shldi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldd $63, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
; X64-NEXT: vpshldd $15, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <8 x i64> %__A to <16 x i32>
|
%0 = bitcast <8 x i64> %__A to <16 x i32>
|
||||||
%1 = bitcast <8 x i64> %__B to <16 x i32>
|
%1 = bitcast <8 x i64> %__B to <16 x i32>
|
||||||
%2 = tail call <16 x i32> @llvm.x86.avx512.vpshld.d.512(<16 x i32> %0, <16 x i32> %1, i32 63)
|
%2 = tail call <16 x i32> @llvm.x86.avx512.vpshld.d.512(<16 x i32> %0, <16 x i32> %1, i32 15)
|
||||||
%3 = bitcast i16 %__U to <16 x i1>
|
%3 = bitcast i16 %__U to <16 x i1>
|
||||||
%4 = select <16 x i1> %3, <16 x i32> %2, <16 x i32> zeroinitializer
|
%4 = select <16 x i1> %3, <16 x i32> %2, <16 x i32> zeroinitializer
|
||||||
%5 = bitcast <16 x i32> %4 to <8 x i64>
|
%5 = bitcast <16 x i32> %4 to <8 x i64>
|
||||||
|
@ -419,18 +419,18 @@ define <8 x i64> @test_mm512_mask_shldi_epi16(<8 x i64> %__S, i32 %__U, <8 x i64
|
||||||
; X86-LABEL: test_mm512_mask_shldi_epi16:
|
; X86-LABEL: test_mm512_mask_shldi_epi16:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshldw $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X86-NEXT: vpshldw $3, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_mask_shldi_epi16:
|
; X64-LABEL: test_mm512_mask_shldi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldw $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X64-NEXT: vpshldw $3, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
||||||
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
||||||
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %0, <32 x i16> %1, i32 127)
|
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %0, <32 x i16> %1, i32 3)
|
||||||
%3 = bitcast <8 x i64> %__S to <32 x i16>
|
%3 = bitcast <8 x i64> %__S to <32 x i16>
|
||||||
%4 = bitcast i32 %__U to <32 x i1>
|
%4 = bitcast i32 %__U to <32 x i1>
|
||||||
%5 = select <32 x i1> %4, <32 x i16> %2, <32 x i16> %3
|
%5 = select <32 x i1> %4, <32 x i16> %2, <32 x i16> %3
|
||||||
|
@ -444,18 +444,18 @@ define <8 x i64> @test_mm512_maskz_shldi_epi16(i32 %__U, <8 x i64> %__A, <8 x i6
|
||||||
; X86-LABEL: test_mm512_maskz_shldi_epi16:
|
; X86-LABEL: test_mm512_maskz_shldi_epi16:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshldw $63, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
; X86-NEXT: vpshldw $7, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_maskz_shldi_epi16:
|
; X64-LABEL: test_mm512_maskz_shldi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldw $63, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
; X64-NEXT: vpshldw $7, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
||||||
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
||||||
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %0, <32 x i16> %1, i32 63)
|
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %0, <32 x i16> %1, i32 7)
|
||||||
%3 = bitcast i32 %__U to <32 x i1>
|
%3 = bitcast i32 %__U to <32 x i1>
|
||||||
%4 = select <32 x i1> %3, <32 x i16> %2, <32 x i16> zeroinitializer
|
%4 = select <32 x i1> %3, <32 x i16> %2, <32 x i16> zeroinitializer
|
||||||
%5 = bitcast <32 x i16> %4 to <8 x i64>
|
%5 = bitcast <32 x i16> %4 to <8 x i64>
|
||||||
|
@ -465,12 +465,12 @@ entry:
|
||||||
define <8 x i64> @test_mm512_shldi_epi16(<8 x i64> %__A, <8 x i64> %__B) {
|
define <8 x i64> @test_mm512_shldi_epi16(<8 x i64> %__A, <8 x i64> %__B) {
|
||||||
; CHECK-LABEL: test_mm512_shldi_epi16:
|
; CHECK-LABEL: test_mm512_shldi_epi16:
|
||||||
; CHECK: # %bb.0: # %entry
|
; CHECK: # %bb.0: # %entry
|
||||||
; CHECK-NEXT: vpshldw $31, %zmm1, %zmm0, %zmm0
|
; CHECK-NEXT: vpshldw $15, %zmm1, %zmm0, %zmm0
|
||||||
; CHECK-NEXT: ret{{[l|q]}}
|
; CHECK-NEXT: ret{{[l|q]}}
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
||||||
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
||||||
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %0, <32 x i16> %1, i32 31)
|
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %0, <32 x i16> %1, i32 15)
|
||||||
%3 = bitcast <32 x i16> %2 to <8 x i64>
|
%3 = bitcast <32 x i16> %2 to <8 x i64>
|
||||||
ret <8 x i64> %3
|
ret <8 x i64> %3
|
||||||
}
|
}
|
||||||
|
@ -480,16 +480,16 @@ define <8 x i64> @test_mm512_mask_shrdi_epi64(<8 x i64> %__S, i8 zeroext %__U, <
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdq $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X86-NEXT: vpshrdq $47, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_mask_shrdi_epi64:
|
; X64-LABEL: test_mm512_mask_shrdi_epi64:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdq $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X64-NEXT: vpshrdq $47, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = tail call <8 x i64> @llvm.x86.avx512.vpshrd.q.512(<8 x i64> %__A, <8 x i64> %__B, i32 127)
|
%0 = tail call <8 x i64> @llvm.x86.avx512.vpshrd.q.512(<8 x i64> %__A, <8 x i64> %__B, i32 47)
|
||||||
%1 = bitcast i8 %__U to <8 x i1>
|
%1 = bitcast i8 %__U to <8 x i1>
|
||||||
%2 = select <8 x i1> %1, <8 x i64> %0, <8 x i64> %__S
|
%2 = select <8 x i1> %1, <8 x i64> %0, <8 x i64> %__S
|
||||||
ret <8 x i64> %2
|
ret <8 x i64> %2
|
||||||
|
@ -531,18 +531,18 @@ define <8 x i64> @test_mm512_mask_shrdi_epi32(<8 x i64> %__S, i16 zeroext %__U,
|
||||||
; X86-LABEL: test_mm512_mask_shrdi_epi32:
|
; X86-LABEL: test_mm512_mask_shrdi_epi32:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshrdd $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X86-NEXT: vpshrdd $7, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_mask_shrdi_epi32:
|
; X64-LABEL: test_mm512_mask_shrdi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdd $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X64-NEXT: vpshrdd $7, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <8 x i64> %__A to <16 x i32>
|
%0 = bitcast <8 x i64> %__A to <16 x i32>
|
||||||
%1 = bitcast <8 x i64> %__B to <16 x i32>
|
%1 = bitcast <8 x i64> %__B to <16 x i32>
|
||||||
%2 = tail call <16 x i32> @llvm.x86.avx512.vpshrd.d.512(<16 x i32> %0, <16 x i32> %1, i32 127)
|
%2 = tail call <16 x i32> @llvm.x86.avx512.vpshrd.d.512(<16 x i32> %0, <16 x i32> %1, i32 7)
|
||||||
%3 = bitcast <8 x i64> %__S to <16 x i32>
|
%3 = bitcast <8 x i64> %__S to <16 x i32>
|
||||||
%4 = bitcast i16 %__U to <16 x i1>
|
%4 = bitcast i16 %__U to <16 x i1>
|
||||||
%5 = select <16 x i1> %4, <16 x i32> %2, <16 x i32> %3
|
%5 = select <16 x i1> %4, <16 x i32> %2, <16 x i32> %3
|
||||||
|
@ -556,18 +556,18 @@ define <8 x i64> @test_mm512_maskz_shrdi_epi32(i16 zeroext %__U, <8 x i64> %__A,
|
||||||
; X86-LABEL: test_mm512_maskz_shrdi_epi32:
|
; X86-LABEL: test_mm512_maskz_shrdi_epi32:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshrdd $63, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
; X86-NEXT: vpshrdd $15, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_maskz_shrdi_epi32:
|
; X64-LABEL: test_mm512_maskz_shrdi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdd $63, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
; X64-NEXT: vpshrdd $15, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <8 x i64> %__A to <16 x i32>
|
%0 = bitcast <8 x i64> %__A to <16 x i32>
|
||||||
%1 = bitcast <8 x i64> %__B to <16 x i32>
|
%1 = bitcast <8 x i64> %__B to <16 x i32>
|
||||||
%2 = tail call <16 x i32> @llvm.x86.avx512.vpshrd.d.512(<16 x i32> %0, <16 x i32> %1, i32 63)
|
%2 = tail call <16 x i32> @llvm.x86.avx512.vpshrd.d.512(<16 x i32> %0, <16 x i32> %1, i32 15)
|
||||||
%3 = bitcast i16 %__U to <16 x i1>
|
%3 = bitcast i16 %__U to <16 x i1>
|
||||||
%4 = select <16 x i1> %3, <16 x i32> %2, <16 x i32> zeroinitializer
|
%4 = select <16 x i1> %3, <16 x i32> %2, <16 x i32> zeroinitializer
|
||||||
%5 = bitcast <16 x i32> %4 to <8 x i64>
|
%5 = bitcast <16 x i32> %4 to <8 x i64>
|
||||||
|
@ -591,18 +591,18 @@ define <8 x i64> @test_mm512_mask_shrdi_epi16(<8 x i64> %__S, i32 %__U, <8 x i64
|
||||||
; X86-LABEL: test_mm512_mask_shrdi_epi16:
|
; X86-LABEL: test_mm512_mask_shrdi_epi16:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshrdw $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X86-NEXT: vpshrdw $3, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_mask_shrdi_epi16:
|
; X64-LABEL: test_mm512_mask_shrdi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdw $127, %zmm2, %zmm1, %zmm0 {%k1}
|
; X64-NEXT: vpshrdw $3, %zmm2, %zmm1, %zmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
||||||
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
||||||
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshrd.w.512(<32 x i16> %0, <32 x i16> %1, i32 127)
|
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshrd.w.512(<32 x i16> %0, <32 x i16> %1, i32 3)
|
||||||
%3 = bitcast <8 x i64> %__S to <32 x i16>
|
%3 = bitcast <8 x i64> %__S to <32 x i16>
|
||||||
%4 = bitcast i32 %__U to <32 x i1>
|
%4 = bitcast i32 %__U to <32 x i1>
|
||||||
%5 = select <32 x i1> %4, <32 x i16> %2, <32 x i16> %3
|
%5 = select <32 x i1> %4, <32 x i16> %2, <32 x i16> %3
|
||||||
|
@ -616,18 +616,18 @@ define <8 x i64> @test_mm512_maskz_shrdi_epi16(i32 %__U, <8 x i64> %__A, <8 x i6
|
||||||
; X86-LABEL: test_mm512_maskz_shrdi_epi16:
|
; X86-LABEL: test_mm512_maskz_shrdi_epi16:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshrdw $63, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
; X86-NEXT: vpshrdw $15, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm512_maskz_shrdi_epi16:
|
; X64-LABEL: test_mm512_maskz_shrdi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdw $63, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
; X64-NEXT: vpshrdw $15, %zmm1, %zmm0, %zmm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
%0 = bitcast <8 x i64> %__A to <32 x i16>
|
||||||
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
%1 = bitcast <8 x i64> %__B to <32 x i16>
|
||||||
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshrd.w.512(<32 x i16> %0, <32 x i16> %1, i32 63)
|
%2 = tail call <32 x i16> @llvm.x86.avx512.vpshrd.w.512(<32 x i16> %0, <32 x i16> %1, i32 15)
|
||||||
%3 = bitcast i32 %__U to <32 x i1>
|
%3 = bitcast i32 %__U to <32 x i1>
|
||||||
%4 = select <32 x i1> %3, <32 x i16> %2, <32 x i16> zeroinitializer
|
%4 = select <32 x i1> %3, <32 x i16> %2, <32 x i16> zeroinitializer
|
||||||
%5 = bitcast <32 x i16> %4 to <8 x i64>
|
%5 = bitcast <32 x i16> %4 to <8 x i64>
|
||||||
|
|
|
@ -330,21 +330,21 @@ declare <8 x i64> @llvm.x86.avx512.mask.vpshld.q.512(<8 x i64>, <8 x i64>, i32,
|
||||||
define <32 x i16>@test_int_x86_avx512_mask_vpshld_w_512(<32 x i16> %x0, <32 x i16> %x1, <32 x i16> %x3, i32 %x4) {
|
define <32 x i16>@test_int_x86_avx512_mask_vpshld_w_512(<32 x i16> %x0, <32 x i16> %x1, <32 x i16> %x3, i32 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_512:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_512:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshldw $22, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x70,0xd9,0x16]
|
; X86-NEXT: vpshldw $6, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x70,0xd9,0x06]
|
||||||
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1 # encoding: [0xc4,0xe1,0xf9,0x90,0x4c,0x24,0x04]
|
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1 # encoding: [0xc4,0xe1,0xf9,0x90,0x4c,0x24,0x04]
|
||||||
; X86-NEXT: vpshldw $22, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x70,0xd1,0x16]
|
; X86-NEXT: vpshldw $6, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x70,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
; X86-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_512:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_512:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshldw $22, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x70,0xd9,0x16]
|
; X64-NEXT: vpshldw $6, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x70,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshldw $22, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x70,0xd1,0x16]
|
; X64-NEXT: vpshldw $6, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x70,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
; X64-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%res = call <32 x i16> @llvm.x86.avx512.mask.vpshld.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 22, <32 x i16> %x3, i32 %x4)
|
%res = call <32 x i16> @llvm.x86.avx512.mask.vpshld.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 6, <32 x i16> %x3, i32 %x4)
|
||||||
%res1 = call <32 x i16> @llvm.x86.avx512.mask.vpshld.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 22, <32 x i16> %x3, i32 -1)
|
%res1 = call <32 x i16> @llvm.x86.avx512.mask.vpshld.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 6, <32 x i16> %x3, i32 -1)
|
||||||
%res2 = add <32 x i16> %res, %res1
|
%res2 = add <32 x i16> %res, %res1
|
||||||
ret <32 x i16> %res2
|
ret <32 x i16> %res2
|
||||||
}
|
}
|
||||||
|
@ -400,21 +400,21 @@ declare <8 x i64> @llvm.x86.avx512.mask.vpshrd.q.512(<8 x i64>, <8 x i64>, i32,
|
||||||
define <32 x i16>@test_int_x86_avx512_mask_vpshrd_w_512(<32 x i16> %x0, <32 x i16> %x1, <32 x i16> %x3, i32 %x4) {
|
define <32 x i16>@test_int_x86_avx512_mask_vpshrd_w_512(<32 x i16> %x0, <32 x i16> %x1, <32 x i16> %x3, i32 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_512:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_512:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshrdw $22, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x72,0xd9,0x16]
|
; X86-NEXT: vpshrdw $6, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x72,0xd9,0x06]
|
||||||
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1 # encoding: [0xc4,0xe1,0xf9,0x90,0x4c,0x24,0x04]
|
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1 # encoding: [0xc4,0xe1,0xf9,0x90,0x4c,0x24,0x04]
|
||||||
; X86-NEXT: vpshrdw $22, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x72,0xd1,0x16]
|
; X86-NEXT: vpshrdw $6, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x72,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
; X86-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_512:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_512:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshrdw $22, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x72,0xd9,0x16]
|
; X64-NEXT: vpshrdw $6, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x72,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshrdw $22, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x72,0xd1,0x16]
|
; X64-NEXT: vpshrdw $6, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x72,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
; X64-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%res = call <32 x i16> @llvm.x86.avx512.mask.vpshrd.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 22, <32 x i16> %x3, i32 %x4)
|
%res = call <32 x i16> @llvm.x86.avx512.mask.vpshrd.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 6, <32 x i16> %x3, i32 %x4)
|
||||||
%res1 = call <32 x i16> @llvm.x86.avx512.mask.vpshrd.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 22, <32 x i16> %x3, i32 -1)
|
%res1 = call <32 x i16> @llvm.x86.avx512.mask.vpshrd.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 6, <32 x i16> %x3, i32 -1)
|
||||||
%res2 = add <32 x i16> %res, %res1
|
%res2 = add <32 x i16> %res, %res1
|
||||||
ret <32 x i16> %res2
|
ret <32 x i16> %res2
|
||||||
}
|
}
|
||||||
|
|
|
@ -148,23 +148,23 @@ declare <8 x i64> @llvm.x86.avx512.vpshld.q.512(<8 x i64>, <8 x i64>, i32)
|
||||||
define <32 x i16>@test_int_x86_avx512_mask_vpshld_w_512(<32 x i16> %x0, <32 x i16> %x1, <32 x i16> %x3, i32 %x4) {
|
define <32 x i16>@test_int_x86_avx512_mask_vpshld_w_512(<32 x i16> %x0, <32 x i16> %x1, <32 x i16> %x3, i32 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_512:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_512:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshldw $22, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x70,0xd9,0x16]
|
; X86-NEXT: vpshldw $6, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x70,0xd9,0x06]
|
||||||
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1 # encoding: [0xc4,0xe1,0xf9,0x90,0x4c,0x24,0x04]
|
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1 # encoding: [0xc4,0xe1,0xf9,0x90,0x4c,0x24,0x04]
|
||||||
; X86-NEXT: vpshldw $22, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x70,0xd1,0x16]
|
; X86-NEXT: vpshldw $6, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x70,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
; X86-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_512:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_512:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshldw $22, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x70,0xd9,0x16]
|
; X64-NEXT: vpshldw $6, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x70,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshldw $22, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x70,0xd1,0x16]
|
; X64-NEXT: vpshldw $6, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x70,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
; X64-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%1 = call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 22)
|
%1 = call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 6)
|
||||||
%2 = bitcast i32 %x4 to <32 x i1>
|
%2 = bitcast i32 %x4 to <32 x i1>
|
||||||
%3 = select <32 x i1> %2, <32 x i16> %1, <32 x i16> %x3
|
%3 = select <32 x i1> %2, <32 x i16> %1, <32 x i16> %x3
|
||||||
%4 = call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 22)
|
%4 = call <32 x i16> @llvm.x86.avx512.vpshld.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 6)
|
||||||
%res2 = add <32 x i16> %3, %4
|
%res2 = add <32 x i16> %3, %4
|
||||||
ret <32 x i16> %res2
|
ret <32 x i16> %res2
|
||||||
}
|
}
|
||||||
|
@ -224,23 +224,23 @@ declare <8 x i64> @llvm.x86.avx512.vpshrd.q.512(<8 x i64>, <8 x i64>, i32)
|
||||||
define <32 x i16>@test_int_x86_avx512_mask_vpshrd_w_512(<32 x i16> %x0, <32 x i16> %x1, <32 x i16> %x3, i32 %x4) {
|
define <32 x i16>@test_int_x86_avx512_mask_vpshrd_w_512(<32 x i16> %x0, <32 x i16> %x1, <32 x i16> %x3, i32 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_512:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_512:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshrdw $22, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x72,0xd9,0x16]
|
; X86-NEXT: vpshrdw $6, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x72,0xd9,0x06]
|
||||||
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1 # encoding: [0xc4,0xe1,0xf9,0x90,0x4c,0x24,0x04]
|
; X86-NEXT: kmovd {{[0-9]+}}(%esp), %k1 # encoding: [0xc4,0xe1,0xf9,0x90,0x4c,0x24,0x04]
|
||||||
; X86-NEXT: vpshrdw $22, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x72,0xd1,0x16]
|
; X86-NEXT: vpshrdw $6, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x72,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
; X86-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_512:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_512:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshrdw $22, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x72,0xd9,0x16]
|
; X64-NEXT: vpshrdw $6, %zmm1, %zmm0, %zmm3 # encoding: [0x62,0xf3,0xfd,0x48,0x72,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshrdw $22, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x72,0xd1,0x16]
|
; X64-NEXT: vpshrdw $6, %zmm1, %zmm0, %zmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x49,0x72,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
; X64-NEXT: vpaddw %zmm3, %zmm2, %zmm0 # encoding: [0x62,0xf1,0x6d,0x48,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%1 = call <32 x i16> @llvm.x86.avx512.vpshrd.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 22)
|
%1 = call <32 x i16> @llvm.x86.avx512.vpshrd.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 6)
|
||||||
%2 = bitcast i32 %x4 to <32 x i1>
|
%2 = bitcast i32 %x4 to <32 x i1>
|
||||||
%3 = select <32 x i1> %2, <32 x i16> %1, <32 x i16> %x3
|
%3 = select <32 x i1> %2, <32 x i16> %1, <32 x i16> %x3
|
||||||
%4 = call <32 x i16> @llvm.x86.avx512.vpshrd.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 22)
|
%4 = call <32 x i16> @llvm.x86.avx512.vpshrd.w.512(<32 x i16> %x0, <32 x i16> %x1, i32 6)
|
||||||
%res2 = add <32 x i16> %3, %4
|
%res2 = add <32 x i16> %3, %4
|
||||||
ret <32 x i16> %res2
|
ret <32 x i16> %res2
|
||||||
}
|
}
|
||||||
|
|
|
@ -582,16 +582,16 @@ define <4 x i64> @test_mm256_mask_shldi_epi64(<4 x i64> %__S, i8 zeroext %__U, <
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldq $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X86-NEXT: vpshldq $47, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_mask_shldi_epi64:
|
; X64-LABEL: test_mm256_mask_shldi_epi64:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldq $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X64-NEXT: vpshldq $47, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = tail call <4 x i64> @llvm.x86.avx512.vpshld.q.256(<4 x i64> %__A, <4 x i64> %__B, i32 127)
|
%0 = tail call <4 x i64> @llvm.x86.avx512.vpshld.q.256(<4 x i64> %__A, <4 x i64> %__B, i32 47)
|
||||||
%1 = bitcast i8 %__U to <8 x i1>
|
%1 = bitcast i8 %__U to <8 x i1>
|
||||||
%extract = shufflevector <8 x i1> %1, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
%extract = shufflevector <8 x i1> %1, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
||||||
%2 = select <4 x i1> %extract, <4 x i64> %0, <4 x i64> %__S
|
%2 = select <4 x i1> %extract, <4 x i64> %0, <4 x i64> %__S
|
||||||
|
@ -636,23 +636,23 @@ define <2 x i64> @test_mm_mask_shldi_epi64(<2 x i64> %__S, i8 zeroext %__U, <2 x
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldq $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X86-NEXT: vpshldq $47, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_mask_shldi_epi64:
|
; X64-LABEL: test_mm_mask_shldi_epi64:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldq $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X64-NEXT: vpshldq $47, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = tail call <2 x i64> @llvm.x86.avx512.vpshld.q.128(<2 x i64> %__A, <2 x i64> %__B, i32 127)
|
%0 = tail call <2 x i64> @llvm.x86.avx512.vpshld.q.128(<2 x i64> %__A, <2 x i64> %__B, i32 47)
|
||||||
%1 = bitcast i8 %__U to <8 x i1>
|
%1 = bitcast i8 %__U to <8 x i1>
|
||||||
%extract = shufflevector <8 x i1> %1, <8 x i1> undef, <2 x i32> <i32 0, i32 1>
|
%extract = shufflevector <8 x i1> %1, <8 x i1> undef, <2 x i32> <i32 0, i32 1>
|
||||||
%2 = select <2 x i1> %extract, <2 x i64> %0, <2 x i64> %__S
|
%2 = select <2 x i1> %extract, <2 x i64> %0, <2 x i64> %__S
|
||||||
ret <2 x i64> %2
|
ret <2 x i64> %2
|
||||||
}
|
}
|
||||||
|
|
||||||
declare <2 x i64> @llvm.x86.avx512.vpshld.q.128(<2 x i64>, <2 x i64>, i32) #3
|
declare <2 x i64> @llvm.x86.avx512.vpshld.q.128(<2 x i64>, <2 x i64>, i32)
|
||||||
|
|
||||||
define <2 x i64> @test_mm_maskz_shldi_epi64(i8 zeroext %__U, <2 x i64> %__A, <2 x i64> %__B) {
|
define <2 x i64> @test_mm_maskz_shldi_epi64(i8 zeroext %__U, <2 x i64> %__A, <2 x i64> %__B) {
|
||||||
; X86-LABEL: test_mm_maskz_shldi_epi64:
|
; X86-LABEL: test_mm_maskz_shldi_epi64:
|
||||||
|
@ -690,18 +690,18 @@ define <4 x i64> @test_mm256_mask_shldi_epi32(<4 x i64> %__S, i8 zeroext %__U, <
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldd $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X86-NEXT: vpshldd $7, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_mask_shldi_epi32:
|
; X64-LABEL: test_mm256_mask_shldi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldd $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X64-NEXT: vpshldd $7, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <4 x i64> %__A to <8 x i32>
|
%0 = bitcast <4 x i64> %__A to <8 x i32>
|
||||||
%1 = bitcast <4 x i64> %__B to <8 x i32>
|
%1 = bitcast <4 x i64> %__B to <8 x i32>
|
||||||
%2 = tail call <8 x i32> @llvm.x86.avx512.vpshld.d.256(<8 x i32> %0, <8 x i32> %1, i32 127)
|
%2 = tail call <8 x i32> @llvm.x86.avx512.vpshld.d.256(<8 x i32> %0, <8 x i32> %1, i32 7)
|
||||||
%3 = bitcast <4 x i64> %__S to <8 x i32>
|
%3 = bitcast <4 x i64> %__S to <8 x i32>
|
||||||
%4 = bitcast i8 %__U to <8 x i1>
|
%4 = bitcast i8 %__U to <8 x i1>
|
||||||
%5 = select <8 x i1> %4, <8 x i32> %2, <8 x i32> %3
|
%5 = select <8 x i1> %4, <8 x i32> %2, <8 x i32> %3
|
||||||
|
@ -716,18 +716,18 @@ define <4 x i64> @test_mm256_maskz_shldi_epi32(i8 zeroext %__U, <4 x i64> %__A,
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldd $63, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
; X86-NEXT: vpshldd $15, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_maskz_shldi_epi32:
|
; X64-LABEL: test_mm256_maskz_shldi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldd $63, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
; X64-NEXT: vpshldd $15, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <4 x i64> %__A to <8 x i32>
|
%0 = bitcast <4 x i64> %__A to <8 x i32>
|
||||||
%1 = bitcast <4 x i64> %__B to <8 x i32>
|
%1 = bitcast <4 x i64> %__B to <8 x i32>
|
||||||
%2 = tail call <8 x i32> @llvm.x86.avx512.vpshld.d.256(<8 x i32> %0, <8 x i32> %1, i32 63)
|
%2 = tail call <8 x i32> @llvm.x86.avx512.vpshld.d.256(<8 x i32> %0, <8 x i32> %1, i32 15)
|
||||||
%3 = bitcast i8 %__U to <8 x i1>
|
%3 = bitcast i8 %__U to <8 x i1>
|
||||||
%4 = select <8 x i1> %3, <8 x i32> %2, <8 x i32> zeroinitializer
|
%4 = select <8 x i1> %3, <8 x i32> %2, <8 x i32> zeroinitializer
|
||||||
%5 = bitcast <8 x i32> %4 to <4 x i64>
|
%5 = bitcast <8 x i32> %4 to <4 x i64>
|
||||||
|
@ -752,18 +752,18 @@ define <2 x i64> @test_mm_mask_shldi_epi32(<2 x i64> %__S, i8 zeroext %__U, <2 x
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldd $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X86-NEXT: vpshldd $7, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_mask_shldi_epi32:
|
; X64-LABEL: test_mm_mask_shldi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldd $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X64-NEXT: vpshldd $7, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <2 x i64> %__A to <4 x i32>
|
%0 = bitcast <2 x i64> %__A to <4 x i32>
|
||||||
%1 = bitcast <2 x i64> %__B to <4 x i32>
|
%1 = bitcast <2 x i64> %__B to <4 x i32>
|
||||||
%2 = tail call <4 x i32> @llvm.x86.avx512.vpshld.d.128(<4 x i32> %0, <4 x i32> %1, i32 127)
|
%2 = tail call <4 x i32> @llvm.x86.avx512.vpshld.d.128(<4 x i32> %0, <4 x i32> %1, i32 7)
|
||||||
%3 = bitcast <2 x i64> %__S to <4 x i32>
|
%3 = bitcast <2 x i64> %__S to <4 x i32>
|
||||||
%4 = bitcast i8 %__U to <8 x i1>
|
%4 = bitcast i8 %__U to <8 x i1>
|
||||||
%extract = shufflevector <8 x i1> %4, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
%extract = shufflevector <8 x i1> %4, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
||||||
|
@ -779,18 +779,18 @@ define <2 x i64> @test_mm_maskz_shldi_epi32(i8 zeroext %__U, <2 x i64> %__A, <2
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldd $63, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
; X86-NEXT: vpshldd $15, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_maskz_shldi_epi32:
|
; X64-LABEL: test_mm_maskz_shldi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldd $63, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
; X64-NEXT: vpshldd $15, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <2 x i64> %__A to <4 x i32>
|
%0 = bitcast <2 x i64> %__A to <4 x i32>
|
||||||
%1 = bitcast <2 x i64> %__B to <4 x i32>
|
%1 = bitcast <2 x i64> %__B to <4 x i32>
|
||||||
%2 = tail call <4 x i32> @llvm.x86.avx512.vpshld.d.128(<4 x i32> %0, <4 x i32> %1, i32 63)
|
%2 = tail call <4 x i32> @llvm.x86.avx512.vpshld.d.128(<4 x i32> %0, <4 x i32> %1, i32 15)
|
||||||
%3 = bitcast i8 %__U to <8 x i1>
|
%3 = bitcast i8 %__U to <8 x i1>
|
||||||
%extract = shufflevector <8 x i1> %3, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
%extract = shufflevector <8 x i1> %3, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
||||||
%4 = select <4 x i1> %extract, <4 x i32> %2, <4 x i32> zeroinitializer
|
%4 = select <4 x i1> %extract, <4 x i32> %2, <4 x i32> zeroinitializer
|
||||||
|
@ -815,18 +815,18 @@ define <4 x i64> @test_mm256_mask_shldi_epi16(<4 x i64> %__S, i16 zeroext %__U,
|
||||||
; X86-LABEL: test_mm256_mask_shldi_epi16:
|
; X86-LABEL: test_mm256_mask_shldi_epi16:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshldw $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X86-NEXT: vpshldw $3, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_mask_shldi_epi16:
|
; X64-LABEL: test_mm256_mask_shldi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldw $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X64-NEXT: vpshldw $3, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <4 x i64> %__A to <16 x i16>
|
%0 = bitcast <4 x i64> %__A to <16 x i16>
|
||||||
%1 = bitcast <4 x i64> %__B to <16 x i16>
|
%1 = bitcast <4 x i64> %__B to <16 x i16>
|
||||||
%2 = tail call <16 x i16> @llvm.x86.avx512.vpshld.w.256(<16 x i16> %0, <16 x i16> %1, i32 127)
|
%2 = tail call <16 x i16> @llvm.x86.avx512.vpshld.w.256(<16 x i16> %0, <16 x i16> %1, i32 3)
|
||||||
%3 = bitcast <4 x i64> %__S to <16 x i16>
|
%3 = bitcast <4 x i64> %__S to <16 x i16>
|
||||||
%4 = bitcast i16 %__U to <16 x i1>
|
%4 = bitcast i16 %__U to <16 x i1>
|
||||||
%5 = select <16 x i1> %4, <16 x i16> %2, <16 x i16> %3
|
%5 = select <16 x i1> %4, <16 x i16> %2, <16 x i16> %3
|
||||||
|
@ -840,18 +840,18 @@ define <4 x i64> @test_mm256_maskz_shldi_epi16(i16 zeroext %__U, <4 x i64> %__A,
|
||||||
; X86-LABEL: test_mm256_maskz_shldi_epi16:
|
; X86-LABEL: test_mm256_maskz_shldi_epi16:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshldw $63, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
; X86-NEXT: vpshldw $7, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_maskz_shldi_epi16:
|
; X64-LABEL: test_mm256_maskz_shldi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldw $63, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
; X64-NEXT: vpshldw $7, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <4 x i64> %__A to <16 x i16>
|
%0 = bitcast <4 x i64> %__A to <16 x i16>
|
||||||
%1 = bitcast <4 x i64> %__B to <16 x i16>
|
%1 = bitcast <4 x i64> %__B to <16 x i16>
|
||||||
%2 = tail call <16 x i16> @llvm.x86.avx512.vpshld.w.256(<16 x i16> %0, <16 x i16> %1, i32 63)
|
%2 = tail call <16 x i16> @llvm.x86.avx512.vpshld.w.256(<16 x i16> %0, <16 x i16> %1, i32 7)
|
||||||
%3 = bitcast i16 %__U to <16 x i1>
|
%3 = bitcast i16 %__U to <16 x i1>
|
||||||
%4 = select <16 x i1> %3, <16 x i16> %2, <16 x i16> zeroinitializer
|
%4 = select <16 x i1> %3, <16 x i16> %2, <16 x i16> zeroinitializer
|
||||||
%5 = bitcast <16 x i16> %4 to <4 x i64>
|
%5 = bitcast <16 x i16> %4 to <4 x i64>
|
||||||
|
@ -876,18 +876,18 @@ define <2 x i64> @test_mm_mask_shldi_epi16(<2 x i64> %__S, i8 zeroext %__U, <2 x
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldw $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X86-NEXT: vpshldw $3, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_mask_shldi_epi16:
|
; X64-LABEL: test_mm_mask_shldi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldw $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X64-NEXT: vpshldw $3, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <2 x i64> %__A to <8 x i16>
|
%0 = bitcast <2 x i64> %__A to <8 x i16>
|
||||||
%1 = bitcast <2 x i64> %__B to <8 x i16>
|
%1 = bitcast <2 x i64> %__B to <8 x i16>
|
||||||
%2 = tail call <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16> %0, <8 x i16> %1, i32 127)
|
%2 = tail call <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16> %0, <8 x i16> %1, i32 3)
|
||||||
%3 = bitcast <2 x i64> %__S to <8 x i16>
|
%3 = bitcast <2 x i64> %__S to <8 x i16>
|
||||||
%4 = bitcast i8 %__U to <8 x i1>
|
%4 = bitcast i8 %__U to <8 x i1>
|
||||||
%5 = select <8 x i1> %4, <8 x i16> %2, <8 x i16> %3
|
%5 = select <8 x i1> %4, <8 x i16> %2, <8 x i16> %3
|
||||||
|
@ -902,18 +902,18 @@ define <2 x i64> @test_mm_maskz_shldi_epi16(i8 zeroext %__U, <2 x i64> %__A, <2
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshldw $63, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
; X86-NEXT: vpshldw $7, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_maskz_shldi_epi16:
|
; X64-LABEL: test_mm_maskz_shldi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshldw $63, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
; X64-NEXT: vpshldw $7, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <2 x i64> %__A to <8 x i16>
|
%0 = bitcast <2 x i64> %__A to <8 x i16>
|
||||||
%1 = bitcast <2 x i64> %__B to <8 x i16>
|
%1 = bitcast <2 x i64> %__B to <8 x i16>
|
||||||
%2 = tail call <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16> %0, <8 x i16> %1, i32 63)
|
%2 = tail call <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16> %0, <8 x i16> %1, i32 7)
|
||||||
%3 = bitcast i8 %__U to <8 x i1>
|
%3 = bitcast i8 %__U to <8 x i1>
|
||||||
%4 = select <8 x i1> %3, <8 x i16> %2, <8 x i16> zeroinitializer
|
%4 = select <8 x i1> %3, <8 x i16> %2, <8 x i16> zeroinitializer
|
||||||
%5 = bitcast <8 x i16> %4 to <2 x i64>
|
%5 = bitcast <8 x i16> %4 to <2 x i64>
|
||||||
|
@ -938,16 +938,16 @@ define <4 x i64> @test_mm256_mask_shrdi_epi64(<4 x i64> %__S, i8 zeroext %__U, <
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdq $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X86-NEXT: vpshrdq $47, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_mask_shrdi_epi64:
|
; X64-LABEL: test_mm256_mask_shrdi_epi64:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdq $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X64-NEXT: vpshrdq $47, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = tail call <4 x i64> @llvm.x86.avx512.vpshrd.q.256(<4 x i64> %__A, <4 x i64> %__B, i32 127)
|
%0 = tail call <4 x i64> @llvm.x86.avx512.vpshrd.q.256(<4 x i64> %__A, <4 x i64> %__B, i32 47)
|
||||||
%1 = bitcast i8 %__U to <8 x i1>
|
%1 = bitcast i8 %__U to <8 x i1>
|
||||||
%extract = shufflevector <8 x i1> %1, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
%extract = shufflevector <8 x i1> %1, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
||||||
%2 = select <4 x i1> %extract, <4 x i64> %0, <4 x i64> %__S
|
%2 = select <4 x i1> %extract, <4 x i64> %0, <4 x i64> %__S
|
||||||
|
@ -992,16 +992,16 @@ define <2 x i64> @test_mm_mask_shrdi_epi64(<2 x i64> %__S, i8 zeroext %__U, <2 x
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdq $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X86-NEXT: vpshrdq $47, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_mask_shrdi_epi64:
|
; X64-LABEL: test_mm_mask_shrdi_epi64:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdq $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X64-NEXT: vpshrdq $47, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = tail call <2 x i64> @llvm.x86.avx512.vpshrd.q.128(<2 x i64> %__A, <2 x i64> %__B, i32 127)
|
%0 = tail call <2 x i64> @llvm.x86.avx512.vpshrd.q.128(<2 x i64> %__A, <2 x i64> %__B, i32 47)
|
||||||
%1 = bitcast i8 %__U to <8 x i1>
|
%1 = bitcast i8 %__U to <8 x i1>
|
||||||
%extract = shufflevector <8 x i1> %1, <8 x i1> undef, <2 x i32> <i32 0, i32 1>
|
%extract = shufflevector <8 x i1> %1, <8 x i1> undef, <2 x i32> <i32 0, i32 1>
|
||||||
%2 = select <2 x i1> %extract, <2 x i64> %0, <2 x i64> %__S
|
%2 = select <2 x i1> %extract, <2 x i64> %0, <2 x i64> %__S
|
||||||
|
@ -1046,18 +1046,18 @@ define <4 x i64> @test_mm256_mask_shrdi_epi32(<4 x i64> %__S, i8 zeroext %__U, <
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdd $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X86-NEXT: vpshrdd $7, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_mask_shrdi_epi32:
|
; X64-LABEL: test_mm256_mask_shrdi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdd $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X64-NEXT: vpshrdd $7, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <4 x i64> %__A to <8 x i32>
|
%0 = bitcast <4 x i64> %__A to <8 x i32>
|
||||||
%1 = bitcast <4 x i64> %__B to <8 x i32>
|
%1 = bitcast <4 x i64> %__B to <8 x i32>
|
||||||
%2 = tail call <8 x i32> @llvm.x86.avx512.vpshrd.d.256(<8 x i32> %0, <8 x i32> %1, i32 127)
|
%2 = tail call <8 x i32> @llvm.x86.avx512.vpshrd.d.256(<8 x i32> %0, <8 x i32> %1, i32 7)
|
||||||
%3 = bitcast <4 x i64> %__S to <8 x i32>
|
%3 = bitcast <4 x i64> %__S to <8 x i32>
|
||||||
%4 = bitcast i8 %__U to <8 x i1>
|
%4 = bitcast i8 %__U to <8 x i1>
|
||||||
%5 = select <8 x i1> %4, <8 x i32> %2, <8 x i32> %3
|
%5 = select <8 x i1> %4, <8 x i32> %2, <8 x i32> %3
|
||||||
|
@ -1072,18 +1072,18 @@ define <4 x i64> @test_mm256_maskz_shrdi_epi32(i8 zeroext %__U, <4 x i64> %__A,
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdd $63, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
; X86-NEXT: vpshrdd $15, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_maskz_shrdi_epi32:
|
; X64-LABEL: test_mm256_maskz_shrdi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdd $63, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
; X64-NEXT: vpshrdd $15, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <4 x i64> %__A to <8 x i32>
|
%0 = bitcast <4 x i64> %__A to <8 x i32>
|
||||||
%1 = bitcast <4 x i64> %__B to <8 x i32>
|
%1 = bitcast <4 x i64> %__B to <8 x i32>
|
||||||
%2 = tail call <8 x i32> @llvm.x86.avx512.vpshrd.d.256(<8 x i32> %0, <8 x i32> %1, i32 63)
|
%2 = tail call <8 x i32> @llvm.x86.avx512.vpshrd.d.256(<8 x i32> %0, <8 x i32> %1, i32 15)
|
||||||
%3 = bitcast i8 %__U to <8 x i1>
|
%3 = bitcast i8 %__U to <8 x i1>
|
||||||
%4 = select <8 x i1> %3, <8 x i32> %2, <8 x i32> zeroinitializer
|
%4 = select <8 x i1> %3, <8 x i32> %2, <8 x i32> zeroinitializer
|
||||||
%5 = bitcast <8 x i32> %4 to <4 x i64>
|
%5 = bitcast <8 x i32> %4 to <4 x i64>
|
||||||
|
@ -1108,18 +1108,18 @@ define <2 x i64> @test_mm_mask_shrdi_epi32(<2 x i64> %__S, i8 zeroext %__U, <2 x
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdd $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X86-NEXT: vpshrdd $7, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_mask_shrdi_epi32:
|
; X64-LABEL: test_mm_mask_shrdi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdd $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X64-NEXT: vpshrdd $7, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <2 x i64> %__A to <4 x i32>
|
%0 = bitcast <2 x i64> %__A to <4 x i32>
|
||||||
%1 = bitcast <2 x i64> %__B to <4 x i32>
|
%1 = bitcast <2 x i64> %__B to <4 x i32>
|
||||||
%2 = tail call <4 x i32> @llvm.x86.avx512.vpshrd.d.128(<4 x i32> %0, <4 x i32> %1, i32 127)
|
%2 = tail call <4 x i32> @llvm.x86.avx512.vpshrd.d.128(<4 x i32> %0, <4 x i32> %1, i32 7)
|
||||||
%3 = bitcast <2 x i64> %__S to <4 x i32>
|
%3 = bitcast <2 x i64> %__S to <4 x i32>
|
||||||
%4 = bitcast i8 %__U to <8 x i1>
|
%4 = bitcast i8 %__U to <8 x i1>
|
||||||
%extract = shufflevector <8 x i1> %4, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
%extract = shufflevector <8 x i1> %4, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
||||||
|
@ -1135,18 +1135,18 @@ define <2 x i64> @test_mm_maskz_shrdi_epi32(i8 zeroext %__U, <2 x i64> %__A, <2
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdd $63, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
; X86-NEXT: vpshrdd $15, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_maskz_shrdi_epi32:
|
; X64-LABEL: test_mm_maskz_shrdi_epi32:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdd $63, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
; X64-NEXT: vpshrdd $15, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <2 x i64> %__A to <4 x i32>
|
%0 = bitcast <2 x i64> %__A to <4 x i32>
|
||||||
%1 = bitcast <2 x i64> %__B to <4 x i32>
|
%1 = bitcast <2 x i64> %__B to <4 x i32>
|
||||||
%2 = tail call <4 x i32> @llvm.x86.avx512.vpshrd.d.128(<4 x i32> %0, <4 x i32> %1, i32 63)
|
%2 = tail call <4 x i32> @llvm.x86.avx512.vpshrd.d.128(<4 x i32> %0, <4 x i32> %1, i32 15)
|
||||||
%3 = bitcast i8 %__U to <8 x i1>
|
%3 = bitcast i8 %__U to <8 x i1>
|
||||||
%extract = shufflevector <8 x i1> %3, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
%extract = shufflevector <8 x i1> %3, <8 x i1> undef, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
|
||||||
%4 = select <4 x i1> %extract, <4 x i32> %2, <4 x i32> zeroinitializer
|
%4 = select <4 x i1> %extract, <4 x i32> %2, <4 x i32> zeroinitializer
|
||||||
|
@ -1171,18 +1171,18 @@ define <4 x i64> @test_mm256_mask_shrdi_epi16(<4 x i64> %__S, i16 zeroext %__U,
|
||||||
; X86-LABEL: test_mm256_mask_shrdi_epi16:
|
; X86-LABEL: test_mm256_mask_shrdi_epi16:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshrdw $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X86-NEXT: vpshrdw $3, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_mask_shrdi_epi16:
|
; X64-LABEL: test_mm256_mask_shrdi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdw $127, %ymm2, %ymm1, %ymm0 {%k1}
|
; X64-NEXT: vpshrdw $3, %ymm2, %ymm1, %ymm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <4 x i64> %__A to <16 x i16>
|
%0 = bitcast <4 x i64> %__A to <16 x i16>
|
||||||
%1 = bitcast <4 x i64> %__B to <16 x i16>
|
%1 = bitcast <4 x i64> %__B to <16 x i16>
|
||||||
%2 = tail call <16 x i16> @llvm.x86.avx512.vpshrd.w.256(<16 x i16> %0, <16 x i16> %1, i32 127)
|
%2 = tail call <16 x i16> @llvm.x86.avx512.vpshrd.w.256(<16 x i16> %0, <16 x i16> %1, i32 3)
|
||||||
%3 = bitcast <4 x i64> %__S to <16 x i16>
|
%3 = bitcast <4 x i64> %__S to <16 x i16>
|
||||||
%4 = bitcast i16 %__U to <16 x i1>
|
%4 = bitcast i16 %__U to <16 x i1>
|
||||||
%5 = select <16 x i1> %4, <16 x i16> %2, <16 x i16> %3
|
%5 = select <16 x i1> %4, <16 x i16> %2, <16 x i16> %3
|
||||||
|
@ -1196,18 +1196,18 @@ define <4 x i64> @test_mm256_maskz_shrdi_epi16(i16 zeroext %__U, <4 x i64> %__A,
|
||||||
; X86-LABEL: test_mm256_maskz_shrdi_epi16:
|
; X86-LABEL: test_mm256_maskz_shrdi_epi16:
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1
|
||||||
; X86-NEXT: vpshrdw $63, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
; X86-NEXT: vpshrdw $7, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm256_maskz_shrdi_epi16:
|
; X64-LABEL: test_mm256_maskz_shrdi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdw $63, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
; X64-NEXT: vpshrdw $7, %ymm1, %ymm0, %ymm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <4 x i64> %__A to <16 x i16>
|
%0 = bitcast <4 x i64> %__A to <16 x i16>
|
||||||
%1 = bitcast <4 x i64> %__B to <16 x i16>
|
%1 = bitcast <4 x i64> %__B to <16 x i16>
|
||||||
%2 = tail call <16 x i16> @llvm.x86.avx512.vpshrd.w.256(<16 x i16> %0, <16 x i16> %1, i32 63)
|
%2 = tail call <16 x i16> @llvm.x86.avx512.vpshrd.w.256(<16 x i16> %0, <16 x i16> %1, i32 7)
|
||||||
%3 = bitcast i16 %__U to <16 x i1>
|
%3 = bitcast i16 %__U to <16 x i1>
|
||||||
%4 = select <16 x i1> %3, <16 x i16> %2, <16 x i16> zeroinitializer
|
%4 = select <16 x i1> %3, <16 x i16> %2, <16 x i16> zeroinitializer
|
||||||
%5 = bitcast <16 x i16> %4 to <4 x i64>
|
%5 = bitcast <16 x i16> %4 to <4 x i64>
|
||||||
|
@ -1232,18 +1232,18 @@ define <2 x i64> @test_mm_mask_shrdi_epi16(<2 x i64> %__S, i8 zeroext %__U, <2 x
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdw $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X86-NEXT: vpshrdw $3, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_mask_shrdi_epi16:
|
; X64-LABEL: test_mm_mask_shrdi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdw $127, %xmm2, %xmm1, %xmm0 {%k1}
|
; X64-NEXT: vpshrdw $3, %xmm2, %xmm1, %xmm0 {%k1}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <2 x i64> %__A to <8 x i16>
|
%0 = bitcast <2 x i64> %__A to <8 x i16>
|
||||||
%1 = bitcast <2 x i64> %__B to <8 x i16>
|
%1 = bitcast <2 x i64> %__B to <8 x i16>
|
||||||
%2 = tail call <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16> %0, <8 x i16> %1, i32 127)
|
%2 = tail call <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16> %0, <8 x i16> %1, i32 3)
|
||||||
%3 = bitcast <2 x i64> %__S to <8 x i16>
|
%3 = bitcast <2 x i64> %__S to <8 x i16>
|
||||||
%4 = bitcast i8 %__U to <8 x i1>
|
%4 = bitcast i8 %__U to <8 x i1>
|
||||||
%5 = select <8 x i1> %4, <8 x i16> %2, <8 x i16> %3
|
%5 = select <8 x i1> %4, <8 x i16> %2, <8 x i16> %3
|
||||||
|
@ -1258,18 +1258,18 @@ define <2 x i64> @test_mm_maskz_shrdi_epi16(i8 zeroext %__U, <2 x i64> %__A, <2
|
||||||
; X86: # %bb.0: # %entry
|
; X86: # %bb.0: # %entry
|
||||||
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
; X86-NEXT: movb {{[0-9]+}}(%esp), %al
|
||||||
; X86-NEXT: kmovd %eax, %k1
|
; X86-NEXT: kmovd %eax, %k1
|
||||||
; X86-NEXT: vpshrdw $63, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
; X86-NEXT: vpshrdw $7, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
||||||
; X86-NEXT: retl
|
; X86-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_mm_maskz_shrdi_epi16:
|
; X64-LABEL: test_mm_maskz_shrdi_epi16:
|
||||||
; X64: # %bb.0: # %entry
|
; X64: # %bb.0: # %entry
|
||||||
; X64-NEXT: kmovd %edi, %k1
|
; X64-NEXT: kmovd %edi, %k1
|
||||||
; X64-NEXT: vpshrdw $63, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
; X64-NEXT: vpshrdw $7, %xmm1, %xmm0, %xmm0 {%k1} {z}
|
||||||
; X64-NEXT: retq
|
; X64-NEXT: retq
|
||||||
entry:
|
entry:
|
||||||
%0 = bitcast <2 x i64> %__A to <8 x i16>
|
%0 = bitcast <2 x i64> %__A to <8 x i16>
|
||||||
%1 = bitcast <2 x i64> %__B to <8 x i16>
|
%1 = bitcast <2 x i64> %__B to <8 x i16>
|
||||||
%2 = tail call <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16> %0, <8 x i16> %1, i32 63)
|
%2 = tail call <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16> %0, <8 x i16> %1, i32 7)
|
||||||
%3 = bitcast i8 %__U to <8 x i1>
|
%3 = bitcast i8 %__U to <8 x i1>
|
||||||
%4 = select <8 x i1> %3, <8 x i16> %2, <8 x i16> zeroinitializer
|
%4 = select <8 x i1> %3, <8 x i16> %2, <8 x i16> zeroinitializer
|
||||||
%5 = bitcast <8 x i16> %4 to <2 x i64>
|
%5 = bitcast <8 x i16> %4 to <2 x i64>
|
||||||
|
|
|
@ -474,22 +474,22 @@ declare <4 x i64> @llvm.x86.avx512.mask.vpshld.q.256(<4 x i64>, <4 x i64>, i32,
|
||||||
define <8 x i16>@test_int_x86_avx512_mask_vpshld_w_128(<8 x i16> %x0, <8 x i16> %x1, <8 x i16> %x3, i8 %x4) {
|
define <8 x i16>@test_int_x86_avx512_mask_vpshld_w_128(<8 x i16> %x0, <8 x i16> %x1, <8 x i16> %x3, i8 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_128:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_128:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshldw $22, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x70,0xd9,0x16]
|
; X86-NEXT: vpshldw $6, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x70,0xd9,0x06]
|
||||||
; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax # encoding: [0x0f,0xb6,0x44,0x24,0x04]
|
; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax # encoding: [0x0f,0xb6,0x44,0x24,0x04]
|
||||||
; X86-NEXT: kmovd %eax, %k1 # encoding: [0xc5,0xfb,0x92,0xc8]
|
; X86-NEXT: kmovd %eax, %k1 # encoding: [0xc5,0xfb,0x92,0xc8]
|
||||||
; X86-NEXT: vpshldw $22, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x70,0xd1,0x16]
|
; X86-NEXT: vpshldw $6, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x70,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
; X86-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_128:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_128:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshldw $22, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x70,0xd9,0x16]
|
; X64-NEXT: vpshldw $6, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x70,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshldw $22, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x70,0xd1,0x16]
|
; X64-NEXT: vpshldw $6, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x70,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
; X64-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%res = call <8 x i16> @llvm.x86.avx512.mask.vpshld.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 22, <8 x i16> %x3, i8 %x4)
|
%res = call <8 x i16> @llvm.x86.avx512.mask.vpshld.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 6, <8 x i16> %x3, i8 %x4)
|
||||||
%res1 = call <8 x i16> @llvm.x86.avx512.mask.vpshld.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 22, <8 x i16> %x3, i8 -1)
|
%res1 = call <8 x i16> @llvm.x86.avx512.mask.vpshld.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 6, <8 x i16> %x3, i8 -1)
|
||||||
%res2 = add <8 x i16> %res, %res1
|
%res2 = add <8 x i16> %res, %res1
|
||||||
ret <8 x i16> %res2
|
ret <8 x i16> %res2
|
||||||
}
|
}
|
||||||
|
@ -498,21 +498,21 @@ declare <8 x i16> @llvm.x86.avx512.mask.vpshld.w.128(<8 x i16>, <8 x i16>, i32,
|
||||||
define <16 x i16>@test_int_x86_avx512_mask_vpshld_w_256(<16 x i16> %x0, <16 x i16> %x1, <16 x i16> %x3, i16 %x4) {
|
define <16 x i16>@test_int_x86_avx512_mask_vpshld_w_256(<16 x i16> %x0, <16 x i16> %x1, <16 x i16> %x3, i16 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_256:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_256:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshldw $22, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x70,0xd9,0x16]
|
; X86-NEXT: vpshldw $6, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x70,0xd9,0x06]
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1 # encoding: [0xc5,0xf8,0x90,0x4c,0x24,0x04]
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1 # encoding: [0xc5,0xf8,0x90,0x4c,0x24,0x04]
|
||||||
; X86-NEXT: vpshldw $22, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x70,0xd1,0x16]
|
; X86-NEXT: vpshldw $6, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x70,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
; X86-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_256:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_256:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshldw $22, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x70,0xd9,0x16]
|
; X64-NEXT: vpshldw $6, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x70,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshldw $22, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x70,0xd1,0x16]
|
; X64-NEXT: vpshldw $6, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x70,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
; X64-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%res = call <16 x i16> @llvm.x86.avx512.mask.vpshld.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 22, <16 x i16> %x3, i16 %x4)
|
%res = call <16 x i16> @llvm.x86.avx512.mask.vpshld.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 6, <16 x i16> %x3, i16 %x4)
|
||||||
%res1 = call <16 x i16> @llvm.x86.avx512.mask.vpshld.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 22, <16 x i16> %x3, i16 -1)
|
%res1 = call <16 x i16> @llvm.x86.avx512.mask.vpshld.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 6, <16 x i16> %x3, i16 -1)
|
||||||
%res2 = add <16 x i16> %res, %res1
|
%res2 = add <16 x i16> %res, %res1
|
||||||
ret <16 x i16> %res2
|
ret <16 x i16> %res2
|
||||||
}
|
}
|
||||||
|
@ -623,22 +623,22 @@ declare <4 x i64> @llvm.x86.avx512.mask.vpshrd.q.256(<4 x i64>, <4 x i64>, i32,
|
||||||
define <8 x i16>@test_int_x86_avx512_mask_vpshrd_w_128(<8 x i16> %x0, <8 x i16> %x1, <8 x i16> %x3, i8 %x4) {
|
define <8 x i16>@test_int_x86_avx512_mask_vpshrd_w_128(<8 x i16> %x0, <8 x i16> %x1, <8 x i16> %x3, i8 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_128:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_128:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshrdw $22, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x72,0xd9,0x16]
|
; X86-NEXT: vpshrdw $6, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x72,0xd9,0x06]
|
||||||
; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax # encoding: [0x0f,0xb6,0x44,0x24,0x04]
|
; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax # encoding: [0x0f,0xb6,0x44,0x24,0x04]
|
||||||
; X86-NEXT: kmovd %eax, %k1 # encoding: [0xc5,0xfb,0x92,0xc8]
|
; X86-NEXT: kmovd %eax, %k1 # encoding: [0xc5,0xfb,0x92,0xc8]
|
||||||
; X86-NEXT: vpshrdw $22, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x72,0xd1,0x16]
|
; X86-NEXT: vpshrdw $6, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x72,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
; X86-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_128:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_128:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshrdw $22, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x72,0xd9,0x16]
|
; X64-NEXT: vpshrdw $6, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x72,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshrdw $22, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x72,0xd1,0x16]
|
; X64-NEXT: vpshrdw $6, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x72,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
; X64-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%res = call <8 x i16> @llvm.x86.avx512.mask.vpshrd.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 22, <8 x i16> %x3, i8 %x4)
|
%res = call <8 x i16> @llvm.x86.avx512.mask.vpshrd.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 6, <8 x i16> %x3, i8 %x4)
|
||||||
%res1 = call <8 x i16> @llvm.x86.avx512.mask.vpshrd.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 22, <8 x i16> %x3, i8 -1)
|
%res1 = call <8 x i16> @llvm.x86.avx512.mask.vpshrd.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 6, <8 x i16> %x3, i8 -1)
|
||||||
%res2 = add <8 x i16> %res, %res1
|
%res2 = add <8 x i16> %res, %res1
|
||||||
ret <8 x i16> %res2
|
ret <8 x i16> %res2
|
||||||
}
|
}
|
||||||
|
@ -647,21 +647,21 @@ declare <8 x i16> @llvm.x86.avx512.mask.vpshrd.w.128(<8 x i16>, <8 x i16>, i32,
|
||||||
define <16 x i16>@test_int_x86_avx512_mask_vpshrd_w_256(<16 x i16> %x0, <16 x i16> %x1, <16 x i16> %x3, i16 %x4) {
|
define <16 x i16>@test_int_x86_avx512_mask_vpshrd_w_256(<16 x i16> %x0, <16 x i16> %x1, <16 x i16> %x3, i16 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_256:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_256:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshrdw $22, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x72,0xd9,0x16]
|
; X86-NEXT: vpshrdw $6, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x72,0xd9,0x06]
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1 # encoding: [0xc5,0xf8,0x90,0x4c,0x24,0x04]
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1 # encoding: [0xc5,0xf8,0x90,0x4c,0x24,0x04]
|
||||||
; X86-NEXT: vpshrdw $22, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x72,0xd1,0x16]
|
; X86-NEXT: vpshrdw $6, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x72,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
; X86-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_256:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_256:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshrdw $22, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x72,0xd9,0x16]
|
; X64-NEXT: vpshrdw $6, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x72,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshrdw $22, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x72,0xd1,0x16]
|
; X64-NEXT: vpshrdw $6, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x72,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
; X64-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%res = call <16 x i16> @llvm.x86.avx512.mask.vpshrd.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 22, <16 x i16> %x3, i16 %x4)
|
%res = call <16 x i16> @llvm.x86.avx512.mask.vpshrd.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 6, <16 x i16> %x3, i16 %x4)
|
||||||
%res1 = call <16 x i16> @llvm.x86.avx512.mask.vpshrd.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 22, <16 x i16> %x3, i16 -1)
|
%res1 = call <16 x i16> @llvm.x86.avx512.mask.vpshrd.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 6, <16 x i16> %x3, i16 -1)
|
||||||
%res2 = add <16 x i16> %res, %res1
|
%res2 = add <16 x i16> %res, %res1
|
||||||
ret <16 x i16> %res2
|
ret <16 x i16> %res2
|
||||||
}
|
}
|
||||||
|
|
|
@ -477,24 +477,24 @@ declare <4 x i64> @llvm.x86.avx512.vpshld.q.256(<4 x i64>, <4 x i64>, i32)
|
||||||
define <8 x i16>@test_int_x86_avx512_mask_vpshld_w_128(<8 x i16> %x0, <8 x i16> %x1, <8 x i16> %x3, i8 %x4) {
|
define <8 x i16>@test_int_x86_avx512_mask_vpshld_w_128(<8 x i16> %x0, <8 x i16> %x1, <8 x i16> %x3, i8 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_128:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_128:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshldw $22, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x70,0xd9,0x16]
|
; X86-NEXT: vpshldw $6, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x70,0xd9,0x06]
|
||||||
; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax # encoding: [0x0f,0xb6,0x44,0x24,0x04]
|
; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax # encoding: [0x0f,0xb6,0x44,0x24,0x04]
|
||||||
; X86-NEXT: kmovd %eax, %k1 # encoding: [0xc5,0xfb,0x92,0xc8]
|
; X86-NEXT: kmovd %eax, %k1 # encoding: [0xc5,0xfb,0x92,0xc8]
|
||||||
; X86-NEXT: vpshldw $22, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x70,0xd1,0x16]
|
; X86-NEXT: vpshldw $6, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x70,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
; X86-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_128:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_128:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshldw $22, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x70,0xd9,0x16]
|
; X64-NEXT: vpshldw $6, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x70,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshldw $22, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x70,0xd1,0x16]
|
; X64-NEXT: vpshldw $6, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x70,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
; X64-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%1 = call <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 22)
|
%1 = call <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 6)
|
||||||
%2 = bitcast i8 %x4 to <8 x i1>
|
%2 = bitcast i8 %x4 to <8 x i1>
|
||||||
%3 = select <8 x i1> %2, <8 x i16> %1, <8 x i16> %x3
|
%3 = select <8 x i1> %2, <8 x i16> %1, <8 x i16> %x3
|
||||||
%4 = call <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 22)
|
%4 = call <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 6)
|
||||||
%res2 = add <8 x i16> %3, %4
|
%res2 = add <8 x i16> %3, %4
|
||||||
ret <8 x i16> %res2
|
ret <8 x i16> %res2
|
||||||
}
|
}
|
||||||
|
@ -503,23 +503,23 @@ declare <8 x i16> @llvm.x86.avx512.vpshld.w.128(<8 x i16>, <8 x i16>, i32)
|
||||||
define <16 x i16>@test_int_x86_avx512_mask_vpshld_w_256(<16 x i16> %x0, <16 x i16> %x1, <16 x i16> %x3, i16 %x4) {
|
define <16 x i16>@test_int_x86_avx512_mask_vpshld_w_256(<16 x i16> %x0, <16 x i16> %x1, <16 x i16> %x3, i16 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_256:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshld_w_256:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshldw $22, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x70,0xd9,0x16]
|
; X86-NEXT: vpshldw $6, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x70,0xd9,0x06]
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1 # encoding: [0xc5,0xf8,0x90,0x4c,0x24,0x04]
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1 # encoding: [0xc5,0xf8,0x90,0x4c,0x24,0x04]
|
||||||
; X86-NEXT: vpshldw $22, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x70,0xd1,0x16]
|
; X86-NEXT: vpshldw $6, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x70,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
; X86-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_256:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshld_w_256:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshldw $22, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x70,0xd9,0x16]
|
; X64-NEXT: vpshldw $6, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x70,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshldw $22, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x70,0xd1,0x16]
|
; X64-NEXT: vpshldw $6, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x70,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
; X64-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%1 = call <16 x i16> @llvm.x86.avx512.vpshld.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 22)
|
%1 = call <16 x i16> @llvm.x86.avx512.vpshld.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 6)
|
||||||
%2 = bitcast i16 %x4 to <16 x i1>
|
%2 = bitcast i16 %x4 to <16 x i1>
|
||||||
%3 = select <16 x i1> %2, <16 x i16> %1, <16 x i16> %x3
|
%3 = select <16 x i1> %2, <16 x i16> %1, <16 x i16> %x3
|
||||||
%4 = call <16 x i16> @llvm.x86.avx512.vpshld.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 22)
|
%4 = call <16 x i16> @llvm.x86.avx512.vpshld.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 6)
|
||||||
%res2 = add <16 x i16> %3, %4
|
%res2 = add <16 x i16> %3, %4
|
||||||
ret <16 x i16> %res2
|
ret <16 x i16> %res2
|
||||||
}
|
}
|
||||||
|
@ -644,24 +644,24 @@ declare <4 x i64> @llvm.x86.avx512.vpshrd.q.256(<4 x i64>, <4 x i64>, i32)
|
||||||
define <8 x i16>@test_int_x86_avx512_mask_vpshrd_w_128(<8 x i16> %x0, <8 x i16> %x1, <8 x i16> %x3, i8 %x4) {
|
define <8 x i16>@test_int_x86_avx512_mask_vpshrd_w_128(<8 x i16> %x0, <8 x i16> %x1, <8 x i16> %x3, i8 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_128:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_128:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshrdw $22, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x72,0xd9,0x16]
|
; X86-NEXT: vpshrdw $6, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x72,0xd9,0x06]
|
||||||
; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax # encoding: [0x0f,0xb6,0x44,0x24,0x04]
|
; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax # encoding: [0x0f,0xb6,0x44,0x24,0x04]
|
||||||
; X86-NEXT: kmovd %eax, %k1 # encoding: [0xc5,0xfb,0x92,0xc8]
|
; X86-NEXT: kmovd %eax, %k1 # encoding: [0xc5,0xfb,0x92,0xc8]
|
||||||
; X86-NEXT: vpshrdw $22, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x72,0xd1,0x16]
|
; X86-NEXT: vpshrdw $6, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x72,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
; X86-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_128:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_128:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshrdw $22, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x72,0xd9,0x16]
|
; X64-NEXT: vpshrdw $6, %xmm1, %xmm0, %xmm3 # encoding: [0x62,0xf3,0xfd,0x08,0x72,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshrdw $22, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x72,0xd1,0x16]
|
; X64-NEXT: vpshrdw $6, %xmm1, %xmm0, %xmm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x09,0x72,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
; X64-NEXT: vpaddw %xmm3, %xmm2, %xmm0 # EVEX TO VEX Compression encoding: [0xc5,0xe9,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%1 = call <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 22)
|
%1 = call <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 6)
|
||||||
%2 = bitcast i8 %x4 to <8 x i1>
|
%2 = bitcast i8 %x4 to <8 x i1>
|
||||||
%3 = select <8 x i1> %2, <8 x i16> %1, <8 x i16> %x3
|
%3 = select <8 x i1> %2, <8 x i16> %1, <8 x i16> %x3
|
||||||
%4 = call <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 22)
|
%4 = call <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16> %x0, <8 x i16> %x1, i32 6)
|
||||||
%res2 = add <8 x i16> %3, %4
|
%res2 = add <8 x i16> %3, %4
|
||||||
ret <8 x i16> %res2
|
ret <8 x i16> %res2
|
||||||
}
|
}
|
||||||
|
@ -670,23 +670,23 @@ declare <8 x i16> @llvm.x86.avx512.vpshrd.w.128(<8 x i16>, <8 x i16>, i32)
|
||||||
define <16 x i16>@test_int_x86_avx512_mask_vpshrd_w_256(<16 x i16> %x0, <16 x i16> %x1, <16 x i16> %x3, i16 %x4) {
|
define <16 x i16>@test_int_x86_avx512_mask_vpshrd_w_256(<16 x i16> %x0, <16 x i16> %x1, <16 x i16> %x3, i16 %x4) {
|
||||||
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_256:
|
; X86-LABEL: test_int_x86_avx512_mask_vpshrd_w_256:
|
||||||
; X86: # %bb.0:
|
; X86: # %bb.0:
|
||||||
; X86-NEXT: vpshrdw $22, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x72,0xd9,0x16]
|
; X86-NEXT: vpshrdw $6, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x72,0xd9,0x06]
|
||||||
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1 # encoding: [0xc5,0xf8,0x90,0x4c,0x24,0x04]
|
; X86-NEXT: kmovw {{[0-9]+}}(%esp), %k1 # encoding: [0xc5,0xf8,0x90,0x4c,0x24,0x04]
|
||||||
; X86-NEXT: vpshrdw $22, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x72,0xd1,0x16]
|
; X86-NEXT: vpshrdw $6, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x72,0xd1,0x06]
|
||||||
; X86-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
; X86-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
||||||
; X86-NEXT: retl # encoding: [0xc3]
|
; X86-NEXT: retl # encoding: [0xc3]
|
||||||
;
|
;
|
||||||
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_256:
|
; X64-LABEL: test_int_x86_avx512_mask_vpshrd_w_256:
|
||||||
; X64: # %bb.0:
|
; X64: # %bb.0:
|
||||||
; X64-NEXT: vpshrdw $22, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x72,0xd9,0x16]
|
; X64-NEXT: vpshrdw $6, %ymm1, %ymm0, %ymm3 # encoding: [0x62,0xf3,0xfd,0x28,0x72,0xd9,0x06]
|
||||||
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
; X64-NEXT: kmovd %edi, %k1 # encoding: [0xc5,0xfb,0x92,0xcf]
|
||||||
; X64-NEXT: vpshrdw $22, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x72,0xd1,0x16]
|
; X64-NEXT: vpshrdw $6, %ymm1, %ymm0, %ymm2 {%k1} # encoding: [0x62,0xf3,0xfd,0x29,0x72,0xd1,0x06]
|
||||||
; X64-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
; X64-NEXT: vpaddw %ymm3, %ymm2, %ymm0 # EVEX TO VEX Compression encoding: [0xc5,0xed,0xfd,0xc3]
|
||||||
; X64-NEXT: retq # encoding: [0xc3]
|
; X64-NEXT: retq # encoding: [0xc3]
|
||||||
%1 = call <16 x i16> @llvm.x86.avx512.vpshrd.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 22)
|
%1 = call <16 x i16> @llvm.x86.avx512.vpshrd.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 6)
|
||||||
%2 = bitcast i16 %x4 to <16 x i1>
|
%2 = bitcast i16 %x4 to <16 x i1>
|
||||||
%3 = select <16 x i1> %2, <16 x i16> %1, <16 x i16> %x3
|
%3 = select <16 x i1> %2, <16 x i16> %1, <16 x i16> %x3
|
||||||
%4 = call <16 x i16> @llvm.x86.avx512.vpshrd.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 22)
|
%4 = call <16 x i16> @llvm.x86.avx512.vpshrd.w.256(<16 x i16> %x0, <16 x i16> %x1, i32 6)
|
||||||
%res2 = add <16 x i16> %3, %4
|
%res2 = add <16 x i16> %3, %4
|
||||||
ret <16 x i16> %res2
|
ret <16 x i16> %res2
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue