Hi Brian,

On 7/12/24 2:56 PM, Brian Hutchinson wrote:
Hi again Kienan,

Manifest says librcu is 0.13.2.

thanks


The app is made up of a bunch of sup projects (about 40 or so) that are built into a bunch of .o objects (I think it's a structure automatically setup by cmake) and finally linked together with the main app .o object so it looks like it's all static linking.

The part where I put in a call to lttng-ust trace is in one of the sub projects.  Looking at all of your example linking scenarios in the documentation, I think what we are doing fits the same scenario as the hello world build/link.

All of the sub project .o's are linked with the main app's .o and linked with lttng-ust and ld at the end.

I've also tried building the trace provider bits linked with lttng-ust and dl as a .so and using LD_PRELOAD to load that before starting the app.  I get same segfault that way too.

Stupid question.  Do I need to create a lttng session or something before the app with lttng-ust tracepoints even runs?  Reason I ask is, systemd starts up several other apps that setup and do things that the app in question needs before it can run so I was hoping the app could start then I create a session and attach to the pid to do tracing.  I can't really start it like the hello world where is runs and pauses while you wait for a key press and then setup and start all the lttng session and recording bits, then hit a key and the tracepoints are exercised.  From all I've read, an application with lttng-ust tracepoints should run as a normal program and the tracing lines do nothing until a lttng session is started and the tracepoints enabled.


It's not necessary to create a session, or even have the sessiond running when a traced application is launched.

When an application that is compiled with user-space tracing, there's are early constructors that run prior to the application's main entry point. By default this waits for up to 3000ms to perform registration with a sessiond before continuing to the program's main entry point. This delay is controlled by the environment variable LTTNG_UST_REGISTER_TIMEOUT ( see https://lttng.org/man/3/lttng-ust/v2.13/#doc-_environment_variables ).

The UST application also opens a piece of shared memory at a well known location and reads it waiting for changes. The sessiond will write to the shared memory at the location when it starts to signal to any UST apps that registration can be retried. C.f. https://github.com/lttng/lttng-ust/blob/9b9714603cfa96a63a42dc9cb8266f81df42a4f3/src/lib/lttng-ust/lttng-ust-comm.c#L1978

Thought I'd ask in case my understanding is wrong and how I'm starting things up is the problem.

I'll work on fixing the 2.13.8 lttng-ust built (as I'm not convinced yet it's right based on what I mentioned before) and let you know how it goes.


If you're not sure re: size, you could always compute a sha512 sum for the libraries.


thanks,
kienan

P.S. Could you please keep lttng-dev in CC? thank you.

Thanks and have a good weekend!

Regards,

Brian

On Fri, Jul 12, 2024 at 10:30 AM Brian Hutchinson <b.hutch...@gmail.com <mailto:b.hutch...@gmail.com>> wrote:

    No, it's a giant app.   But made what I'm trying to test as simple
    as possible to demonstrate the error ... its the same trace provider
    that worked with hello world and my app is just calling a line of that.

    I don't think I did something right with my 2.13.8 build.  Bitbake
    made a package that says it's 2.13.8 but I compared the files to
    2.13.6 and the file sizes were all identical so somethings not
    right.   So I need to figure out why recipe isn't working.

    I'm off work today but when I get a chance I'll check manifest and
    get you the rcu version and try to describe how app is built.

    Thanks,

    Brian

    On Fri, Jul 12, 2024, 10:17 AM Kienan Stewart <kstew...@efficios.com
    <mailto:kstew...@efficios.com>> wrote:

        Hi Brian,

        On 7/11/24 7:20 PM, Brian Hutchinson wrote:
         > Hi Kienan
         >
         > Do I need to update lttng-tools and modules too?  I did a
        bbappend and
> pulled in 2.13.8 recipe from master and get the same issue. I'm double
         > checking to make sure everything built right.  Had to update
        sdk, rootfs
         > and rebuild app with new sdk etc.

        I don't believe so.

        Do you have a minimal reproducer example that you are able to share
        including the build instructions you are using?

        Also, which version of urcu is being used in your environment?

        thanks,
        kienan

         >
         > Regards,
         >
         > Brian
         >
         > On Thu, Jul 11, 2024 at 8:38 AM Kienan Stewart
        <kstew...@efficios.com <mailto:kstew...@efficios.com>
         > <mailto:kstew...@efficios.com
        <mailto:kstew...@efficios.com>>> wrote:
         >
         >     Hi Brian,
         >
         >     On 7/11/24 8:33 AM, Brian Hutchinson via lttng-dev wrote:
         >       > ...
         >       >
         >       > I'm not sure about this, still trying to comprehend
        everything,
         >     but I
         >       > think my issue could be related to all this gcc TLS,
        heap,
         >     trampoline
         >       > talk here:
         >       >
         >       >
         >
        https://www.mail-archive.com/lttng-dev@lists.lttng.org/msg13584.html 
<https://www.mail-archive.com/lttng-dev@lists.lttng.org/msg13584.html>
>  <https://www.mail-archive.com/lttng-dev@lists.lttng.org/msg13584.html <https://www.mail-archive.com/lttng-dev@lists.lttng.org/msg13584.html>>
         >       >
>  <https://www.mail-archive.com/lttng-dev@lists.lttng.org/msg13584.html <https://www.mail-archive.com/lttng-dev@lists.lttng.org/msg13584.html> <https://www.mail-archive.com/lttng-dev@lists.lttng.org/msg13584.html <https://www.mail-archive.com/lttng-dev@lists.lttng.org/msg13584.html>>>
         >       >
         >       > Regards,
         >       >
         >       > Brian
         >       >
         >
         >     You could try using lttng-ust 2.13.8, which includes a
        fix for the
         >     discussion you referenced.
         >
         >
        https://github.com/lttng/lttng-ust/commit/5db715e800d9b721f48495a987cd26c25965e836 
<https://github.com/lttng/lttng-ust/commit/5db715e800d9b721f48495a987cd26c25965e836> 
<https://github.com/lttng/lttng-ust/commit/5db715e800d9b721f48495a987cd26c25965e836 
<https://github.com/lttng/lttng-ust/commit/5db715e800d9b721f48495a987cd26c25965e836>>
         >
         >     Please let us know if it doesn't solve it.
         >
         >     thanks,
         >     kienan
         >

_______________________________________________
lttng-dev mailing list
lttng-dev@lists.lttng.org
https://lists.lttng.org/cgi-bin/mailman/listinfo/lttng-dev

Reply via email to