X-Git-Url: https://git.lttng.org/?a=blobdiff_plain;f=include%2Flttng%2Ftracepoint-event.h;h=a2f54066fe78e267dc217158dc40d8e2afe83420;hb=5b393d6424d959e2efbb800b0c8a61b81bf9968e;hp=94b0bcb17623117fb0a0c541e3eab7a9c561d8f6;hpb=1c324e592f238f5c1d19b19faf3a95a6d9185bdf;p=lttng-ust.git diff --git a/include/lttng/tracepoint-event.h b/include/lttng/tracepoint-event.h index 94b0bcb1..a2f54066 100644 --- a/include/lttng/tracepoint-event.h +++ b/include/lttng/tracepoint-event.h @@ -1,51 +1,96 @@ /* - * Copyright (c) 2011 - Mathieu Desnoyers + * SPDX-License-Identifier: MIT * - * 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. + * Copyright (C) 2011 Mathieu Desnoyers */ -#ifdef __cplusplus -extern "C" { -#endif +#include + -#ifdef TRACEPOINT_CREATE_PROBES +#if LTTNG_UST_COMPAT_API(0) +# if defined(TRACEPOINT_CREATE_PROBES) && !defined(LTTNG_UST_TRACEPOINT_CREATE_PROBES) +# define LTTNG_UST_TRACEPOINT_CREATE_PROBES +# endif +#endif /* #if LTTNG_UST_COMPAT_API(0) */ + +#ifdef LTTNG_UST_TRACEPOINT_CREATE_PROBES #define __tp_stringify1(x) #x #define __tp_stringify(x) __tp_stringify1(x) -#undef TRACEPOINT_EVENT_INSTANCE -#define TRACEPOINT_EVENT_INSTANCE(_provider, _template, _name, _args) \ - _DEFINE_TRACEPOINT(_provider, _name) +#undef LTTNG_UST_TRACEPOINT_EVENT_INSTANCE +#define LTTNG_UST_TRACEPOINT_EVENT_INSTANCE(_provider, _template, _name, _args) -#undef TRACEPOINT_EVENT -#define TRACEPOINT_EVENT(_provider, _name, _args, _fields) \ - TRACEPOINT_EVENT_CLASS(_provider, _name, _TP_PARAMS(_args), \ - _TP_PARAMS(_fields)) \ - TRACEPOINT_EVENT_INSTANCE(_provider, _name, _name, \ - _TP_PARAMS(_args)) +#undef LTTNG_UST_TRACEPOINT_EVENT +#define LTTNG_UST_TRACEPOINT_EVENT(_provider, _name, _args, _fields) \ + LTTNG_UST_TRACEPOINT_EVENT_CLASS(_provider, _name, LTTNG_UST__TP_PARAMS(_args), \ + LTTNG_UST__TP_PARAMS(_fields)) \ + LTTNG_UST_TRACEPOINT_EVENT_INSTANCE(_provider, _name, _name, \ + LTTNG_UST__TP_PARAMS(_args)) -#define TRACEPOINT_INCLUDE __tp_stringify(TRACEPOINT_INCLUDE_FILE) +#undef LTTNG_UST_TRACEPOINT_CREATE_PROBES +#if LTTNG_UST_COMPAT_API(0) #undef TRACEPOINT_CREATE_PROBES +#endif +#define LTTNG_UST_TRACEPOINT_HEADER_MULTI_READ +#if LTTNG_UST_COMPAT_API(0) #define TRACEPOINT_HEADER_MULTI_READ -#include TRACEPOINT_INCLUDE +#endif + +#if LTTNG_UST_COMPAT_API(0) +# if defined(TRACEPOINT_INCLUDE) && !defined(LTTNG_UST_TRACEPOINT_INCLUDE) +# define LTTNG_UST_TRACEPOINT_INCLUDE TRACEPOINT_INCLUDE +# endif +#endif /* #if LTTNG_UST_COMPAT_API(0) */ + +#if LTTNG_UST_COMPAT_API(0) +# if defined(TRACEPOINT_PROVIDER) && !defined(LTTNG_UST_TRACEPOINT_PROVIDER) +# define LTTNG_UST_TRACEPOINT_PROVIDER TRACEPOINT_PROVIDER +# endif +#endif /* #if LTTNG_UST_COMPAT_API(0) */ + +#include LTTNG_UST_TRACEPOINT_INCLUDE #include +#undef LTTNG_UST_TRACEPOINT_HEADER_MULTI_READ +#if LTTNG_UST_COMPAT_API(0) #undef TRACEPOINT_HEADER_MULTI_READ +#endif -#define TRACEPOINT_CREATE_PROBES +#undef LTTNG_UST_TRACEPOINT_INCLUDE +#if LTTNG_UST_COMPAT_API(0) +# undef TRACEPOINT_INCLUDE +#endif -#endif /* TRACEPOINT_CREATE_PROBES */ +#define LTTNG_UST_TRACEPOINT_CREATE_PROBES -#ifdef __cplusplus -} -#endif +/* + * Put back definitions to the state they were when defined by + * tracepoint.h. + */ +#undef LTTNG_UST_TP_ARGS +#define LTTNG_UST_TP_ARGS(...) __VA_ARGS__ + +#undef LTTNG_UST_TRACEPOINT_EVENT +#define LTTNG_UST_TRACEPOINT_EVENT(provider, name, args, fields) \ + LTTNG_UST__DECLARE_TRACEPOINT(provider, name, LTTNG_UST__TP_PARAMS(args)) \ + LTTNG_UST__DEFINE_TRACEPOINT(provider, name, LTTNG_UST__TP_PARAMS(args)) + +#undef LTTNG_UST_TRACEPOINT_EVENT_CLASS +#define LTTNG_UST_TRACEPOINT_EVENT_CLASS(provider, name, args, fields) + +#undef LTTNG_UST_TRACEPOINT_EVENT_INSTANCE +#define LTTNG_UST_TRACEPOINT_EVENT_INSTANCE(provider, _template, name, args) \ + LTTNG_UST__DECLARE_TRACEPOINT(provider, name, LTTNG_UST__TP_PARAMS(args)) \ + LTTNG_UST__DEFINE_TRACEPOINT(provider, name, LTTNG_UST__TP_PARAMS(args)) + +#undef LTTNG_UST_TRACEPOINT_LOGLEVEL +#define LTTNG_UST_TRACEPOINT_LOGLEVEL(provider, name, loglevel) + +#undef LTTNG_UST_TRACEPOINT_MODEL_EMF_URI +#define LTTNG_UST_TRACEPOINT_MODEL_EMF_URI(provider, name, uri) + +#endif /* LTTNG_UST_TRACEPOINT_CREATE_PROBES */