mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-07-01 00:38:31 +00:00
Add Intel intrinsics headers
This commit is contained in:
parent
369f9740de
commit
b7bf052a4b
121 changed files with 47114 additions and 849 deletions
75
third_party/intel/vaesintrin.internal.h
vendored
Normal file
75
third_party/intel/vaesintrin.internal.h
vendored
Normal file
|
@ -0,0 +1,75 @@
|
|||
#ifndef __VAESINTRIN_H_INCLUDED
|
||||
#define __VAESINTRIN_H_INCLUDED
|
||||
#include "third_party/intel/x86intrin.internal.h"
|
||||
|
||||
#if !defined(__VAES__) || !defined(__AVX__)
|
||||
#pragma GCC push_options
|
||||
#pragma GCC target("vaes,avx")
|
||||
#define __DISABLE_VAES__
|
||||
#endif /* __VAES__ */
|
||||
|
||||
extern __inline __m256i
|
||||
__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
||||
_mm256_aesdec_epi128(__m256i __A, __m256i __B) {
|
||||
return (__m256i)__builtin_ia32_vaesdec_v32qi((__v32qi)__A, (__v32qi)__B);
|
||||
}
|
||||
|
||||
extern __inline __m256i
|
||||
__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
||||
_mm256_aesdeclast_epi128(__m256i __A, __m256i __B) {
|
||||
return (__m256i)__builtin_ia32_vaesdeclast_v32qi((__v32qi)__A, (__v32qi)__B);
|
||||
}
|
||||
|
||||
extern __inline __m256i
|
||||
__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
||||
_mm256_aesenc_epi128(__m256i __A, __m256i __B) {
|
||||
return (__m256i)__builtin_ia32_vaesenc_v32qi((__v32qi)__A, (__v32qi)__B);
|
||||
}
|
||||
|
||||
extern __inline __m256i
|
||||
__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
||||
_mm256_aesenclast_epi128(__m256i __A, __m256i __B) {
|
||||
return (__m256i)__builtin_ia32_vaesenclast_v32qi((__v32qi)__A, (__v32qi)__B);
|
||||
}
|
||||
|
||||
#ifdef __DISABLE_VAES__
|
||||
#undef __DISABLE_VAES__
|
||||
#pragma GCC pop_options
|
||||
#endif /* __DISABLE_VAES__ */
|
||||
|
||||
#if !defined(__VAES__) || !defined(__AVX512F__)
|
||||
#pragma GCC push_options
|
||||
#pragma GCC target("vaes,avx512f")
|
||||
#define __DISABLE_VAESF__
|
||||
#endif /* __VAES__ */
|
||||
|
||||
extern __inline __m512i
|
||||
__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
||||
_mm512_aesdec_epi128(__m512i __A, __m512i __B) {
|
||||
return (__m512i)__builtin_ia32_vaesdec_v64qi((__v64qi)__A, (__v64qi)__B);
|
||||
}
|
||||
|
||||
extern __inline __m512i
|
||||
__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
||||
_mm512_aesdeclast_epi128(__m512i __A, __m512i __B) {
|
||||
return (__m512i)__builtin_ia32_vaesdeclast_v64qi((__v64qi)__A, (__v64qi)__B);
|
||||
}
|
||||
|
||||
extern __inline __m512i
|
||||
__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
||||
_mm512_aesenc_epi128(__m512i __A, __m512i __B) {
|
||||
return (__m512i)__builtin_ia32_vaesenc_v64qi((__v64qi)__A, (__v64qi)__B);
|
||||
}
|
||||
|
||||
extern __inline __m512i
|
||||
__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
||||
_mm512_aesenclast_epi128(__m512i __A, __m512i __B) {
|
||||
return (__m512i)__builtin_ia32_vaesenclast_v64qi((__v64qi)__A, (__v64qi)__B);
|
||||
}
|
||||
|
||||
#ifdef __DISABLE_VAESF__
|
||||
#undef __DISABLE_VAESF__
|
||||
#pragma GCC pop_options
|
||||
#endif /* __DISABLE_VAES__ */
|
||||
|
||||
#endif /* __VAESINTRIN_H_INCLUDED */
|
Loading…
Add table
Add a link
Reference in a new issue