ETISS 0.8.0
Extendable Translating Instruction Set Simulator (version 0.8.0)
shaintrin.h
Go to the documentation of this file.
1 /*===---- shaintrin.h - SHA intrinsics -------------------------------------===
2  *
3  * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4  * See https://llvm.org/LICENSE.txt for license information.
5  * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6  *
7  *===-----------------------------------------------------------------------===
8  */
9 
10 #ifndef __IMMINTRIN_H
11 #error "Never use <shaintrin.h> directly; include <immintrin.h> instead."
12 #endif
13 
14 #ifndef __SHAINTRIN_H
15 #define __SHAINTRIN_H
16 
17 /* Define the default attributes for the functions in this file. */
18 #define __DEFAULT_FN_ATTRS __attribute__((__always_inline__, __nodebug__, __target__("sha"), __min_vector_width__(128)))
19 
20 #define _mm_sha1rnds4_epu32(V1, V2, M) \
21  __builtin_ia32_sha1rnds4((__v4si)(__m128i)(V1), (__v4si)(__m128i)(V2), (M))
22 
23 static __inline__ __m128i __DEFAULT_FN_ATTRS
24 _mm_sha1nexte_epu32(__m128i __X, __m128i __Y)
25 {
26  return (__m128i)__builtin_ia32_sha1nexte((__v4si)__X, (__v4si)__Y);
27 }
28 
29 static __inline__ __m128i __DEFAULT_FN_ATTRS
30 _mm_sha1msg1_epu32(__m128i __X, __m128i __Y)
31 {
32  return (__m128i)__builtin_ia32_sha1msg1((__v4si)__X, (__v4si)__Y);
33 }
34 
35 static __inline__ __m128i __DEFAULT_FN_ATTRS
36 _mm_sha1msg2_epu32(__m128i __X, __m128i __Y)
37 {
38  return (__m128i)__builtin_ia32_sha1msg2((__v4si)__X, (__v4si)__Y);
39 }
40 
41 static __inline__ __m128i __DEFAULT_FN_ATTRS
42 _mm_sha256rnds2_epu32(__m128i __X, __m128i __Y, __m128i __Z)
43 {
44  return (__m128i)__builtin_ia32_sha256rnds2((__v4si)__X, (__v4si)__Y, (__v4si)__Z);
45 }
46 
47 static __inline__ __m128i __DEFAULT_FN_ATTRS
48 _mm_sha256msg1_epu32(__m128i __X, __m128i __Y)
49 {
50  return (__m128i)__builtin_ia32_sha256msg1((__v4si)__X, (__v4si)__Y);
51 }
52 
53 static __inline__ __m128i __DEFAULT_FN_ATTRS
54 _mm_sha256msg2_epu32(__m128i __X, __m128i __Y)
55 {
56  return (__m128i)__builtin_ia32_sha256msg2((__v4si)__X, (__v4si)__Y);
57 }
58 
59 #undef __DEFAULT_FN_ATTRS
60 
61 #endif /* __SHAINTRIN_H */
#define __DEFAULT_FN_ATTRS
Definition: shaintrin.h:18
static __inline__ __m128i __DEFAULT_FN_ATTRS _mm_sha256rnds2_epu32(__m128i __X, __m128i __Y, __m128i __Z)
Definition: shaintrin.h:42
static __inline__ __m128i __DEFAULT_FN_ATTRS _mm_sha1nexte_epu32(__m128i __X, __m128i __Y)
Definition: shaintrin.h:24
static __inline__ __m128i __DEFAULT_FN_ATTRS _mm_sha1msg2_epu32(__m128i __X, __m128i __Y)
Definition: shaintrin.h:36
static __inline__ __m128i __DEFAULT_FN_ATTRS _mm_sha1msg1_epu32(__m128i __X, __m128i __Y)
Definition: shaintrin.h:30
static __inline__ __m128i __DEFAULT_FN_ATTRS _mm_sha256msg1_epu32(__m128i __X, __m128i __Y)
Definition: shaintrin.h:48
static __inline__ __m128i __DEFAULT_FN_ATTRS _mm_sha256msg2_epu32(__m128i __X, __m128i __Y)
Definition: shaintrin.h:54