[ltt-dev] UST double-buffering won't always trigger consumer daemon
Mathieu Desnoyers
compudj at krystal.dyndns.org
Mon Oct 31 18:26:42 EDT 2011
* Anders Carlsson (capricornalpha2 at gmail.com) wrote:
> Hello!
>
> I working on a UST port, but I cannot _reliably_ get trace data trough to
> the consumer daemon. To me it seems the traced application fails to trigger
> the consumer daemon when a sub-buffer boundary is crossed.
Can you specify which UST version you are working on ?
This looks like one of the few design issues that I fixed in the generic
ring buffer that I introduce in userspace in UST 2.0.
Thanks,
Mathieu
>
> From buffers.h:
>
> static __inline__ void ltt_check_deliver(struct ust_channel *chan,
> struct ust_buffer *buf,
> long offset, long commit_count, long idx)
> {
> long old_commit_count = commit_count - chan->subbuf_size;
>
> /* Check if all commits have been done */
> if (unlikely((BUFFER_TRUNC(offset, chan)
> >> chan->n_subbufs_order)
> - (old_commit_count
> & chan->commit_count_mask) == 0)) {
> ...
>
> This condition becomes true only when commit_count equals a multiple of
> chan->subbuf_size, but when I add a printout of the values it appears that
> the buffer boundary is often crossed without commit_count ever becoming
> equal to the subbuffer size. In those cases, the trace ceases to operate.
> This seems to depend on the various tracepoint data sizes, and the order of
> commit etc.
>
> I suppose this could be taken care of by aligning the reservations to the
> subbuffer boundaries. It seems to me there is already code to handle that
> (in ltt_relay_try_reserve_slow()) Am I correct?
>
> Am I missing something (e.g. alignment differences between ARM and x86)?
>
> Should I look somewhere specific?
>
> Thank you for reading this far. Any help is appreciated.
>
> Kind regards
> Anders
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
More information about the lttng-dev
mailing list