cdrom: change pause timing again
[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
17#define HAVE_ARMV5
18
8638b7ee 19#elif (defined(__ARM_ARCH) && __ARM_ARCH >= 7) \
20 || defined(__ARM_ARCH_7__) || defined(__ARM_ARCH_7A__) \
21 || defined(__ARM_ARCH_7R__) || defined(__ARM_ARCH_7M__) \
22 || defined(__ARM_ARCH_7EM__) || defined(__ARM_ARCH_7S__)
665f33e1 23
24#define HAVE_ARMV7
25#define HAVE_ARMV6
26#define HAVE_ARMV5
27
8638b7ee 28#elif (defined(__ARM_ARCH) && __ARM_ARCH >= 6) \
29 || defined(__ARM_ARCH_6__) || defined(__ARM_ARCH_6J__) \
30 || defined(__ARM_ARCH_6K__) || defined(__ARM_ARCH_6Z__) \
31 || defined(__ARM_ARCH_6ZK__) || defined(__ARM_ARCH_6T2__) \
32 || defined(__ARM_ARCH_6M__)
665f33e1 33
34#define HAVE_ARMV6
35#define HAVE_ARMV5
8638b7ee 36#define HAVE_PRE_ARMV7
665f33e1 37
38#elif defined(__ARM_ARCH_5__) || defined(__ARM_ARCH_5E__) \
39 || defined(__ARM_ARCH_5T__) || defined(__ARM_ARCH_5TE__) || defined(__ARM_ARCH_5TEJ__)
40
41#define HAVE_ARMV5
8638b7ee 42#define HAVE_PRE_ARMV7
43
44#elif defined(__arm__)
45
46#define HAVE_PRE_ARMV7
665f33e1 47
48#endif
49
203769fe 50/* gcc defines __ARM_NEON__ consistently for 32bit, but apple clang defines it for 64bit also... */
51#if defined(HAVE_ARMV7) && defined(__ARM_NEON__)
52#define HAVE_NEON32
53#endif
665f33e1 54
c57af5e6 55#if defined(__APPLE__) && defined(__aarch64__)
56#define ASM_SEPARATOR %%
57#else
58#define ASM_SEPARATOR ;
59#endif
60
4ae83961 61/* global function/external symbol */
c57af5e6 62#ifndef __APPLE__
4ae83961 63#define ESYM(name) name
64
5c6457c3 65#define FUNCTION(name) \
4ae83961 66 .globl name; \
5c6457c3 67 .type name, %function; \
68 name
69
c57af5e6 70#define ESIZE(name_, size_) \
71 .size name_, size_
72
73#define EOBJECT(name_) \
74 .type name_, %object
75
5df0e313 76#define EXTRA_UNSAVED_REGS
77
5c6457c3 78#else
4ae83961 79#define ESYM(name) _##name
80
5c6457c3 81#define FUNCTION(name) \
c57af5e6 82 name: ASM_SEPARATOR \
83 .globl ESYM(name) ASM_SEPARATOR \
4ae83961 84 ESYM(name)
5c6457c3 85
c57af5e6 86#define ESIZE(name_, size_)
87#define EOBJECT(name_)
88
5df0e313 89// r7 is preserved, but add it for EABI alignment..
90#define EXTRA_UNSAVED_REGS r7, r9,
91
5c6457c3 92#endif
93
0e4ad319 94#if defined(__MACH__) || defined(__PIC__)
95#define TEXRELS_FORBIDDEN
96#endif
97
665f33e1 98#endif /* __ARM_FEATURES_H__ */