gpulib: remove some unreliable heuristics
[pcsx_rearmed.git] / include / arm_features.h
CommitLineData
665f33e1 1#ifndef __ARM_FEATURES_H__
2#define __ARM_FEATURES_H__
3
8638b7ee 4/* note: features only available since:
5 * __ARM_ARCH gcc 4.8/clang 3.2
6 * ARMv8 support gcc 4.8/clang 3.4
7 * ARM64 support gcc 4.8/clang 3.5
8 */
9
10#if defined(__aarch64__)
11
12#elif (defined(__ARM_ARCH) && __ARM_ARCH >= 8)
663fc559 13
14#define HAVE_ARMV8
15#define HAVE_ARMV7
16#define HAVE_ARMV6
0ff4daa3 17#define HAVE_ARMV5E
663fc559 18#define HAVE_ARMV5
19
8638b7ee 20#elif (defined(__ARM_ARCH) && __ARM_ARCH >= 7) \
21 || defined(__ARM_ARCH_7__) || defined(__ARM_ARCH_7A__) \
22 || defined(__ARM_ARCH_7R__) || defined(__ARM_ARCH_7M__) \
23 || defined(__ARM_ARCH_7EM__) || defined(__ARM_ARCH_7S__)
665f33e1 24
25#define HAVE_ARMV7
26#define HAVE_ARMV6
0ff4daa3 27#define HAVE_ARMV5E
665f33e1 28#define HAVE_ARMV5
29
8638b7ee 30#elif (defined(__ARM_ARCH) && __ARM_ARCH >= 6) \
31 || defined(__ARM_ARCH_6__) || defined(__ARM_ARCH_6J__) \
32 || defined(__ARM_ARCH_6K__) || defined(__ARM_ARCH_6Z__) \
33 || defined(__ARM_ARCH_6ZK__) || defined(__ARM_ARCH_6T2__) \
34 || defined(__ARM_ARCH_6M__)
665f33e1 35
36#define HAVE_ARMV6
0ff4daa3 37#define HAVE_ARMV5E
665f33e1 38#define HAVE_ARMV5
8638b7ee 39#define HAVE_PRE_ARMV7
665f33e1 40
0ff4daa3 41#elif defined(__ARM_ARCH_5E__) || defined(__ARM_ARCH_5TE__) || defined(__ARM_ARCH_5TEJ__)
42
43#define HAVE_ARMV5E
44#define HAVE_ARMV5
45#define HAVE_PRE_ARMV7
46
47#elif defined(__ARM_ARCH_5__) || defined(__ARM_ARCH_5T__)
665f33e1 48
49#define HAVE_ARMV5
8638b7ee 50#define HAVE_PRE_ARMV7
51
52#elif defined(__arm__)
53
54#define HAVE_PRE_ARMV7
665f33e1 55
56#endif
57
203769fe 58/* gcc defines __ARM_NEON__ consistently for 32bit, but apple clang defines it for 64bit also... */
59#if defined(HAVE_ARMV7) && defined(__ARM_NEON__)
60#define HAVE_NEON32
61#endif
665f33e1 62
c57af5e6 63#if defined(__APPLE__) && defined(__aarch64__)
64#define ASM_SEPARATOR %%
65#else
66#define ASM_SEPARATOR ;
67#endif
68
4ae83961 69/* global function/external symbol */
c57af5e6 70#ifndef __APPLE__
4ae83961 71#define ESYM(name) name
72
5c6457c3 73#define FUNCTION(name) \
4ae83961 74 .globl name; \
5c6457c3 75 .type name, %function; \
76 name
77
c57af5e6 78#define ESIZE(name_, size_) \
79 .size name_, size_
80
81#define EOBJECT(name_) \
82 .type name_, %object
83
5df0e313 84#define EXTRA_UNSAVED_REGS
85
5c6457c3 86#else
4ae83961 87#define ESYM(name) _##name
88
5c6457c3 89#define FUNCTION(name) \
c57af5e6 90 name: ASM_SEPARATOR \
91 .globl ESYM(name) ASM_SEPARATOR \
4ae83961 92 ESYM(name)
5c6457c3 93
c57af5e6 94#define ESIZE(name_, size_)
95#define EOBJECT(name_)
96
5df0e313 97// r7 is preserved, but add it for EABI alignment..
98#define EXTRA_UNSAVED_REGS r7, r9,
99
5c6457c3 100#endif
101
0e4ad319 102#if defined(__MACH__) || defined(__PIC__)
103#define TEXRELS_FORBIDDEN
104#endif
105
665f33e1 106#endif /* __ARM_FEATURES_H__ */