| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 | #ifndef _SHIM_TLS_H_#define _SHIM_TLS_H_#ifdef IN_SHIM#include <atomic.h>#else  /* !IN_SHIM *//* workaround to make glibc build * the following structure must match to the one defined in pal/lib/atomic.h */#ifdef __x86_64__struct atomic_int {    volatile int64_t counter;};#endif#endif /* IN_SHIM */#define SHIM_TLS_CANARY 0xdeadbeefstruct shim_regs {    unsigned long           orig_rax;    unsigned long           rsp;    unsigned long           r15;    unsigned long           r14;    unsigned long           r13;    unsigned long           r12;    unsigned long           r11;    unsigned long           r10;    unsigned long           r9;    unsigned long           r8;    unsigned long           rcx;    unsigned long           rdx;    unsigned long           rsi;    unsigned long           rdi;    unsigned long           rbx;    unsigned long           rbp;    unsigned long           rflags;    unsigned long           rip;};struct shim_context {    struct shim_regs *      regs;    struct shim_context *   next;    uint64_t                enter_time;    struct atomic_int       preempt;};struct debug_buf;typedef struct shim_tcb shim_tcb_t;struct shim_tcb {    uint64_t                canary;    shim_tcb_t *            self;    struct shim_thread *    tp;    struct shim_context     context;    unsigned int            tid;    int                     pal_errno;    struct debug_buf *      debug_buf;    /* This record is for testing the memory of user inputs.     * If a segfault occurs with the range [start, end],     * the code addr is set to cont_addr to alert the caller. */    struct {        void * start, * end;        void * cont_addr;        bool has_fault;    } test_range;};#ifdef IN_SHIM#include <stddef.h>void init_tcb (shim_tcb_t * tcb);static inline shim_tcb_t * shim_get_tcb(void){    PAL_TCB * tcb = pal_get_tcb();    return (shim_tcb_t*)tcb->libos_tcb;}static inline bool shim_tls_check_canary(void){    /* TODO: optimize to use single movq %gs:<offset> */    shim_tcb_t * shim_tcb = shim_get_tcb();    return shim_tcb->canary == SHIM_TLS_CANARY;}#endif /* IN_SHIM */#endif /* _SHIM_H_ */
 |