Index: fusl/arch/or1k/pthread_arch.h |
diff --git a/fusl/arch/or1k/pthread_arch.h b/fusl/arch/or1k/pthread_arch.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..7decd769a8598ab35de5293ccc2bf58b51a3c414 |
--- /dev/null |
+++ b/fusl/arch/or1k/pthread_arch.h |
@@ -0,0 +1,17 @@ |
+/* or1k use variant I, but with the twist that tp points to the end of TCB */ |
+static inline struct pthread *__pthread_self() |
+{ |
+#ifdef __clang__ |
+ char *tp; |
+ __asm__ __volatile__ ("l.ori %0, r10, 0" : "=r" (tp) ); |
+#else |
+ register char *tp __asm__("r10"); |
+ __asm__ __volatile__ ("" : "=r" (tp) ); |
+#endif |
+ return (struct pthread *) (tp - sizeof(struct pthread)); |
+} |
+ |
+#define TLS_ABOVE_TP |
+#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread)) |
+ |
+#define MC_PC regs.pc |