wmmintrin.h revision 239462
1206084Srdivacky/*===---- wmmintrin.h - AES intrinsics ------------------------------------===
2206084Srdivacky *
3206084Srdivacky * Permission is hereby granted, free of charge, to any person obtaining a copy
4206084Srdivacky * of this software and associated documentation files (the "Software"), to deal
5206084Srdivacky * in the Software without restriction, including without limitation the rights
6206084Srdivacky * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7206084Srdivacky * copies of the Software, and to permit persons to whom the Software is
8206084Srdivacky * furnished to do so, subject to the following conditions:
9206084Srdivacky *
10206084Srdivacky * The above copyright notice and this permission notice shall be included in
11206084Srdivacky * all copies or substantial portions of the Software.
12206084Srdivacky *
13206084Srdivacky * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14206084Srdivacky * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15206084Srdivacky * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16206084Srdivacky * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17206084Srdivacky * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18206084Srdivacky * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
19206084Srdivacky * THE SOFTWARE.
20206084Srdivacky *
21206084Srdivacky *===-----------------------------------------------------------------------===
22206084Srdivacky */
23206084Srdivacky
24206084Srdivacky#ifndef _WMMINTRIN_H
25206084Srdivacky#define _WMMINTRIN_H
26206084Srdivacky
27239462Sdim#include <emmintrin.h>
28239462Sdim
29239462Sdim#if !defined (__AES__) && !defined (__PCLMUL__)
30239462Sdim# error "AES/PCLMUL instructions not enabled"
31206084Srdivacky#else
32206084Srdivacky
33239462Sdim#ifdef __AES__
34206084Srdivacky
35206084Srdivackystatic __inline__ __m128i __attribute__((__always_inline__, __nodebug__))
36206084Srdivacky_mm_aesenc_si128(__m128i __V, __m128i __R)
37206084Srdivacky{
38206084Srdivacky  return (__m128i)__builtin_ia32_aesenc128(__V, __R);
39206084Srdivacky}
40206084Srdivacky
41206084Srdivackystatic __inline__ __m128i __attribute__((__always_inline__, __nodebug__))
42206084Srdivacky_mm_aesenclast_si128(__m128i __V, __m128i __R)
43206084Srdivacky{
44206084Srdivacky  return (__m128i)__builtin_ia32_aesenclast128(__V, __R);
45206084Srdivacky}
46206084Srdivacky
47206084Srdivackystatic __inline__ __m128i __attribute__((__always_inline__, __nodebug__))
48206084Srdivacky_mm_aesdec_si128(__m128i __V, __m128i __R)
49206084Srdivacky{
50206084Srdivacky  return (__m128i)__builtin_ia32_aesdec128(__V, __R);
51206084Srdivacky}
52206084Srdivacky
53206084Srdivackystatic __inline__ __m128i __attribute__((__always_inline__, __nodebug__))
54206084Srdivacky_mm_aesdeclast_si128(__m128i __V, __m128i __R)
55206084Srdivacky{
56206084Srdivacky  return (__m128i)__builtin_ia32_aesdeclast128(__V, __R);
57206084Srdivacky}
58206084Srdivacky
59206084Srdivackystatic __inline__ __m128i __attribute__((__always_inline__, __nodebug__))
60206084Srdivacky_mm_aesimc_si128(__m128i __V)
61206084Srdivacky{
62206084Srdivacky  return (__m128i)__builtin_ia32_aesimc128(__V);
63206084Srdivacky}
64206084Srdivacky
65206084Srdivacky#define _mm_aeskeygenassist_si128(C, R) \
66206084Srdivacky  __builtin_ia32_aeskeygenassist128((C), (R))
67206084Srdivacky
68206084Srdivacky#endif /* __AES__ */
69239462Sdim
70239462Sdim#ifdef __PCLMUL__
71239462Sdim
72239462Sdim#define _mm_clmulepi64_si128(__X, __Y, __I) \
73239462Sdim  ((__m128i)__builtin_ia32_pclmulqdq128((__v2di)(__m128i)(__X), \
74239462Sdim                                        (__v2di)(__m128i)(__Y), (char)(__I)))
75239462Sdim
76239462Sdim#endif /* __PCLMUL__ */
77239462Sdim
78239462Sdim#endif /* __AES__ || __PCLMUL__ */
79206084Srdivacky#endif /* _WMMINTRIN_H */
80