X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Fs390x%2Fpthread_arch.h;h=e54fec3fe64fa763ae5b0fbcae71ef62a953aa4f;hb=523d9b965df65bd3ad52863abc817724d7a35f32;hp=bd90016d3f77f3e40520c7aba1bc910b4e4602f7;hpb=15094943050eb9a564f409323070e50b40f78816;p=musl diff --git a/arch/s390x/pthread_arch.h b/arch/s390x/pthread_arch.h index bd90016d..e54fec3f 100644 --- a/arch/s390x/pthread_arch.h +++ b/arch/s390x/pthread_arch.h @@ -1,14 +1,12 @@ -static inline struct pthread *__pthread_self() +static inline uintptr_t __get_tp() { - struct pthread *self; - __asm__ __volatile__ ( + uintptr_t tp; + __asm__ ( "ear %0, %%a0\n" "sllg %0, %0, 32\n" "ear %0, %%a1\n" - : "=r"(self)); - return self; + : "=r"(tp)); + return tp; } -#define TP_ADJ(p) (p) - #define MC_PC psw.addr