X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Farm%2Fpthread_arch.h;h=5c6aff28a3d5f9ed6e834ad750852c632bda19ba;hb=5e46e8d4b0fee11a5d2ea12d0d21ed0bff6db855;hp=ec77a8337b10991b54df11896dbed015175a67a3;hpb=1974bffa2db151b4a05a2387ae765ab81ac83ba8;p=musl diff --git a/arch/arm/pthread_arch.h b/arch/arm/pthread_arch.h index ec77a833..5c6aff28 100644 --- a/arch/arm/pthread_arch.h +++ b/arch/arm/pthread_arch.h @@ -1,23 +1,33 @@ -#if __ARM_ARCH_6K__ || __ARM_ARCH_6ZK__ \ - || __ARM_ARCH_7A__ || __ARM_ARCH_7R__ \ - || __ARM_ARCH >= 7 +#if ((__ARM_ARCH_6K__ || __ARM_ARCH_6KZ__ || __ARM_ARCH_6ZK__) && !__thumb__) \ + || __ARM_ARCH_7A__ || __ARM_ARCH_7R__ || __ARM_ARCH >= 7 -static inline __attribute__((const)) pthread_t __pthread_self() +static inline pthread_t __pthread_self() { char *p; - __asm__( "mrc p15,0,%0,c13,c0,3" : "=r"(p) ); - return (void *)(p+8-sizeof(struct pthread)); + __asm__ __volatile__ ( "mrc p15,0,%0,c13,c0,3" : "=r"(p) ); + return (void *)(p-sizeof(struct pthread)); } #else -typedef char *(*__ptr_func_t)(void) __attribute__((const)); -#define __pthread_self() \ - ((pthread_t)(((__ptr_func_t)0xffff0fe0)()+8-sizeof(struct pthread))) +#if __ARM_ARCH_4__ || __ARM_ARCH_4T__ || __ARM_ARCH == 4 +#define BLX "mov lr,pc\n\tbx" +#else +#define BLX "blx" +#endif + +static inline pthread_t __pthread_self() +{ + extern hidden uintptr_t __a_gettp_ptr; + register uintptr_t p __asm__("r0"); + __asm__ __volatile__ ( BLX " %1" : "=r"(p) : "r"(__a_gettp_ptr) : "cc", "lr" ); + return (void *)(p-sizeof(struct pthread)); +} #endif #define TLS_ABOVE_TP -#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) - 8) +#define GAP_ABOVE_TP 8 +#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread)) -#define CANCEL_REG_IP 18 +#define MC_PC arm_pc