1 // RUN: %clang_cc1 %s -triple=x86_64-apple-darwin -target-feature +avx512vbmi -emit-llvm -o - -Werror | FileCheck %s
2
3 // Don't include mm_malloc.h, it's system specific.
4 #define __MM_MALLOC_H
5
6 #include <immintrin.h>
7
test_mm512_mask2_permutex2var_epi8(__m512i __A,__m512i __I,__mmask64 __U,__m512i __B)8 __m512i test_mm512_mask2_permutex2var_epi8(__m512i __A, __m512i __I, __mmask64 __U, __m512i __B) {
9 // CHECK-LABEL: @test_mm512_mask2_permutex2var_epi8
10 // CHECK: @llvm.x86.avx512.mask.vpermi2var.qi.512
11 return _mm512_mask2_permutex2var_epi8(__A, __I, __U, __B);
12 }
13
test_mm512_permutex2var_epi8(__m512i __A,__m512i __I,__m512i __B)14 __m512i test_mm512_permutex2var_epi8(__m512i __A, __m512i __I, __m512i __B) {
15 // CHECK-LABEL: @test_mm512_permutex2var_epi8
16 // CHECK: @llvm.x86.avx512.mask.vpermt2var.qi.512
17 return _mm512_permutex2var_epi8(__A, __I, __B);
18 }
19
test_mm512_mask_permutex2var_epi8(__m512i __A,__mmask64 __U,__m512i __I,__m512i __B)20 __m512i test_mm512_mask_permutex2var_epi8(__m512i __A, __mmask64 __U, __m512i __I, __m512i __B) {
21 // CHECK-LABEL: @test_mm512_mask_permutex2var_epi8
22 // CHECK: @llvm.x86.avx512.mask.vpermt2var.qi.512
23 return _mm512_mask_permutex2var_epi8(__A, __U, __I, __B);
24 }
25
test_mm512_maskz_permutex2var_epi8(__mmask64 __U,__m512i __A,__m512i __I,__m512i __B)26 __m512i test_mm512_maskz_permutex2var_epi8(__mmask64 __U, __m512i __A, __m512i __I, __m512i __B) {
27 // CHECK-LABEL: @test_mm512_maskz_permutex2var_epi8
28 // CHECK: @llvm.x86.avx512.maskz.vpermt2var.qi.512
29 return _mm512_maskz_permutex2var_epi8(__U, __A, __I, __B);
30 }
31
test_mm512_permutexvar_epi8(__m512i __A,__m512i __B)32 __m512i test_mm512_permutexvar_epi8(__m512i __A, __m512i __B) {
33 // CHECK-LABEL: @test_mm512_permutexvar_epi8
34 // CHECK: @llvm.x86.avx512.mask.permvar.qi.512
35 return _mm512_permutexvar_epi8(__A, __B);
36 }
37
test_mm512_maskz_permutexvar_epi8(__mmask64 __M,__m512i __A,__m512i __B)38 __m512i test_mm512_maskz_permutexvar_epi8(__mmask64 __M, __m512i __A, __m512i __B) {
39 // CHECK-LABEL: @test_mm512_maskz_permutexvar_epi8
40 // CHECK: @llvm.x86.avx512.mask.permvar.qi.512
41 return _mm512_maskz_permutexvar_epi8(__M, __A, __B);
42 }
43
test_mm512_mask_permutexvar_epi8(__m512i __W,__mmask64 __M,__m512i __A,__m512i __B)44 __m512i test_mm512_mask_permutexvar_epi8(__m512i __W, __mmask64 __M, __m512i __A, __m512i __B) {
45 // CHECK-LABEL: @test_mm512_mask_permutexvar_epi8
46 // CHECK: @llvm.x86.avx512.mask.permvar.qi.512
47 return _mm512_mask_permutexvar_epi8(__W, __M, __A, __B);
48 }
49
test_mm512_mask_multishift_epi64_epi8(__m512i __W,__mmask64 __M,__m512i __X,__m512i __Y)50 __m512i test_mm512_mask_multishift_epi64_epi8(__m512i __W, __mmask64 __M, __m512i __X, __m512i __Y) {
51 // CHECK-LABEL: @test_mm512_mask_multishift_epi64_epi8
52 // CHECK: @llvm.x86.avx512.mask.pmultishift.qb.512
53 return _mm512_mask_multishift_epi64_epi8(__W, __M, __X, __Y);
54 }
55
test_mm512_maskz_multishift_epi64_epi8(__mmask64 __M,__m512i __X,__m512i __Y)56 __m512i test_mm512_maskz_multishift_epi64_epi8(__mmask64 __M, __m512i __X, __m512i __Y) {
57 // CHECK-LABEL: @test_mm512_maskz_multishift_epi64_epi8
58 // CHECK: @llvm.x86.avx512.mask.pmultishift.qb.512
59 return _mm512_maskz_multishift_epi64_epi8(__M, __X, __Y);
60 }
61
test_mm512_multishift_epi64_epi8(__m512i __X,__m512i __Y)62 __m512i test_mm512_multishift_epi64_epi8(__m512i __X, __m512i __Y) {
63 // CHECK-LABEL: @test_mm512_multishift_epi64_epi8
64 // CHECK: @llvm.x86.avx512.mask.pmultishift.qb.512
65 return _mm512_multishift_epi64_epi8(__X, __Y);
66 }
67