summaryrefslogtreecommitdiffstats
path: root/libc-top-half/musl/arch/mips64/pthread_arch.h
diff options
context:
space:
mode:
Diffstat (limited to 'libc-top-half/musl/arch/mips64/pthread_arch.h')
-rw-r--r--libc-top-half/musl/arch/mips64/pthread_arch.h19
1 files changed, 19 insertions, 0 deletions
diff --git a/libc-top-half/musl/arch/mips64/pthread_arch.h b/libc-top-half/musl/arch/mips64/pthread_arch.h
new file mode 100644
index 0000000..c45347a
--- /dev/null
+++ b/libc-top-half/musl/arch/mips64/pthread_arch.h
@@ -0,0 +1,19 @@
+static inline uintptr_t __get_tp()
+{
+#if __mips_isa_rev < 2
+ register uintptr_t tp __asm__("$3");
+ __asm__ (".word 0x7c03e83b" : "=r" (tp) );
+#else
+ uintptr_t tp;
+ __asm__ ("rdhwr %0, $29" : "=r" (tp) );
+#endif
+ return tp;
+}
+
+#define TLS_ABOVE_TP
+#define GAP_ABOVE_TP 0
+
+#define TP_OFFSET 0x7000
+#define DTP_OFFSET 0x8000
+
+#define MC_PC pc