xref: /freebsd/contrib/llvm-project/clang/lib/Headers/avx512vpopcntdqintrin.h (revision 0b57cec536236d46e3dba9bd041533462f33dbb7)
1*0b57cec5SDimitry Andric /*===----- avx512vpopcntdqintrin.h - AVX512VPOPCNTDQ intrinsics-------------===
2*0b57cec5SDimitry Andric  *
3*0b57cec5SDimitry Andric  *
4*0b57cec5SDimitry Andric  * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5*0b57cec5SDimitry Andric  * See https://llvm.org/LICENSE.txt for license information.
6*0b57cec5SDimitry Andric  * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7*0b57cec5SDimitry Andric  *
8*0b57cec5SDimitry Andric  *===-----------------------------------------------------------------------===
9*0b57cec5SDimitry Andric  */
10*0b57cec5SDimitry Andric #ifndef __IMMINTRIN_H
11*0b57cec5SDimitry Andric #error                                                                         \
12*0b57cec5SDimitry Andric     "Never use <avx512vpopcntdqintrin.h> directly; include <immintrin.h> instead."
13*0b57cec5SDimitry Andric #endif
14*0b57cec5SDimitry Andric 
15*0b57cec5SDimitry Andric #ifndef __AVX512VPOPCNTDQINTRIN_H
16*0b57cec5SDimitry Andric #define __AVX512VPOPCNTDQINTRIN_H
17*0b57cec5SDimitry Andric 
18*0b57cec5SDimitry Andric /* Define the default attributes for the functions in this file. */
19*0b57cec5SDimitry Andric #define __DEFAULT_FN_ATTRS                                                     \
20*0b57cec5SDimitry Andric   __attribute__((__always_inline__, __nodebug__, __target__("avx512vpopcntdq"), __min_vector_width__(512)))
21*0b57cec5SDimitry Andric 
22*0b57cec5SDimitry Andric static __inline__ __m512i __DEFAULT_FN_ATTRS _mm512_popcnt_epi64(__m512i __A) {
23*0b57cec5SDimitry Andric   return (__m512i)__builtin_ia32_vpopcntq_512((__v8di)__A);
24*0b57cec5SDimitry Andric }
25*0b57cec5SDimitry Andric 
26*0b57cec5SDimitry Andric static __inline__ __m512i __DEFAULT_FN_ATTRS
27*0b57cec5SDimitry Andric _mm512_mask_popcnt_epi64(__m512i __W, __mmask8 __U, __m512i __A) {
28*0b57cec5SDimitry Andric   return (__m512i)__builtin_ia32_selectq_512(
29*0b57cec5SDimitry Andric       (__mmask8)__U, (__v8di)_mm512_popcnt_epi64(__A), (__v8di)__W);
30*0b57cec5SDimitry Andric }
31*0b57cec5SDimitry Andric 
32*0b57cec5SDimitry Andric static __inline__ __m512i __DEFAULT_FN_ATTRS
33*0b57cec5SDimitry Andric _mm512_maskz_popcnt_epi64(__mmask8 __U, __m512i __A) {
34*0b57cec5SDimitry Andric   return _mm512_mask_popcnt_epi64((__m512i)_mm512_setzero_si512(), __U, __A);
35*0b57cec5SDimitry Andric }
36*0b57cec5SDimitry Andric 
37*0b57cec5SDimitry Andric static __inline__ __m512i __DEFAULT_FN_ATTRS _mm512_popcnt_epi32(__m512i __A) {
38*0b57cec5SDimitry Andric   return (__m512i)__builtin_ia32_vpopcntd_512((__v16si)__A);
39*0b57cec5SDimitry Andric }
40*0b57cec5SDimitry Andric 
41*0b57cec5SDimitry Andric static __inline__ __m512i __DEFAULT_FN_ATTRS
42*0b57cec5SDimitry Andric _mm512_mask_popcnt_epi32(__m512i __W, __mmask16 __U, __m512i __A) {
43*0b57cec5SDimitry Andric   return (__m512i)__builtin_ia32_selectd_512(
44*0b57cec5SDimitry Andric       (__mmask16)__U, (__v16si)_mm512_popcnt_epi32(__A), (__v16si)__W);
45*0b57cec5SDimitry Andric }
46*0b57cec5SDimitry Andric 
47*0b57cec5SDimitry Andric static __inline__ __m512i __DEFAULT_FN_ATTRS
48*0b57cec5SDimitry Andric _mm512_maskz_popcnt_epi32(__mmask16 __U, __m512i __A) {
49*0b57cec5SDimitry Andric   return _mm512_mask_popcnt_epi32((__m512i)_mm512_setzero_si512(), __U, __A);
50*0b57cec5SDimitry Andric }
51*0b57cec5SDimitry Andric 
52*0b57cec5SDimitry Andric #undef __DEFAULT_FN_ATTRS
53*0b57cec5SDimitry Andric 
54*0b57cec5SDimitry Andric #endif
55