ReactOS 0.4.16-dev-2104-gb84fa49
intrin.h
Go to the documentation of this file.
1
7#ifndef _INC_INTRIN
8#define _INC_INTRIN
9
10#if defined(__i386__) || (defined(__x86_64__) && !defined(__arm64ec__))
11# include <x86intrin.h>
12#endif
13
14#ifdef __cplusplus
15extern "C" {
16#endif
17
18#ifndef __has_builtin
19# define __has_builtin(x) 0
20#endif
21
22#if defined(__i386__) || (defined(__x86_64__) && !defined(__arm64ec__))
23
24#if __has_builtin(__cpuidex) || (defined(_MSC_VER) && !defined(__clang__))
25void __cpuidex(int info[4], int ax, int cx);
26#pragma intrinsic(__cpuidex)
27#else
28static inline void __cpuidex(int info[4], int ax, int cx)
29{
30 __asm__ ("cpuid" : "=a"(info[0]), "=b" (info[1]), "=c"(info[2]), "=d"(info[3]) : "a"(ax), "c"(cx));
31}
32#endif
33
34#if __has_builtin(__cpuid) || (defined(_MSC_VER) && !defined(__clang__))
35void __cpuid(int info[4], int ax);
36#pragma intrinsic(__cpuid)
37#else
38static inline void __cpuid(int info[4], int ax)
39{
40 return __cpuidex(info, ax, 0);
41}
42#endif
43
44#endif
45
46#if defined(__aarch64__) || defined(__arm64ec__)
48{
62#endif
63
64#ifdef __arm__
66{
68 _ARM_BARRIER_OSH = 0x3,
70 _ARM_BARRIER_NSH = 0x7,
72 _ARM_BARRIER_ISH = 0xb,
73 _ARM_BARRIER_ST = 0xe,
74 _ARM_BARRIER_SY = 0xf
76#endif
77
78#if defined(_MSC_VER) && (defined(__arm__) || defined(__aarch64__) || defined(__arm64ec__))
79
80void __dmb(unsigned int);
81
82#pragma intrinsic(__dmb)
83
84#endif
85
86#if defined(_MSC_VER) && (defined(__aarch64__) || defined(__arm64ec__))
87
88unsigned __int64 __getReg(int);
89#pragma intrinsic(__getReg)
90
91#endif
92
93#ifdef __cplusplus
94}
95#endif
96
97#endif /* _INC_INTRIN */
void __dmb(unsigned int _Type)
_tag_ARM64INTR_BARRIER_TYPE
Definition: arm64intr.h:15
@ _ARM64_BARRIER_NSH
Definition: arm64intr.h:22
@ _ARM64_BARRIER_SY
Definition: arm64intr.h:16
@ _ARM64_BARRIER_ISHLD
Definition: arm64intr.h:21
@ _ARM64_BARRIER_NSHLD
Definition: arm64intr.h:24
@ _ARM64_BARRIER_LD
Definition: arm64intr.h:18
@ _ARM64_BARRIER_OSHLD
Definition: arm64intr.h:27
@ _ARM64_BARRIER_ISHST
Definition: arm64intr.h:20
@ _ARM64_BARRIER_OSHST
Definition: arm64intr.h:26
@ _ARM64_BARRIER_ST
Definition: arm64intr.h:17
@ _ARM64_BARRIER_NSHST
Definition: arm64intr.h:23
@ _ARM64_BARRIER_ISH
Definition: arm64intr.h:19
@ _ARM64_BARRIER_OSH
Definition: arm64intr.h:25
enum _tag_ARM64INTR_BARRIER_TYPE _ARM64INTR_BARRIER_TYPE
_tag_ARMINTR_BARRIER_TYPE
Definition: armintr.h:32
@ _ARM_BARRIER_NSHST
Definition: armintr.h:38
@ _ARM_BARRIER_NSH
Definition: armintr.h:37
@ _ARM_BARRIER_ST
Definition: armintr.h:34
@ _ARM_BARRIER_ISH
Definition: armintr.h:35
@ _ARM_BARRIER_ISHST
Definition: armintr.h:36
@ _ARM_BARRIER_SY
Definition: armintr.h:33
@ _ARM_BARRIER_OSH
Definition: armintr.h:39
@ _ARM_BARRIER_OSHST
Definition: armintr.h:40
enum _tag_ARMINTR_BARRIER_TYPE _ARMINTR_BARRIER_TYPE
#define __int64
Definition: corecrt.h:72
PPC_QUAL void __cpuid(int CPUInfo[], const int InfoType)
Definition: intrin_ppc.h:682
__INTRIN_INLINE void __cpuidex(int CPUInfo[4], int InfoType, int ECXValue)
Definition: intrin_x86.h:1662
_Out_opt_ int * cx
Definition: commctrl.h:585
__asm__(".p2align 4, 0x90\n" ".seh_proc __seh2_global_filter_func\n" "__seh2_global_filter_func:\n" "\tsub %rbp, %rax\n" "\tpush %rbp\n" "\t.seh_pushreg %rbp\n" "\tsub $32, %rsp\n" "\t.seh_stackalloc 32\n" "\t.seh_endprologue\n" "\tsub %rax, %rdx\n" "\tmov %rdx, %rbp\n" "\tjmp *%r8\n" "__seh2_global_filter_func_exit:\n" "\t.p2align 4\n" "\tadd $32, %rsp\n" "\tpop %rbp\n" "\tret\n" "\t.seh_endproc")
ecx edi movl ebx edx edi decl ecx esi eax jecxz decl eax andl eax esi movl edx movl TEMP incl eax andl eax ecx incl ebx testl eax jnz xchgl ecx incl TEMP esp ecx subl ebx pushl ecx ecx edx ecx shrl ecx mm0 mm4 mm0 mm4 mm1 mm5 mm1 mm5 mm2 mm6 mm2 mm6 mm3 mm7 mm3 mm7 paddd mm0 paddd mm4 paddd mm0 paddd mm4 paddd mm0 paddd mm4 movq mm1 movq mm5 psrlq mm1 psrlq mm5 paddd mm0 paddd mm4 psrad mm0 psrad mm4 packssdw mm0 packssdw mm4 mm1 punpckldq mm0 pand mm1 pand mm0 por mm1 movq edi esi edx edi decl ecx jnz popl ecx andl ecx jecxz mm0 mm0 mm1 mm1 mm2 mm2 mm3 mm3 paddd mm0 paddd mm0 paddd mm0 movq mm1 psrlq mm1 paddd mm0 psrad mm0 packssdw mm0 movd eax movw ax
Definition: synth_sse3d.h:180