[ltt-dev] Traces data alignment
Jérôme Stadelmann
jerome.stadelmann at heig-vd.ch
Thu Mar 26 02:41:14 EDT 2009
On mercredi 25 mars 2009 08:05:18 Mathieu Desnoyers wrote:
> * Jérôme Stadelmann (jerome.stadelmann at heig-vd.ch) wrote:
> > On mardi 24 mars 2009 14:11:31 Mathieu Desnoyers wrote:
> > > * Jérôme Stadelmann (jerome.stadelmann at heig-vd.ch) wrote:
> > > > On vendredi 20 mars 2009 15:53:55 Mathieu Desnoyers wrote:
> > > > > * Jérôme Stadelmann (jerome.stadelmann at heig-vd.ch) wrote:
> > > > > > On jeudi 19 mars 2009 18:00:01 Mathieu Desnoyers wrote:
> > > > > > > * Jérôme Stadelmann (jerome.stadelmann at heig-vd.ch) wrote:
> > > > > > > > Hi everybody,
> > > > > > > >
> > > > > > > > I'm working on a LTTng traces parser and I'm a little bit blocked on the alignment. Can someone please explain how and where it is coded ?
> > > > > > >
> > > > > > > The lttv lib "ltttraceread" should do that for you.
> > > > > >
> > > > > > > > What are the roles of the alignment defined in the traces header and the one defined in the metadata file in the core_marker_id ?
> > > > > > > >
> > > > > > >
> > > > > > > They tell that a specific tracefile content is aligned or not, and if
> > > > > > > the content of a given event is aligned or not. You should really have
> > > > > > > at least a look at the ltt lib traceread reference implementation.
> > > > > >
> > > > > > Thank you. This library helped me a lot. I see that there is an up to 2 byte alignment in the core marker id event definition. Is there the only special case ?
> > > > > > I've searched the uses of the ltt_align function. Are there other functions to look for ?
> > > > > >
> > > > >
> > > > > Looking at ltt_align use is a good starting point.
> > > > >
> > > > > Can you point out to the specific package/version/file/line you refer to
> > > > > for the core marker id "special case" you talk about here ?
> > > > >
> > > >
> > > > I think I've understood now. The alignment in the metadata file is
> > > > "hardcoded" as 2 byte because the id field is the biggest value and is
> > > > coded as a 2 bytes value. Am I right ?
> > > >
> > >
> > > Possibly. Again, can you point out which package/version/file/line you
> > > refer to so I can be sure we are talking about the same piece of code ?
> > > Telling which file and function, with a cut and paste of the context,
> > > would be nice to have.
> > >
> >
> > in tracefile.c :
> >
> > static int ltt_process_metadata_tracefile(LttTracefile *tf)
> > {
> > .....
> >
> > case MARKER_ID_SET_MARKER_ID:
> > channel_name = pos = tf->event.data;
> > pos += strlen(channel_name) + 1;
> > marker_name = pos;
> > g_debug("Doing MARKER_ID_SET_MARKER_ID of marker %s.%s",
> > channel_name, marker_name);
> > pos += strlen(marker_name) + 1;
> >
> > pos += ltt_align((size_t)pos, sizeof(guint16), tf->alignment);
> >
> > id = ltt_get_uint16(LTT_GET_BO(tf), pos);
> > g_debug("In MARKER_ID_SET_MARKER_ID of marker %s.%s id %hu",
> > channel_name, marker_name, id);
> > pos += sizeof(guint16);
> > int_size = *(guint8*)pos;
> > pos += sizeof(guint8);
> > long_size = *(guint8*)pos;
> > pos += sizeof(guint8);
> > pointer_size = *(guint8*)pos;
> > pos += sizeof(guint8);
> > size_t_size = *(guint8*)pos;
> > pos += sizeof(guint8);
> > alignment = *(guint8*)pos;
> > pos += sizeof(guint8);
> >
> > .....
> > }
> >
> > As I said, you are using an "hardcoded" up to 2 bytes alignment because you already know in this case all the fields ?
> >
>
> I use a 2 bytes alignment there because I know the next field is 2
> bytes in size.
>
> Alignment of the whole event payload is done by the
> ltt_update_event_size() call in ltt_tracefile_read_update_event(). See
> the following comment :
>
> /*
> * Let ltt_update_event_size update event->data according to the largest
> * alignment within the payload.
> * Get the data size and update the event fields with the current
> * information. */
>
> There is a small trick here though : ltt_update_event_size() seems to
> assume that the payload will always be aligned on 2-bytes boundaries (it
> does not ltt_align at the beginning of the metadata parsing code). It's
> OK because, when trace alignment is active, event headers are aligned on
> their own size, and they are always multiples of 2 bytes.
>
> It could be more solid if I added a ltt_align on 2-bytes at the
> beginning of those though. That would not fail if the event header
> becomes something else than a 2-bytes multiple.
>
> Mathieu
Now with your explanations I could do what I wanted. Thanks for your help.
Best regards
Jerome
>
> > > Mathieu
> > >
> > > > > Mathieu
> > > > >
> > > > > > Jerome
> > > > > >
> > > > > > > Mathieu
> > > > > > >
> > > > > > > > Regards,
> > > > > > > > Jerome
> > > > > > > >
> > > > > > > > _______________________________________________
> > > > > > > > ltt-dev mailing list
> > > > > > > > ltt-dev at lists.casi.polymtl.ca
> > > > > > > > http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
> > > > > > > >
> > > > > > >
> > > > > >
> > > > >
> > > >
> > >
> >
>
More information about the lttng-dev
mailing list