[ltt-dev] [Fwd: Re: sub roadmap for text output]

Mathieu Desnoyers compudj at krystal.dyndns.org
Fri Dec 12 09:13:42 EST 2008


* Lai Jiangshan (laijs at cn.fujitsu.com) wrote:
> Mathieu Desnoyers wrote:
[...]
> > Lai wrote:
> >> Mathieu Desnoyers wrote:
> >>>> 2) ltt-relay events traveling
> >>>>    current ltt-relay does not support iterator. it seems that ltt-relay is too
> >>>>    complex to do this things. Is any plan to revise ltt-relay?
> >>>>
> >>> ltt-relay task is to write data into buffers. I would create a different
> >>> module which task is to do just like lttd does (get subbuf, read, put
> >>> subbuf), but within the kernel. We might have to extend the API beyond
> >>> the current ioctl/poll-based interface to allow in-kernel modules to do
> >>> this.
> >>>
> >>> Side-note : I think I would need to hook into open()/close() to keep
> >>> refcounts on the channel reads rather that to use the get subbuf/put
> >>> subbuf for refcounting. The currently implementation will behave a bit
> >>> weirdly if multiple processes try to hook on the same trace channels.
> >>> The resulting trace outputs will only each have part of the subbuffers.
> >>>
> >> Very shocked!
> >> I thought we should iterate very events directly in kernel, and merge them.
> >> What you do is moving a user-space tool to kernel.
> >>
> > 
> > Hrm, I think I have not been clear enough then. Sorry. My plan is to
> > iterate on every events directly in kernel. Those events will be stored
> > in ltt-relay buffers. We will _not_ use the poll() and ioctl() methods.
> > Instead, we will create new in-kernel APIs which will act _similarly_ to
> > those primitives. But everything will be in-kernel.
> > 
> > Those two different methods of accessing the buffers would be called
> > "data consumers".
> > 
> > (current) method 1:
> > - poll, ioctl, splice to export the data
> > 
> > (new) text output consumer :
> > - api to get events from a trace channel, merging the events by
> >   increasing timestamp
> > - exports the data to a userspace seq file (single stream per trace)
> 
> I understood. I had said, we need revise ltt-relay a lot:
> >>>> 2) ltt-relay events traveling
> >>>>    current ltt-relay does not support iterator. it seems that ltt-relay is too
> >>>>    complex to do this things. Is any plan to revise ltt-relay?
> But ltt-relay is so complicated that I can't write iterator for it.
> 

That's why I suggested that we first look at how ltt_ioctl and ltt_poll
works, because this is about the only thing we really need to understand
to create iterators. Because an iterator can be seen as a data
"consumer", and all the code that is responsible for synchronizing the
data consumption sits in ltt_ioctl and ltt_poll.

Mathieu

-- 
Mathieu Desnoyers
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F  BA06 3F25 A8FE 3BAE 9A68




More information about the lttng-dev mailing list