X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Fmips%2Fpthread_arch.h;h=e5812655df8684f7e44204bf0561c9c0dade0ceb;hb=9d4c902c42b3fda368d7ea64bb9575c46228fa7f;hp=77b7330dacfd1445d4635d64bb0c6ece1a87897c;hpb=9f65796c35bd93a1de42752ce8af901acfe4b1a4;p=musl diff --git a/arch/mips/pthread_arch.h b/arch/mips/pthread_arch.h index 77b7330d..e5812655 100644 --- a/arch/mips/pthread_arch.h +++ b/arch/mips/pthread_arch.h @@ -1,12 +1,18 @@ static inline struct pthread *__pthread_self() { - struct pthread *self; -#ifdef __clang__ - __asm__ __volatile__ (".word 0x7c03e83b ; move %0, $3" : "=r" (self) : : "$3" ); +#if __mips_isa_rev < 2 + register char *tp __asm__("$3"); + __asm__ __volatile__ (".word 0x7c03e83b" : "=r" (tp) ); #else - __asm__ __volatile__ (".word 0x7c03e83b" : "=v" (self) ); + char *tp; + __asm__ __volatile__ ("rdhwr %0, $29" : "=r" (tp) ); #endif - return self; + return (pthread_t)(tp - 0x7000 - sizeof(struct pthread)); } -#define CANCEL_REG_IP (3-(union {int __i; char __b;}){1}.__b) +#define TLS_ABOVE_TP +#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) + 0x7000) + +#define DTP_OFFSET 0x8000 + +#define MC_PC pc