diff options
author | Vladimir Azarov <avm@intermediate-node.net> | 2024-10-01 15:47:05 +0200 |
---|---|---|
committer | Vladimir Azarov <avm@intermediate-node.net> | 2024-10-01 15:47:05 +0200 |
commit | 4abab5ad6c8465a7528ccdd5f49367da05f78bbd (patch) | |
tree | ebf009bf1376a5a223a915bc27cbbd791a1316bc /arch/mips/pthread_arch.h |
Initial version
Diffstat (limited to 'arch/mips/pthread_arch.h')
-rw-r--r-- | arch/mips/pthread_arch.h | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/arch/mips/pthread_arch.h b/arch/mips/pthread_arch.h new file mode 100644 index 0000000..376b774 --- /dev/null +++ b/arch/mips/pthread_arch.h @@ -0,0 +1,18 @@ +static inline uintptr_t __get_tp() +{ + register uintptr_t tp __asm__("$3"); +#if __mips_isa_rev < 2 + __asm__ (".word 0x7c03e83b" : "=r" (tp) ); +#else + __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 |