From: Mathieu Desnoyers Date: Thu, 9 Apr 2020 15:29:18 +0000 (-0400) Subject: Fix: namespace contexts !CONFIG_RCU_TLS variable initialization X-Git-Tag: v2.12.1~16 X-Git-Url: https://git.lttng.org./?a=commitdiff_plain;h=4ae3f13373ab43824ddca62d3482584a6296641d;p=lttng-ust.git Fix: namespace contexts !CONFIG_RCU_TLS variable initialization The namespace contexts introduced in lttng-ust 2.12 require to initialize TLS variable to nonzero values. However, in !CONFIG_RCU_TLS (compatibility mode using pthread setspecific), this initialization does not build. Use the new DEFINE_URCU_TLS_INIT from liburcu when building !CONFIG_RCU_TLS to fix this issue. Since this requires a dependency on a new liburcu version, only !CONFIG_RCU_TLS adds this dependency in the fix. A followup cleanup patch will use DEFINE_URCU_TLS_INIT as we add a strict version dependency. Signed-off-by: Mathieu Desnoyers --- diff --git a/liblttng-ust/lttng-context-cgroup-ns.c b/liblttng-ust/lttng-context-cgroup-ns.c index d4053150..97af2759 100644 --- a/liblttng-ust/lttng-context-cgroup-ns.c +++ b/liblttng-ust/lttng-context-cgroup-ns.c @@ -38,7 +38,11 @@ * We cache the result to ensure we don't stat(2) the proc filesystem on * each event. */ +#ifdef CONFIG_RCU_TLS static DEFINE_URCU_TLS(ino_t, cached_cgroup_ns) = NS_INO_UNINITIALIZED; +#else +static DEFINE_URCU_TLS_INIT(ino_t, cached_cgroup_ns, NS_INO_UNINITIALIZED); +#endif static ino_t get_cgroup_ns(void) diff --git a/liblttng-ust/lttng-context-ipc-ns.c b/liblttng-ust/lttng-context-ipc-ns.c index c973dc86..a05a6c61 100644 --- a/liblttng-ust/lttng-context-ipc-ns.c +++ b/liblttng-ust/lttng-context-ipc-ns.c @@ -33,12 +33,15 @@ #include "lttng-tracer-core.h" #include "ns.h" - /* * We cache the result to ensure we don't stat(2) the proc filesystem on * each event. */ +#ifdef CONFIG_RCU_TLS static DEFINE_URCU_TLS(ino_t, cached_ipc_ns) = NS_INO_UNINITIALIZED; +#else +static DEFINE_URCU_TLS_INIT(ino_t, cached_ipc_ns, NS_INO_UNINITIALIZED); +#endif static ino_t get_ipc_ns(void) diff --git a/liblttng-ust/lttng-context-net-ns.c b/liblttng-ust/lttng-context-net-ns.c index 9d6ded12..c0aaa9d4 100644 --- a/liblttng-ust/lttng-context-net-ns.c +++ b/liblttng-ust/lttng-context-net-ns.c @@ -33,12 +33,15 @@ #include "lttng-tracer-core.h" #include "ns.h" - /* * We cache the result to ensure we don't stat(2) the proc filesystem on * each event. */ +#ifdef CONFIG_RCU_TLS static DEFINE_URCU_TLS(ino_t, cached_net_ns) = NS_INO_UNINITIALIZED; +#else +static DEFINE_URCU_TLS_INIT(ino_t, cached_net_ns, NS_INO_UNINITIALIZED); +#endif static ino_t get_net_ns(void) diff --git a/liblttng-ust/lttng-context-uts-ns.c b/liblttng-ust/lttng-context-uts-ns.c index fb2d89f9..778ccb46 100644 --- a/liblttng-ust/lttng-context-uts-ns.c +++ b/liblttng-ust/lttng-context-uts-ns.c @@ -38,7 +38,11 @@ * We cache the result to ensure we don't stat(2) the proc filesystem on * each event. */ +#ifdef CONFIG_RCU_TLS static DEFINE_URCU_TLS(ino_t, cached_uts_ns) = NS_INO_UNINITIALIZED; +#else +static DEFINE_URCU_TLS_INIT(ino_t, cached_uts_ns, NS_INO_UNINITIALIZED); +#endif static ino_t get_uts_ns(void)