projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
move __BYTE_ORDER definition to alltypes.h
[musl]
/
arch
/
mips
/
pthread_arch.h
diff --git
a/arch/mips/pthread_arch.h
b/arch/mips/pthread_arch.h
index
f8e35ae
..
1e7839e
100644
(file)
--- a/
arch/mips/pthread_arch.h
+++ b/
arch/mips/pthread_arch.h
@@
-1,16
+1,19
@@
static inline struct pthread *__pthread_self()
{
static inline struct pthread *__pthread_self()
{
-#ifdef __clang__
- char *tp;
- __asm__ __volatile__ (".word 0x7c03e83b ; move %0, $3" : "=r" (tp) : : "$3" );
-#else
+#if __mips_isa_rev < 2
register char *tp __asm__("$3");
register char *tp __asm__("$3");
- __asm__ __volatile__ (".word 0x7c03e83b" : "=r" (tp) );
+ __asm__ (".word 0x7c03e83b" : "=r" (tp) );
+#else
+ char *tp;
+ __asm__ ("rdhwr %0, $29" : "=r" (tp) );
#endif
return (pthread_t)(tp - 0x7000 - sizeof(struct pthread));
}
#define TLS_ABOVE_TP
#endif
return (pthread_t)(tp - 0x7000 - sizeof(struct pthread));
}
#define TLS_ABOVE_TP
+#define GAP_ABOVE_TP 0
#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) + 0x7000)
#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) + 0x7000)
-#define CANCEL_REG_IP (3-(union {int __i; char __b;}){1}.__b)
+#define DTP_OFFSET 0x8000
+
+#define MC_PC pc