cosmopolitan/third_party/intel/avx512vbmiintrin.internal.h

91 lines
3.3 KiB
C
Raw Normal View History

2023-04-27 09:56:41 +00:00
#ifndef _IMMINTRIN_H_INCLUDED
#error "Never use <avx512vbmiintrin.h> directly; include <immintrin.h> instead."
#endif
#ifndef _AVX512VBMIINTRIN_H_INCLUDED
#define _AVX512VBMIINTRIN_H_INCLUDED
#ifndef __AVX512VBMI__
#pragma GCC push_options
#pragma GCC target("avx512vbmi")
#define __DISABLE_AVX512VBMI__
#endif /* __AVX512VBMI__ */
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_mask_multishift_epi64_epi8(__m512i __W, __mmask64 __M,
__m512i __X, __m512i __Y) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_vpmultishiftqb512_mask(
(__v64qi)__X, (__v64qi)__Y, (__v64qi)__W, (__mmask64)__M);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_maskz_multishift_epi64_epi8(__mmask64 __M, __m512i __X,
__m512i __Y) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_vpmultishiftqb512_mask(
(__v64qi)__X, (__v64qi)__Y, (__v64qi)_mm512_setzero_si512(),
(__mmask64)__M);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_multishift_epi64_epi8(__m512i __X, __m512i __Y) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_vpmultishiftqb512_mask(
(__v64qi)__X, (__v64qi)__Y, (__v64qi)_mm512_undefined_epi32(),
(__mmask64)-1);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_permutexvar_epi8(__m512i __A, __m512i __B) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_permvarqi512_mask(
(__v64qi)__B, (__v64qi)__A, (__v64qi)_mm512_undefined_epi32(),
(__mmask64)-1);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_maskz_permutexvar_epi8(__mmask64 __M, __m512i __A,
__m512i __B) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_permvarqi512_mask(
(__v64qi)__B, (__v64qi)__A, (__v64qi)_mm512_setzero_si512(),
(__mmask64)__M);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_mask_permutexvar_epi8(__m512i __W, __mmask64 __M,
__m512i __A, __m512i __B) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_permvarqi512_mask(
(__v64qi)__B, (__v64qi)__A, (__v64qi)__W, (__mmask64)__M);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_permutex2var_epi8(__m512i __A, __m512i __I,
__m512i __B) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_vpermt2varqi512_mask(
(__v64qi)__I
/* idx */,
(__v64qi)__A, (__v64qi)__B, (__mmask64)-1);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_mask_permutex2var_epi8(__m512i __A, __mmask64 __U,
__m512i __I, __m512i __B) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_vpermt2varqi512_mask(
(__v64qi)__I
/* idx */,
(__v64qi)__A, (__v64qi)__B, (__mmask64)__U);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_mask2_permutex2var_epi8(__m512i __A, __m512i __I,
__mmask64 __U, __m512i __B) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_vpermi2varqi512_mask((__v64qi)__A,
(__v64qi)__I
/* idx */,
(__v64qi)__B,
(__mmask64)__U);
}
2023-05-16 06:11:47 +00:00
__funline __m512i _mm512_maskz_permutex2var_epi8(__mmask64 __U, __m512i __A,
__m512i __I, __m512i __B) {
2023-04-27 09:56:41 +00:00
return (__m512i)__builtin_ia32_vpermt2varqi512_maskz(
(__v64qi)__I
/* idx */,
(__v64qi)__A, (__v64qi)__B, (__mmask64)__U);
}
#ifdef __DISABLE_AVX512VBMI__
#undef __DISABLE_AVX512VBMI__
#pragma GCC pop_options
#endif /* __DISABLE_AVX512VBMI__ */
#endif /* _AVX512VBMIINTRIN_H_INCLUDED */