X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Fmips64%2Fpthread_arch.h;h=1e7839ea6740ceac26c7a5b222e02bf92b5b05e7;hb=107d68ad1737929a3e815bd28514cb56e4bedd57;hp=b42edbe3e0672a29fea0c9bdb21820a9bb323a48;hpb=83933573aff71a5d178ab71912f177d2d844e63e;p=musl diff --git a/arch/mips64/pthread_arch.h b/arch/mips64/pthread_arch.h index b42edbe3..1e7839ea 100644 --- a/arch/mips64/pthread_arch.h +++ b/arch/mips64/pthread_arch.h @@ -1,16 +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"); - __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