On 2023-05-17 12:37, Brian Hutchinson wrote:
On Wed, May 17, 2023 at 12:08 PM Mathieu Desnoyers
<mathieu.desnoy...@efficios.com> wrote:
On 2023-05-16 22:11, Brian Hutchinson via lttng-dev wrote:
Hi,
I'm trying to figure out how to use uprobes with lttng.
I can't use a normal uprobe for a line number just using the address I
want to probe obtained from objdump? As in:
echo 'p /usr/local/bin/my_app:0x2c3a8' >>
/sys/kernel/debug/tracing/uprobe_events
... which isn't a function entry, it's just a line of code I want to probe on.
This link says it has to be elf or sdt:
https://lttng.org/man/1/lttng-enable-event/v2.11/#doc-opt--userspace-probe
So can I not probe on just a line of code by specifying an address???
It doesn't look like these methods above will do what I'm wanting to
do. I've tried to find examples of using enable-event --kernel
--userspace-probe= but there doesn't appear to be many.
There are examples here:
https://lttng.org/docs/v2.13/#doc-enabling-disabling-events
Indeed inserting a lttng-modules uprobe within functions is not
supported at the moment, mainly because we prefer to err towards safety
and don't have the validation in place to prevent corrupting the
program's instructions if an end user would try to insert a uprobe at an
address which is not an instruction boundary.
Hmm, was really hoping to be able to do dynamic tracing without having
to modify code.
uprobes with the proper validations about instruction boundaries would
eventually provide this. Another approach we want to invest time in is
to integrate libpatch from Olivier Dion into lttng-ust. This would
provide dynamic instrumentation with the performance of a purely
userspace tracer.
But those are all things that were never prioritized by any of our
customers, so they progress at a "back burner" pace.
I guess if I add a function call to a debug statement or something at
the point I want to probe then I could use the elf example.
Yes.
So we only support inserting uprobe on functions and SDT probes at
the moment.
I've heard of system tap but never used it. Will have to look into that.
I really want to get lttng-ust working but I'm getting pushback on the
time I'm spending trying to get it to work ... and would really like
to demonstrate something (was hoping kernel events and uprobes)
quickly to an audience that knows nothing about lttng or full stack
tracing to gain "buy in" for the effort.
Understood.
The main thing we are missing to help you on the UST front is a console
log of the _application_ with LTTNG_UST_DEBUG=1. I suspect it is not
collected in your tests.
Thanks,
Mathieu
You know, those pesky things called schedules.
Thanks,
Brian
Thanks,
Mathieu
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
--
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