ETISS 0.8.0
Extendable Translating Instruction Set Simulator (version 0.8.0)
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
fxsrintrin.h
Go to the documentation of this file.
1/*===---- fxsrintrin.h - FXSR intrinsic ------------------------------------===
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 <fxsrintrin.h> directly; include <immintrin.h> instead."
12#endif
13
14#ifndef __FXSRINTRIN_H
15#define __FXSRINTRIN_H
16
17#define __DEFAULT_FN_ATTRS __attribute__((__always_inline__, __nodebug__, __target__("fxsr")))
18
29static __inline__ void __DEFAULT_FN_ATTRS
31{
32 __builtin_ia32_fxsave(__p);
33}
34
47static __inline__ void __DEFAULT_FN_ATTRS
49{
50 __builtin_ia32_fxrstor(__p);
51}
52
53#ifdef __x86_64__
64static __inline__ void __DEFAULT_FN_ATTRS
65_fxsave64(void *__p)
66{
67 __builtin_ia32_fxsave64(__p);
68}
69
82static __inline__ void __DEFAULT_FN_ATTRS
83_fxrstor64(void *__p)
84{
85 __builtin_ia32_fxrstor64(__p);
86}
87#endif
88
89#undef __DEFAULT_FN_ATTRS
90
91#endif
static __inline unsigned char unsigned int unsigned int unsigned int * __p
Definition adxintrin.h:24
static __inline__ void __DEFAULT_FN_ATTRS _fxsave(void *__p)
Saves the XMM, MMX, MXCSR and x87 FPU registers into a 512-byte memory region pointed to by the input...
Definition fxsrintrin.h:30
#define __DEFAULT_FN_ATTRS
Definition fxsrintrin.h:17
static __inline__ void __DEFAULT_FN_ATTRS _fxrstor(void *__p)
Restores the XMM, MMX, MXCSR and x87 FPU registers from the 512-byte memory region pointed to by the ...
Definition fxsrintrin.h:48