X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=arch%2Fmips%2Fpthread_arch.h;h=1e7839ea6740ceac26c7a5b222e02bf92b5b05e7;hb=a730639273fd5040ea3528a9fc7b8590f46a6702;hp=8a49965496928b8d1df438f2d184c93678253300;hpb=cb1bf2f321b45a06447133b3db00621b7300c456;p=musl diff --git a/arch/mips/pthread_arch.h b/arch/mips/pthread_arch.h index 8a499654..1e7839ea 100644 --- a/arch/mips/pthread_arch.h +++ b/arch/mips/pthread_arch.h @@ -1,17 +1,17 @@ static inline struct pthread *__pthread_self() { -#ifdef __clang__ - char *tp; - __asm__ __volatile__ (".word 0x7c03e83b ; move %0, $3" : "=r" (tp) : : "$3" ); -#else +#if __mips_isa_rev < 2 register char *tp __asm__("$3"); - /* rdhwr $3,$29 */ - __asm__ __volatile__ (".word 0x7c03e83b" : "=r" (tp) ); + __asm__ (".word 0x7c03e83b" : "=r" (tp) ); +#else + char *tp; + __asm__ ("rdhwr %0, $29" : "=r" (tp) ); #endif return (pthread_t)(tp - 0x7000 - sizeof(struct pthread)); } #define TLS_ABOVE_TP +#define GAP_ABOVE_TP 0 #define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) + 0x7000) #define DTP_OFFSET 0x8000