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