[ltt-dev] ltt channel thread safe?
Pierre-Marc Fournier
pierre-marc.fournier at polymtl.ca
Tue Aug 10 00:28:50 EDT 2010
On 08/04/2010 02:12 AM, chris meyers wrote:
> To give a bit of context to the problem. I am using user space ltt to
> help profile code. I have created two events, time_begin and time_end.
> The goal is to allow for logging the runtime of specific code blocks
> via start() stop() insertions.
>
> I am having some issues with traces not coming out "correct" on the
> other "end". Let me further explain what I mean by correct and end.
>
> correct
> trace_mark(ust, time_begin, "thread %d func %s depth %d extra %s", 0,
> __FUNCTION__, 1, __FUNCTION__)
> trace_mark(ust, time_end, "thread %d func %s depth %d extra %s", 0,
> __FUNCTION__, 1, __FUNCTION__)
>
> end
> ust.time_begin: 30208.932264102
> (/home/meyers/.usttraces/lappy-20100804020140730811027/28367_5501430910891543571/ust_0),
> 0, 0, , , 0, 0x0, MODE_UNKNOWN { thread = 1, func =
> "memloc_request_response_decider", depth = 1, extra =
> "memloc_request_response_decider" }
> ust.time_end: 30208.932267455
> (/home/meyers/.usttraces/lappy-20100804020140730811027/28367_5501430910891543571/ust_0),
> 0, 0, , , 0, 0x0, MODE_UNKNOWN { thread = 1, func =
> "memloc_request_response_decider", depth = 1, extra =
> "memloc_request_response_decider" }
>
> Later on the output looks like this:
> ust.time_begin: 30198.142843837
> (/home/meyers/.usttraces/lappy-20100804020140730811027/28367_5501430910891543571/ust_0),
> 0, 0, , , 0, 0x0, MODE_UNKNOWN { thread = 1, func = "ne_worker_thread",
> depth = 560296821, extra = "" }
>
> Notice that in the trace_mark() code above I hard coded depth to be 0
> and _str is always __FUNCTION__.
>
> Possible reasons:
> * Buffer is being overrun. I changed the buffer size using the -N and
> -S options in usttrace to something > 2 MB (plenty large).
> * Channels are not thread-safe? I have 3 threads of execution in this
> example. All using the ust channel.
Channels are supposed to be thread-safe.
If there is an overrun, it will be printed in the console output from
lttv. Overruns are always possible if the rate at which the application
produces events is higher than the rate at which they can be flushed to
the disk. The solution may be to increase buffer size to counter
temporary event rate peaks. However if the sustained rate is too high,
an overrun will still eventually happen. One way to avoid this would be
to add a synchronous mode where the application may block on a marker to
prevent overruns.
> * My code is crappy and I am overwriting the lust library buffer?
>
>
> Also, I am having trouble using any channel other than ust. Is ust the
> only channel available in user space?
From the ust manual:
"Note: Although this example uses mychannel as the channel, the only
channel name currently supported with early tracing is ust. The usttrace
tool always uses the early tracing mode. When using manual mode without
early tracing, any channel name may be used."
pmf
More information about the lttng-dev
mailing list