[ltt-dev] [PATCH take2 03/13] read event header from ltt-relay buffer
Mathieu Desnoyers
compudj at krystal.dyndns.org
Mon Feb 23 11:40:34 EST 2009
* Lai Jiangshan (laijs at cn.fujitsu.com) wrote:
> we implement ltt_read_event_header() read event header from ltt-relay
> buffer. it does the work oppositely to ltt_write_event_header().
>
This patch is ready, I'm merging it. Thanks !
Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers at polymtl.ca>
> Signed-off-by: Lai Jiangshan <laijs at cn.fujitsu.com>
> ---
> diff --git a/include/linux/ltt-tracer.h b/include/linux/ltt-tracer.h
> index ef91456..42fc47d 100644
> --- a/include/linux/ltt-tracer.h
> +++ b/include/linux/ltt-tracer.h
> @@ -290,6 +290,8 @@ struct ltt_event_header {
> #define LTT_RFLAG_ID_SIZE (1 << 1)
> #define LTT_RFLAG_ID_SIZE_TSC (1 << 2)
>
> +#define LTT_MAX_SMALL_SIZE 0xFFFFU
> +
> /*
> * We use asm/timex.h : cpu_khz/HZ variable in here : we might have to deal
> * specifically with CPU frequency scaling someday, so using an interpolation
> @@ -359,7 +361,8 @@ static inline size_t ltt_subbuffer_header_size(void)
> * Alignment of header struct on 32 bits (min arch size, header size)
> * + sizeof(header struct) (32-bits)
> * + (opt) u16 (ext. event id)
> - * + (opt) u16 (event_size) (if event_size == 0xFFFFUL, has ext. event size)
> + * + (opt) u16 (event_size)
> + * (if event_size == LTT_MAX_SMALL_SIZE, has ext. event size)
> * + (opt) u32 (ext. event size)
> * + (opt) u64 full TSC (aligned on min(64-bits, arch size))
> *
> @@ -385,14 +388,14 @@ static inline unsigned char ltt_get_header_size(
> switch (rflags) {
> case LTT_RFLAG_ID_SIZE_TSC:
> offset += sizeof(u16) + sizeof(u16);
> - if (data_size >= 0xFFFFU)
> + if (data_size >= LTT_MAX_SMALL_SIZE)
> offset += sizeof(u32);
> offset += ltt_align(offset, sizeof(u64));
> offset += sizeof(u64);
> break;
> case LTT_RFLAG_ID_SIZE:
> offset += sizeof(u16) + sizeof(u16);
> - if (data_size >= 0xFFFFU)
> + if (data_size >= LTT_MAX_SMALL_SIZE)
> offset += sizeof(u32);
> break;
> case LTT_RFLAG_ID:
> @@ -449,14 +452,14 @@ static inline size_t ltt_write_event_header(struct ltt_trace_struct *trace,
>
> switch (rflags) {
> case LTT_RFLAG_ID_SIZE_TSC:
> - small_size = min_t(size_t, event_size, 0xFFFFU);
> + small_size = min_t(size_t, event_size, LTT_MAX_SMALL_SIZE);
> ltt_relay_write(buf, buf_offset,
> (u16[]){ (u16)eID }, sizeof(u16));
> buf_offset += sizeof(u16);
> ltt_relay_write(buf, buf_offset,
> (u16[]){ (u16)small_size }, sizeof(u16));
> buf_offset += sizeof(u16);
> - if (small_size == 0xFFFFU) {
> + if (small_size == LTT_MAX_SMALL_SIZE) {
> ltt_relay_write(buf, buf_offset,
> (u32[]){ (u32)event_size }, sizeof(u32));
> buf_offset += sizeof(u32);
> @@ -467,14 +470,14 @@ static inline size_t ltt_write_event_header(struct ltt_trace_struct *trace,
> buf_offset += sizeof(u64);
> break;
> case LTT_RFLAG_ID_SIZE:
> - small_size = min_t(size_t, event_size, 0xFFFFU);
> + small_size = min_t(size_t, event_size, LTT_MAX_SMALL_SIZE);
> ltt_relay_write(buf, buf_offset,
> (u16[]){ (u16)eID }, sizeof(u16));
> buf_offset += sizeof(u16);
> ltt_relay_write(buf, buf_offset,
> (u16[]){ (u16)small_size }, sizeof(u16));
> buf_offset += sizeof(u16);
> - if (small_size == 0xFFFFU) {
> + if (small_size == LTT_MAX_SMALL_SIZE) {
> ltt_relay_write(buf, buf_offset,
> (u32[]){ (u32)event_size }, sizeof(u32));
> buf_offset += sizeof(u32);
> @@ -492,6 +495,67 @@ static inline size_t ltt_write_event_header(struct ltt_trace_struct *trace,
> return buf_offset;
> }
>
> +/*
> + * ltt_read_event_header
> + * buf_offset must aligned on 32 bits
> + */
> +static inline size_t ltt_read_event_header(struct rchan_buf *buf,
> + long buf_offset, u64 *tsc, u32 *event_size, u16 *eID,
> + unsigned int *rflags)
> +{
> + struct ltt_event_header header;
> + u16 small_size;
> +
> + ltt_relay_read(buf, buf_offset, &header, sizeof(header));
> + buf_offset += sizeof(header);
> +
> + *event_size = INT_MAX;
> + *eID = header.id_time >> LTT_TSC_BITS;
> + *tsc = header.id_time & LTT_TSC_MASK;
> +
> + switch (*eID) {
> + case 29:
> + *rflags = LTT_RFLAG_ID_SIZE_TSC;
> + ltt_relay_read(buf, buf_offset, eID, sizeof(u16));
> + buf_offset += sizeof(u16);
> + ltt_relay_read(buf, buf_offset, &small_size, sizeof(u16));
> + buf_offset += sizeof(u16);
> + if (small_size == LTT_MAX_SMALL_SIZE) {
> + ltt_relay_read(buf, buf_offset, event_size,
> + sizeof(u32));
> + buf_offset += sizeof(u32);
> + } else
> + *event_size = small_size;
> + buf_offset += ltt_align(buf_offset, sizeof(u64));
> + ltt_relay_read(buf, buf_offset, tsc, sizeof(u64));
> + buf_offset += sizeof(u64);
> + break;
> + case 30:
> + *rflags = LTT_RFLAG_ID_SIZE;
> + ltt_relay_read(buf, buf_offset, eID, sizeof(u16));
> + buf_offset += sizeof(u16);
> + ltt_relay_read(buf, buf_offset, &small_size, sizeof(u16));
> + buf_offset += sizeof(u16);
> + if (small_size == LTT_MAX_SMALL_SIZE) {
> + ltt_relay_read(buf, buf_offset, event_size,
> + sizeof(u32));
> + buf_offset += sizeof(u32);
> + } else
> + *event_size = small_size;
> + break;
> + case 31:
> + *rflags = LTT_RFLAG_ID;
> + ltt_relay_read(buf, buf_offset, eID, sizeof(u16));
> + buf_offset += sizeof(u16);
> + break;
> + default:
> + *rflags = 0;
> + break;
> + }
> +
> + return buf_offset;
> +}
> +
> /* Lockless LTTng */
>
> /* Buffer offset macros */
>
>
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
>
--
Mathieu Desnoyers
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68
More information about the lttng-dev
mailing list