X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=arch%2Fpowerpc%2Fpthread_arch.h;h=42e88b07e8184080b03c7b297621cb9631255059;hb=b90841e2583237a4132bbbd74752e0e9563660cd;hp=cb2a70b83b7696ae97e992d8d98a687bd3c9b133;hpb=1c8eb8bad791fe9d01d0d4ab77882db634fa933d;p=musl diff --git a/arch/powerpc/pthread_arch.h b/arch/powerpc/pthread_arch.h index cb2a70b8..42e88b07 100644 --- a/arch/powerpc/pthread_arch.h +++ b/arch/powerpc/pthread_arch.h @@ -1,14 +1,16 @@ -static inline struct pthread *__pthread_self() +static inline uintptr_t __get_tp() { - register char* tp __asm__("r2"); - return (pthread_t)(tp - 0x7000 - sizeof(struct pthread)); + register uintptr_t tp __asm__("r2"); + __asm__ ("" : "=r" (tp) ); + return tp; } #define TLS_ABOVE_TP -#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) + 0x7000) +#define GAP_ABOVE_TP 0 + +#define TP_OFFSET 0x7000 +#define DTP_OFFSET 0x8000 -// offset of the PC register in mcontext_t, divided by the system wordsize // the kernel calls the ip "nip", it's the first saved value after the 32 // GPRs. -#define CANCEL_REG_IP 32 - +#define MC_PC gregs[32]