overhaul ARM atomics/tls for performance and compatibility
[musl] / arch / arm / pthread_arch.h
1 #if ((__ARM_ARCH_6K__ || __ARM_ARCH_6ZK__) && !__thumb__) \
2  || __ARM_ARCH_7A__ || __ARM_ARCH_7R__ || __ARM_ARCH >= 7
3
4 static inline __attribute__((const)) pthread_t __pthread_self()
5 {
6         char *p;
7         __asm__( "mrc p15,0,%0,c13,c0,3" : "=r"(p) );
8         return (void *)(p+8-sizeof(struct pthread));
9 }
10
11 #else
12
13 static inline __attribute__((const)) pthread_t __pthread_self()
14 {
15 #ifdef __clang__
16         char *p;
17         __asm__( "bl __a_gettp\n\tmov %0,r0" : "=r"(p) : : "cc", "r0", "lr" );
18 #else
19         register char *p __asm__("r0");
20         __asm__( "bl __a_gettp" : "=r"(p) : : "cc", "lr" );
21 #endif
22         return (void *)(p+8-sizeof(struct pthread));
23 }
24
25 #endif
26
27 #define TLS_ABOVE_TP
28 #define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) - 8)
29
30 #define CANCEL_REG_IP 18