xref: /openbmc/qemu/host/include/i386/host/crypto/clmul.h (revision d6493dbb46b4b7be13a39425b5a1e523e72f5a68)
1*d6493dbbSRichard Henderson /*
2*d6493dbbSRichard Henderson  * x86 specific clmul acceleration.
3*d6493dbbSRichard Henderson  * SPDX-License-Identifier: GPL-2.0-or-later
4*d6493dbbSRichard Henderson  */
5*d6493dbbSRichard Henderson 
6*d6493dbbSRichard Henderson #ifndef X86_HOST_CRYPTO_CLMUL_H
7*d6493dbbSRichard Henderson #define X86_HOST_CRYPTO_CLMUL_H
8*d6493dbbSRichard Henderson 
9*d6493dbbSRichard Henderson #include "host/cpuinfo.h"
10*d6493dbbSRichard Henderson #include <immintrin.h>
11*d6493dbbSRichard Henderson 
12*d6493dbbSRichard Henderson #if defined(__PCLMUL__)
13*d6493dbbSRichard Henderson # define HAVE_CLMUL_ACCEL  true
14*d6493dbbSRichard Henderson # define ATTR_CLMUL_ACCEL
15*d6493dbbSRichard Henderson #else
16*d6493dbbSRichard Henderson # define HAVE_CLMUL_ACCEL  likely(cpuinfo & CPUINFO_PCLMUL)
17*d6493dbbSRichard Henderson # define ATTR_CLMUL_ACCEL  __attribute__((target("pclmul")))
18*d6493dbbSRichard Henderson #endif
19*d6493dbbSRichard Henderson 
20*d6493dbbSRichard Henderson static inline Int128 ATTR_CLMUL_ACCEL
21*d6493dbbSRichard Henderson clmul_64_accel(uint64_t n, uint64_t m)
22*d6493dbbSRichard Henderson {
23*d6493dbbSRichard Henderson     union { __m128i v; Int128 s; } u;
24*d6493dbbSRichard Henderson 
25*d6493dbbSRichard Henderson     u.v = _mm_clmulepi64_si128(_mm_set_epi64x(0, n), _mm_set_epi64x(0, m), 0);
26*d6493dbbSRichard Henderson     return u.s;
27*d6493dbbSRichard Henderson }
28*d6493dbbSRichard Henderson 
29*d6493dbbSRichard Henderson #endif /* X86_HOST_CRYPTO_CLMUL_H */
30