X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Fpowerpc%2Fpthread_arch.h;h=7c5c4fadb2116382e4a3a15a8e2a7adbaa95bb06;hb=8735a921d0242be0d7e6dbe0f76f79e09d4f06dd;hp=1cbfc223ad23e3745243cf90a058ef1be75043d7;hpb=6ba5517a460c6c438f64d69464fdfc3269a4c91a;p=musl diff --git a/arch/powerpc/pthread_arch.h b/arch/powerpc/pthread_arch.h index 1cbfc223..7c5c4fad 100644 --- a/arch/powerpc/pthread_arch.h +++ b/arch/powerpc/pthread_arch.h @@ -5,6 +5,7 @@ static inline struct pthread *__pthread_self() __asm__ __volatile__ ("mr %0, 2" : "=r"(tp) : : ); #else register char *tp __asm__("r2"); + __asm__ __volatile__ ("" : "=r" (tp) ); #endif return (pthread_t)(tp - 0x7000 - sizeof(struct pthread)); } @@ -14,9 +15,8 @@ static inline struct pthread *__pthread_self() #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] #define CANARY canary_at_end