X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=include%2Flttng%2Ftracepoint-rcu.h;h=4528236814c777b0b563fef05bd1f9a0ba3eaf86;hb=ed6dd5d6d9f0ddccd1a09afea5398705bb934048;hp=852cfe48d55ee630d588a7ed64d822142e3c7561;hpb=40b2b5a43e4c2067849770b3379ca5360facacd5;p=lttng-ust.git diff --git a/include/lttng/tracepoint-rcu.h b/include/lttng/tracepoint-rcu.h index 852cfe48..45282368 100644 --- a/include/lttng/tracepoint-rcu.h +++ b/include/lttng/tracepoint-rcu.h @@ -1,48 +1,34 @@ -#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. + * SPDX-License-Identifier: MIT * - * 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. + * Copyright (C) 2011-2012 Mathieu Desnoyers */ +#ifndef _LTTNG_TRACEPOINT_RCU_H +#define _LTTNG_TRACEPOINT_RCU_H + #include +#include #ifdef _LGPL_SOURCE -#include +#include +#define tp_rcu_read_lock lttng_ust_urcu_read_lock +#define tp_rcu_read_unlock lttng_ust_urcu_read_unlock +#define tp_rcu_dereference lttng_ust_rcu_dereference #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 #else /* _LGPL_SOURCE */ -#define TP_RCU_LINK_TEST() tp_rcu_read_lock_bp +#define tp_rcu_read_lock tracepoint_dlopen_ptr->rcu_read_lock_sym +#define tp_rcu_read_unlock 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 tp_rcu_dereference(p) \ + URCU_FORCE_CAST(__typeof__(p), \ + 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 TP_RCU_LINK_TEST() (tracepoint_dlopen_ptr && tp_rcu_read_lock) #endif /* _LGPL_SOURCE */