X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=include%2Flttng%2Ftracepoint-rcu.h;h=58de697be88ebb660103be47b3e06dfa8ab35942;hb=1c1968450409b3c159a3000f9e1a968ff1e5f7e8;hp=852cfe48d55ee630d588a7ed64d822142e3c7561;hpb=40b2b5a43e4c2067849770b3379ca5360facacd5;p=lttng-ust.git diff --git a/include/lttng/tracepoint-rcu.h b/include/lttng/tracepoint-rcu.h index 852cfe48..58de697b 100644 --- a/include/lttng/tracepoint-rcu.h +++ b/include/lttng/tracepoint-rcu.h @@ -1,49 +1,41 @@ -#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. - * - * This file allows weak linking on tracepoint RCU symbols for non-LGPL - * code. - */ +// SPDX-FileCopyrightText: 2011-2012 Mathieu Desnoyers +// +// SPDX-License-Identifier: MIT + +#ifndef _LTTNG_UST_TRACEPOINT_RCU_H +#define _LTTNG_UST_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 && lttng_ust_tp_rcu_read_lock) #endif /* _LGPL_SOURCE */ -#endif /* _LTTNG_TRACEPOINT_RCU_H */ +#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_UST_TRACEPOINT_RCU_H */