X-Git-Url: https://git.lttng.org/?a=blobdiff_plain;f=include%2Flttng%2Ftracepoint-rcu.h;h=2898845834beaeaebeebfcf284f49f6f50ac8b1d;hb=f3b06377a014332947b20cc4c266369ea85ddcfa;hp=852cfe48d55ee630d588a7ed64d822142e3c7561;hpb=40b2b5a43e4c2067849770b3379ca5360facacd5;p=lttng-ust.git diff --git a/include/lttng/tracepoint-rcu.h b/include/lttng/tracepoint-rcu.h index 852cfe48..28988458 100644 --- a/include/lttng/tracepoint-rcu.h +++ b/include/lttng/tracepoint-rcu.h @@ -1,49 +1,43 @@ -#ifndef _LTTNG_TRACEPOINT_RCU_H -#define _LTTNG_TRACEPOINT_RCU_H - /* - * Copyright (c) 2011 - Mathieu Desnoyers - * - * THIS MATERIAL IS PROVIDED AS IS, WITH ABSOLUTELY NO WARRANTY EXPRESSED - * OR IMPLIED. ANY USE IS AT YOUR OWN RISK. - * - * Permission is hereby granted to use or copy this program - * for any purpose, provided the above notices are retained on all copies. - * Permission to modify the code and to distribute modified code is granted, - * provided the above notices are retained, and a notice that the code was - * modified is included with the above copyright notice. + * SPDX-License-Identifier: MIT * - * This file allows weak linking on tracepoint RCU symbols for non-LGPL - * code. + * Copyright (C) 2011-2012 Mathieu Desnoyers */ +#ifndef _LTTNG_TRACEPOINT_RCU_H +#define _LTTNG_TRACEPOINT_RCU_H + #include +#include +#include #ifdef _LGPL_SOURCE -#include +#include -#define TP_RCU_LINK_TEST() 1 -#define tp_rcu_read_lock_bp rcu_read_lock_bp -#define tp_rcu_read_unlock_bp rcu_read_unlock_bp -#define tp_rcu_dereference_bp rcu_dereference_bp +#define lttng_ust_tp_rcu_read_lock lttng_ust_urcu_read_lock +#define lttng_ust_tp_rcu_read_unlock lttng_ust_urcu_read_unlock +#define lttng_ust_tp_rcu_dereference lttng_ust_rcu_dereference +#define LTTNG_UST_TP_RCU_LINK_TEST() 1 #else /* _LGPL_SOURCE */ -#define TP_RCU_LINK_TEST() tp_rcu_read_lock_bp +#define lttng_ust_tp_rcu_read_lock lttng_ust_tracepoint_dlopen_ptr->rcu_read_lock_sym +#define lttng_ust_tp_rcu_read_unlock lttng_ust_tracepoint_dlopen_ptr->rcu_read_unlock_sym -/* Symbols looked up with dlsym */ -static void (*tp_rcu_read_lock_bp)(void) __attribute__((unused)); -static void (*tp_rcu_read_unlock_bp)(void) __attribute__((unused)); -static void *(*tp_rcu_dereference_sym_bp)(void *p) __attribute__((unused)); +#define lttng_ust_tp_rcu_dereference(p) \ + URCU_FORCE_CAST(__typeof__(p), \ + lttng_ust_tracepoint_dlopen_ptr->rcu_dereference_sym(URCU_FORCE_CAST(void *, p))) -#define tp_rcu_dereference_bp(p) \ - ({ \ - typeof(p) _________p1 = URCU_FORCE_CAST(typeof(p), \ - tp_rcu_dereference_sym_bp(URCU_FORCE_CAST(void *, p))); \ - (_________p1); \ - }) +#define LTTNG_UST_TP_RCU_LINK_TEST() (lttng_ust_tracepoint_dlopen_ptr && tp_rcu_read_lock) #endif /* _LGPL_SOURCE */ +#if LTTNG_UST_COMPAT_API(0) +#define tp_rcu_read_lock lttng_ust_tp_rcu_read_lock +#define tp_rcu_read_unlock lttng_ust_tp_rcu_read_unlock +#define tp_rcu_dereference lttng_ust_tp_rcu_dereference +#define TP_RCU_LINK_TEST LTTNG_UST_TP_RCU_LINK_TEST +#endif + #endif /* _LTTNG_TRACEPOINT_RCU_H */