projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix powerpc atomic compare-and-swap function
[musl]
/
arch
/
mips
/
pthread_arch.h
diff --git
a/arch/mips/pthread_arch.h
b/arch/mips/pthread_arch.h
index
77b7330
..
f8e35ae
100644
(file)
--- a/
arch/mips/pthread_arch.h
+++ b/
arch/mips/pthread_arch.h
@@
-1,12
+1,16
@@
static inline struct pthread *__pthread_self()
{
static inline struct pthread *__pthread_self()
{
- struct pthread *self;
#ifdef __clang__
#ifdef __clang__
- __asm__ __volatile__ (".word 0x7c03e83b ; move %0, $3" : "=r" (self) : : "$3" );
+ char *tp;
+ __asm__ __volatile__ (".word 0x7c03e83b ; move %0, $3" : "=r" (tp) : : "$3" );
#else
#else
- __asm__ __volatile__ (".word 0x7c03e83b" : "=v" (self) );
+ register char *tp __asm__("$3");
+ __asm__ __volatile__ (".word 0x7c03e83b" : "=r" (tp) );
#endif
#endif
- return
self
;
+ return
(pthread_t)(tp - 0x7000 - sizeof(struct pthread))
;
}
}
+#define TLS_ABOVE_TP
+#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) + 0x7000)
+
#define CANCEL_REG_IP (3-(union {int __i; char __b;}){1}.__b)
#define CANCEL_REG_IP (3-(union {int __i; char __b;}){1}.__b)