#ifndef TR2_TLS_H #define TR2_TLS_H #include "strbuf.h" /* * Arbitry limit for thread names for column alignment. */ #define TR2_MAX_THREAD_NAME (24) struct tr2tls_thread_ctx { struct strbuf thread_name; uint64_t *array_us_start; int alloc; int nr_open_regions; /* plays role of "nr" in ALLOC_GROW */ int thread_id; }; /* * Create TLS data for the current thread. This gives us a place to * put per-thread data, such as thread start time, function nesting * and a per-thread label for our messages. * * We assume the first thread is "main". Other threads are given * non-zero thread-ids to help distinguish messages from concurrent * threads. * * Truncate the thread name if necessary to help with column alignment * in printf-style messages. * * In this and all following functions the term "self" refers to the * current thread. */ struct tr2tls_thread_ctx *tr2tls_create_self(const char *thread_name, uint64_t us_thread_start); /* * Get our TLS data. */ struct tr2tls_thread_ctx *tr2tls_get_self(void); /* * return true if the current thread is the main thread. */ int tr2tls_is_main_thread(void); /* * Free our TLS data. */ void tr2tls_unset_self(void); /* * Begin a new nested region and remember the start time. */ void tr2tls_push_self(uint64_t us_now); /* * End the innermost nested region. */ void tr2tls_pop_self(void); /* * Pop any extra (above the first) open regions on the current * thread and discard. During a thread-exit, we should only * have region[0] that was pushed in trace2_thread_start() if * the thread exits normally. */ void tr2tls_pop_unwind_self(void); /* * Compute the elapsed time since the innermost region in the * current thread started and the given time (usually now). */ uint64_t tr2tls_region_elasped_self(uint64_t us); /* * Compute the elapsed time since the main thread started * and the given time (usually now). This is assumed to * be the absolute run time of the process. */ uint64_t tr2tls_absolute_elapsed(uint64_t us); /* * Initialize the tr2 TLS system. */ void tr2tls_init(void); /* * Free all tr2 TLS resources. */ void tr2tls_release(void); /* * Protected increment of an integer. */ int tr2tls_locked_increment(int *p); /* * Capture the process start time and do nothing else. */ void tr2tls_start_process_clock(void); #endif /* TR2_TLS_H */