On 2023-05-11 14:13, Mathieu Desnoyers via lttng-dev wrote:
On 2023-05-11 12:36, Brian Hutchinson via lttng-dev wrote:
... more background. I've always used ltt in the kernel so I don't
have much experience with the user side of it and especially
multi-threaded, multi-core so I'm probably missing some fundamental
concepts that I need to understand.
Which are the exact versions of LTTng-UST and LTTng-Tools you are using
now ? (2.13.N or which git commit ?)
Also, can you try using lttng-ust stable-2.13 branch, which includes the
following commit ?
commit be2ca8b563bab81be15cbce7b9f52422369f79f7
Author: Mathieu Desnoyers <mathieu.desnoy...@efficios.com>
Date: Tue Feb 21 14:29:49 2023 -0500
Fix: Reevaluate LTTNG_UST_TRACEPOINT_DEFINE each time tracepoint.h is
included
Fix issues with missing symbols in use-cases where tracef.h is included
before defining LTTNG_UST_TRACEPOINT_DEFINE, e.g.:
#include <lttng/tracef.h>
#define LTTNG_UST_TRACEPOINT_DEFINE
#include <provider.h>
It is caused by the fact that tracef.h includes tracepoint.h in a
context which has LTTNG_UST_TRACEPOINT_DEFINE undefined, and this is not
re-evaluated for the following includes.
Fix this by lifting the definition code in tracepoint.h outside of the
header include guards, and #undef the old LTTNG_UST__DEFINE_TRACEPOINT
before re-defining it to its new semantic. Use a new
_LTTNG_UST_TRACEPOINT_DEFINE_ONCE include guard within the
LTTNG_UST_TRACEPOINT_DEFINE defined case to ensure symbols are not
duplicated.
Signed-off-by: Mathieu Desnoyers <mathieu.desnoy...@efficios.com>
Change-Id: I0ef720435003a7ca0bfcf29d7bf27866c5ff8678
Thanks,
Mathieu
Thanks,
Mathieu
Regards,
Brian
On Thu, May 11, 2023 at 11:53 AM Brian Hutchinson
<b.hutch...@gmail.com> wrote:
Hi,
I posted a while ago (thread - Using lttng 2.11 and UST doesn't appear
to work - getting empty trace files) about this problem I'm having
with getting empty trace logs.
I've since upgraded to lttng v2.13 and while I can do a simple hello
world program with tracef and get events in the log files, my more
complicated large multi-threaded app I'm trying to debug is still
getting empty log file traces.
I can list the user space events in my app.
Next I do:
lttng enable-event --userspace 'lttng_ust_tracef:*'
... to enable the events, start lttng, start my app, .... and I get a
trace directory structure that's empty.
I feel like I've read every thread in the archives about people having
the same problem.
I did try using LD_PRELOAD with various libs thinking that was the
problem but so far I'm still getting empty traces.
So far I've tried:
LD_PRELOAD=liblttng-ust-libc-wrapper.so.1:liblttng-ust-pthread-wrapper.so.1:liblttng-ust-dl.so.1:liblttng-ust-fork.so.1:liblttng-ust-fd.so.1
/usr/local/bin/my_app
I guess one question I have is how do I determine which "helper libs"
I need to preload?
The application I'm working on is made up of a bunch of smaller static
libs linked together into one big executable and that is linked with
-llttng-ust and -ldl.
I'm pretty stuck at the moment. Anyone have any wisdom on what I
might be doing wrong or how I can tell why I'm not getting events in
the logs?
Thanks,
Brian
_______________________________________________
lttng-dev mailing list
lttng-dev@lists.lttng.org
https://lists.lttng.org/cgi-bin/mailman/listinfo/lttng-dev
--
Mathieu Desnoyers
EfficiOS Inc.
https://www.efficios.com
_______________________________________________
lttng-dev mailing list
lttng-dev@lists.lttng.org
https://lists.lttng.org/cgi-bin/mailman/listinfo/lttng-dev