Merge branch 'master' into dev
[lttng-ust.git] / liblttng-ust / lttng-context-vtid.c
index 6f7e078d22d2910072748adfd0ee59b8c9a695b4..c419d18b3ede7db666d2c5ea3cada82df6dafcbd 100644 (file)
 #include <lttng/ust-events.h>
 #include <lttng/ust-tracer.h>
 #include <lttng/ringbuffer-config.h>
-
-#ifdef __linux__
-#include <syscall.h>
-#endif
-
-#if defined(_syscall0)
-_syscall0(pid_t, gettid)
-#elif defined(__NR_gettid)
-static inline pid_t gettid(void)
-{
-       return syscall(__NR_gettid);
-}
-#else
-#warning "use pid as tid"
-static inline pid_t gettid(void)
-{
-       return getpid();
-}
-#endif
+#include <lttng/ust-tid.h>
+#include "ltt-tracer-core.h"
 
 /*
  * We cache the result to ensure we don't trigger a system call for
@@ -92,3 +75,11 @@ int lttng_add_vtid_to_ctx(struct lttng_ctx **ctx)
        field->record = vtid_record;
        return 0;
 }
+
+/*
+ * Force a read (imply TLS fixup for dlopen) of TLS variables.
+ */
+void lttng_fixup_vtid_tls(void)
+{
+       asm volatile ("" : : "m" (cached_vtid));
+}
This page took 0.02509 seconds and 4 git commands to generate.