X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=include%2Flttng%2Ftracepoint-rcu.h;h=58de697be88ebb660103be47b3e06dfa8ab35942;hb=1c1968450409b3c159a3000f9e1a968ff1e5f7e8;hp=23dab7d6c9b47e9838e719d00a479dff315d4cfc;hpb=51920067af7b1049413c1b8c30ee254afbd4e448;p=lttng-ust.git diff --git a/include/lttng/tracepoint-rcu.h b/include/lttng/tracepoint-rcu.h index 23dab7d6..58de697b 100644 --- a/include/lttng/tracepoint-rcu.h +++ b/include/lttng/tracepoint-rcu.h @@ -1,47 +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_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 TP_RCU_LINK_TEST() 1 +#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_read_lock_bp tracepoint_dlopen.rcu_read_lock_sym_bp -#define tp_rcu_read_unlock_bp tracepoint_dlopen.rcu_read_unlock_sym_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 -#define tp_rcu_dereference_bp(p) \ - ({ \ - typeof(p) _________p1 = URCU_FORCE_CAST(typeof(p), \ - tracepoint_dlopen.rcu_dereference_sym_bp(URCU_FORCE_CAST(void *, p))); \ - (_________p1); \ - }) +#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_LINK_TEST() tp_rcu_read_lock_bp +#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 */