123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- /* -*- mode:c; c-file-style:"k&r"; c-basic-offset: 4; tab-width:4; indent-tabs-mode:nil; mode:auto-fill; fill-column:78; -*- */
- /* vim: set ts=4 sw=4 et tw=78 fo=cqt wm=0: */
- #ifndef _SHIM_TLS_H_
- #define _SHIM_TLS_H_
- #ifdef __ASSEMBLER__
- #define SHIM_TLS_CANARY $xdeadbeef
- #if defined(__x86_64__)
- # define SHIM_TCB_OFFSET 80
- #else
- # define SHIM_TCB_OFFSET 44
- #endif
- #else /* !__ASSEMBLER__ */
- #define SHIM_TLS_CANARY 0xdeadbeef
- struct lock_record {
- enum { NO_LOCK, SEM_LOCK, READ_LOCK, WRITE_LOCK } type;
- void * lock;
- const char * filename;
- int lineno;
- };
- #define NUM_LOCK_RECORD 32
- #define NUM_LOCK_RECORD_MASK (NUM_LOCK_RECORD - 1)
- struct shim_regs {
- unsigned long r15;
- unsigned long r14;
- unsigned long r13;
- unsigned long r12;
- unsigned long r9;
- unsigned long r8;
- unsigned long rcx;
- unsigned long rdx;
- unsigned long rsi;
- unsigned long rdi;
- unsigned long rbx;
- unsigned long rbp;
- };
- struct shim_context {
- unsigned long syscall_nr;
- void * sp;
- void * ret_ip;
- struct shim_regs * regs;
- struct shim_context * next;
- unsigned long enter_time;
- unsigned long preempt;
- };
- #ifdef IN_SHIM
- #include <shim_defs.h>
- #define SIGNAL_DELAYED (0x80000000UL)
- #endif /* IN_SHIM */
- typedef struct {
- uint64_t canary;
- void * self;
- void * tp;
- struct shim_context context;
- unsigned int tid;
- int pal_errno;
- void * debug_buf;
- int last_lock;
- struct lock_record held_locks[NUM_LOCK_RECORD];
- } shim_tcb_t;
- #ifdef IN_SHIM
- typedef struct
- {
- void * tcb, * dtv, * self;
- int mthreads, gscope;
- uintptr_t sysinfo, sg, pg;
- unsigned long int vgetcpu_cache[2];
- int __unused1;
- shim_tcb_t shim_tcb;
- } __libc_tcb_t;
- #include <stddef.h>
- #define SHIM_TLS_CHECK_CANARY() \
- ({ uint64_t __canary; \
- asm ("movq %%fs:%c1,%q0" : "=r" (__canary) \
- : "i" (offsetof(__libc_tcb_t, shim_tcb.canary))); \
- __canary == SHIM_TLS_CANARY; })
- #define SHIM_GET_TLS() \
- ({ shim_tcb_t *__self; \
- asm ("movq %%fs:%c1,%q0" : "=r" (__self) \
- : "i" (offsetof(__libc_tcb_t, shim_tcb.self))); \
- __self; })
- #define GET_LIBC_TCB() \
- ({ void *__self; \
- asm ("movq %%fs:%c1,%q0" : "=r" (__self) \
- : "i" (offsetof(__libc_tcb_t, tcb))); \
- __self; })
- #endif /* IN_SHIM */
- #endif /* !__ASSEMBLER__ */
- #endif /* _SHIM_H_ */
|