X-Git-Url: https://git.liburcu.org/?a=blobdiff_plain;f=include%2Fust%2Ftracepoint.h;h=ec1a4fce76bf55ec6cb1085688dcd7a0e4a1622c;hb=42be6c46cb6afa9720c224c24ccabb2ce21293d1;hp=626f8af545dfea3d9c5136503ad7a61c44fae6ef;hpb=377d33ed8d03fbfd6c8655862de50d7fc213c0f4;p=ust.git diff --git a/include/ust/tracepoint.h b/include/ust/tracepoint.h index 626f8af..ec1a4fc 100644 --- a/include/ust/tracepoint.h +++ b/include/ust/tracepoint.h @@ -27,10 +27,8 @@ #define _LGPL_SOURCE #include -#include #include -struct module; struct tracepoint; struct probe { @@ -40,7 +38,7 @@ struct probe { struct tracepoint { const char *name; /* Tracepoint name */ - DEFINE_IMV(char, state); /* State. */ + char state; /* State. */ struct probe *probes; }; @@ -86,39 +84,23 @@ struct tracepoint { rcu_read_unlock(); \ } while (0) -#define __CHECK_TRACE(name, generic, proto, args) \ +#define __CHECK_TRACE(name, proto, args) \ do { \ - if (!generic) { \ - if (unlikely(imv_read(__tracepoint_##name.state))) \ - __DO_TRACE(&__tracepoint_##name, \ - TP_PROTO(proto), TP_ARGS(args)); \ - } else { \ - if (unlikely(_imv_read(__tracepoint_##name.state))) \ - __DO_TRACE(&__tracepoint_##name, \ - TP_PROTO(proto), TP_ARGS(args)); \ - } \ + if (unlikely(__tracepoint_##name.state)) \ + __DO_TRACE(&__tracepoint_##name, \ + TP_PROTO(proto), TP_ARGS(args)); \ } while (0) /* * Make sure the alignment of the structure in the __tracepoints section will * not add unwanted padding between the beginning of the section and the * structure. Force alignment to the same alignment as the section start. - * - * The "generic" argument, passed to the declared __trace_##name inline - * function controls which tracepoint enabling mechanism must be used. - * If generic is true, a variable read is used. - * If generic is false, immediate values are used. */ #define __DECLARE_TRACE(name, proto, args, data_proto, data_args) \ extern struct tracepoint __tracepoint_##name; \ static inline void __trace_##name(proto) \ { \ - __CHECK_TRACE(name, 0, TP_PROTO(data_proto), \ - TP_ARGS(data_args)); \ - } \ - static inline void _trace_##name(proto) \ - { \ - __CHECK_TRACE(name, 1, TP_PROTO(data_proto), \ + __CHECK_TRACE(name, TP_PROTO(data_proto), \ TP_ARGS(data_args)); \ } \ static inline int \ @@ -216,7 +198,6 @@ extern int tracepoint_probe_unregister_noupdate(const char *name, void *probe, extern void tracepoint_probe_update_all(void); struct tracepoint_iter { -//ust// struct module *module; struct tracepoint_lib *lib; struct tracepoint * const *tracepoint; };