]> git.ipfire.org Git - thirdparty/git.git/blame - trace2/tr2_tls.h
Merge branch 'js/update-index-ignore-removal-for-skip-worktree'
[thirdparty/git.git] / trace2 / tr2_tls.h
CommitLineData
ee4512ed
JH
1#ifndef TR2_TLS_H
2#define TR2_TLS_H
3
4#include "strbuf.h"
5
6/*
7 * Arbitry limit for thread names for column alignment.
8 */
9#define TR2_MAX_THREAD_NAME (24)
10
11struct tr2tls_thread_ctx {
12 struct strbuf thread_name;
13 uint64_t *array_us_start;
14 int alloc;
15 int nr_open_regions; /* plays role of "nr" in ALLOC_GROW */
16 int thread_id;
17};
18
19/*
20 * Create TLS data for the current thread. This gives us a place to
21 * put per-thread data, such as thread start time, function nesting
22 * and a per-thread label for our messages.
23 *
24 * We assume the first thread is "main". Other threads are given
25 * non-zero thread-ids to help distinguish messages from concurrent
26 * threads.
27 *
28 * Truncate the thread name if necessary to help with column alignment
29 * in printf-style messages.
30 *
31 * In this and all following functions the term "self" refers to the
32 * current thread.
33 */
a0897249
JH
34struct tr2tls_thread_ctx *tr2tls_create_self(const char *thread_name,
35 uint64_t us_thread_start);
ee4512ed
JH
36
37/*
38 * Get our TLS data.
39 */
40struct tr2tls_thread_ctx *tr2tls_get_self(void);
41
42/*
43 * return true if the current thread is the main thread.
44 */
45int tr2tls_is_main_thread(void);
46
47/*
48 * Free our TLS data.
49 */
50void tr2tls_unset_self(void);
51
52/*
53 * Begin a new nested region and remember the start time.
54 */
55void tr2tls_push_self(uint64_t us_now);
56
57/*
58 * End the innermost nested region.
59 */
60void tr2tls_pop_self(void);
61
62/*
63 * Pop any extra (above the first) open regions on the current
64 * thread and discard. During a thread-exit, we should only
65 * have region[0] that was pushed in trace2_thread_start() if
66 * the thread exits normally.
67 */
68void tr2tls_pop_unwind_self(void);
69
70/*
71 * Compute the elapsed time since the innermost region in the
72 * current thread started and the given time (usually now).
73 */
74uint64_t tr2tls_region_elasped_self(uint64_t us);
75
76/*
77 * Compute the elapsed time since the main thread started
78 * and the given time (usually now). This is assumed to
79 * be the absolute run time of the process.
80 */
81uint64_t tr2tls_absolute_elapsed(uint64_t us);
82
83/*
84 * Initialize the tr2 TLS system.
85 */
86void tr2tls_init(void);
87
88/*
89 * Free all tr2 TLS resources.
90 */
91void tr2tls_release(void);
92
93/*
94 * Protected increment of an integer.
95 */
96int tr2tls_locked_increment(int *p);
97
a0897249
JH
98/*
99 * Capture the process start time and do nothing else.
100 */
101void tr2tls_start_process_clock(void);
102
ee4512ed 103#endif /* TR2_TLS_H */