summaryrefslogtreecommitdiffstats
path: root/src/libnetdata/os/gettid.c
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-07-24 09:54:23 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-07-24 09:54:44 +0000
commit836b47cb7e99a977c5a23b059ca1d0b5065d310e (patch)
tree1604da8f482d02effa033c94a84be42bc0c848c3 /src/libnetdata/os/gettid.c
parentReleasing debian version 1.44.3-2. (diff)
downloadnetdata-836b47cb7e99a977c5a23b059ca1d0b5065d310e.tar.xz
netdata-836b47cb7e99a977c5a23b059ca1d0b5065d310e.zip
Merging upstream version 1.46.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--src/libnetdata/os/gettid.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/src/libnetdata/os/gettid.c b/src/libnetdata/os/gettid.c
new file mode 100644
index 000000000..273c428f8
--- /dev/null
+++ b/src/libnetdata/os/gettid.c
@@ -0,0 +1,33 @@
+// SPDX-License-Identifier: GPL-3.0-or-later
+
+#include "../libnetdata.h"
+
+#if defined(OS_WINDOWS)
+#include <windows.h>
+#endif
+
+pid_t os_gettid(void) {
+#if defined(HAVE_GETTID)
+ return gettid();
+#elif defined(HAVE_PTHREAD_GETTHREADID_NP)
+ return (pid_t)pthread_getthreadid_np();
+#elif defined(HAVE_PTHREAD_THREADID_NP)
+ uint64_t curthreadid;
+ pthread_threadid_np(NULL, &curthreadid);
+ return curthreadid;
+#elif defined(OS_WINDOWS)
+ return (pid_t)GetCurrentThreadId();
+#elif defined(OS_LINUX)
+ return (pid_t)syscall(SYS_gettid);
+#else
+ return (pid_t)pthread_self();
+#endif
+}
+
+static __thread pid_t gettid_cached_tid = 0;
+pid_t gettid_cached(void) {
+ if(unlikely(gettid_cached_tid == 0))
+ gettid_cached_tid = os_gettid();
+
+ return gettid_cached_tid;
+} \ No newline at end of file