[ltt-dev] UST double-buffering won't always trigger consumer daemon
Mathieu Desnoyers
compudj at krystal.dyndns.org
Tue Nov 1 13:18:59 EDT 2011
* Mathieu Desnoyers (compudj at krystal.dyndns.org) wrote:
> * 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.
For everyone's benefit, I received a private reply stating that the
problem was not in UST upstream, but rather in the specific adaptation
Anders is working on.
Thanks,
Mathieu
>
> 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
>
> _______________________________________________
> 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