X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Fmips%2Fpthread_arch.h;h=1e7839ea6740ceac26c7a5b222e02bf92b5b05e7;hb=b4712ba445a5cb589d1ac37785c29164cd3cf1f9;hp=f75379cf834deb53c02c31c5f28584b75c0e7a44;hpb=e1e4d6b269dd5c03480d55b031f2932df0490c96;p=musl diff --git a/arch/mips/pthread_arch.h b/arch/mips/pthread_arch.h index f75379cf..1e7839ea 100644 --- a/arch/mips/pthread_arch.h +++ b/arch/mips/pthread_arch.h @@ -1,8 +1,19 @@ static inline struct pthread *__pthread_self() { - struct pthread *self; - __asm__ __volatile__ (".word 0x7c03e83b" : "=v" (self) ); - return self; +#if __mips_isa_rev < 2 + register char *tp __asm__("$3"); + __asm__ (".word 0x7c03e83b" : "=r" (tp) ); +#else + char *tp; + __asm__ ("rdhwr %0, $29" : "=r" (tp) ); +#endif + 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 GAP_ABOVE_TP 0 +#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) + 0x7000) + +#define DTP_OFFSET 0x8000 + +#define MC_PC pc