X-Git-Url: http://git.lttng.org/?a=blobdiff_plain;f=liblttng-ust%2Ftracef.c;h=d5d702a85a7acac405596cc3aec0a49d3d54bedc;hb=f03092d7780681b375484769c2f0e20ed0f0d2a2;hp=9ef063ce754c4bdcc05edf199c47794cb9afc066;hpb=641c659aa0558ea68008e96c64abe9629d540ae7;p=lttng-ust.git diff --git a/liblttng-ust/tracef.c b/liblttng-ust/tracef.c index 9ef063ce..d5d702a8 100644 --- a/liblttng-ust/tracef.c +++ b/liblttng-ust/tracef.c @@ -20,27 +20,40 @@ * SOFTWARE. */ -#define _GNU_SOURCE #define _LGPL_SOURCE #include +#include #define TRACEPOINT_CREATE_PROBES #define TRACEPOINT_DEFINE #include "lttng-ust-tracef-provider.h" -void _lttng_ust_tracef(const char *fmt, ...) +static inline __attribute__((always_inline)) +void __lttng_ust_vtracef(const char *fmt, va_list ap) { - va_list ap; char *msg; - int len; + const int len = vasprintf(&msg, fmt, ap); - va_start(ap, fmt); - len = vasprintf(&msg, fmt, ap); /* len does not include the final \0 */ if (len < 0) goto end; - __tracepoint_cb_lttng_ust_tracef___event(msg, len); + __tracepoint_cb_lttng_ust_tracef___event(msg, len, + LTTNG_UST_CALLER_IP()); free(msg); end: + return; +} + +void _lttng_ust_vtracef(const char *fmt, va_list ap) +{ + __lttng_ust_vtracef(fmt, ap); +} + +void _lttng_ust_tracef(const char *fmt, ...) +{ + va_list ap; + + va_start(ap, fmt); + __lttng_ust_vtracef(fmt, ap); va_end(ap); }