xref: /freebsd/contrib/llvm-project/clang/lib/Headers/vpclmulqdqintrin.h (revision 0b57cec536236d46e3dba9bd041533462f33dbb7)
1*0b57cec5SDimitry Andric /*===------------ vpclmulqdqintrin.h - VPCLMULQDQ 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 "Never use <vpclmulqdqintrin.h> directly; include <immintrin.h> instead."
12*0b57cec5SDimitry Andric #endif
13*0b57cec5SDimitry Andric 
14*0b57cec5SDimitry Andric #ifndef __VPCLMULQDQINTRIN_H
15*0b57cec5SDimitry Andric #define __VPCLMULQDQINTRIN_H
16*0b57cec5SDimitry Andric 
17*0b57cec5SDimitry Andric #define _mm256_clmulepi64_epi128(A, B, I) \
18*0b57cec5SDimitry Andric   (__m256i)__builtin_ia32_pclmulqdq256((__v4di)(__m256i)(A),  \
19*0b57cec5SDimitry Andric                                        (__v4di)(__m256i)(B),  \
20*0b57cec5SDimitry Andric                                        (char)(I))
21*0b57cec5SDimitry Andric 
22*0b57cec5SDimitry Andric #define _mm512_clmulepi64_epi128(A, B, I) \
23*0b57cec5SDimitry Andric   (__m512i)__builtin_ia32_pclmulqdq512((__v8di)(__m512i)(A),  \
24*0b57cec5SDimitry Andric                                        (__v8di)(__m512i)(B),  \
25*0b57cec5SDimitry Andric                                        (char)(I))
26*0b57cec5SDimitry Andric 
27*0b57cec5SDimitry Andric #endif /* __VPCLMULQDQINTRIN_H */
28*0b57cec5SDimitry Andric 
29