Index: fusl/arch/powerpc/pthread_arch.h |
diff --git a/fusl/arch/powerpc/pthread_arch.h b/fusl/arch/powerpc/pthread_arch.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..7c5c4fadb2116382e4a3a15a8e2a7adbaa95bb06 |
--- /dev/null |
+++ b/fusl/arch/powerpc/pthread_arch.h |
@@ -0,0 +1,22 @@ |
+static inline struct pthread *__pthread_self() |
+{ |
+#ifdef __clang__ |
+ char *tp; |
+ __asm__ __volatile__ ("mr %0, 2" : "=r"(tp) : : ); |
+#else |
+ register char *tp __asm__("r2"); |
+ __asm__ __volatile__ ("" : "=r" (tp) ); |
+#endif |
+ return (pthread_t)(tp - 0x7000 - sizeof(struct pthread)); |
+} |
+ |
+#define TLS_ABOVE_TP |
+#define TP_ADJ(p) ((char *)(p) + sizeof(struct pthread) + 0x7000) |
+ |
+#define DTP_OFFSET 0x8000 |
+ |
+// the kernel calls the ip "nip", it's the first saved value after the 32 |
+// GPRs. |
+#define MC_PC gregs[32] |
+ |
+#define CANARY canary_at_end |