[ltt-dev] [PATCH 05/13] read basic type from ltt-relay buffer

Lai Jiangshan laijs at cn.fujitsu.com
Sun Jan 18 21:27:19 EST 2009


Mathieu Desnoyers wrote:
> * Lai Jiangshan (laijs at cn.fujitsu.com) wrote:
>> Mathieu Desnoyers wrote:
>>> * Lai Jiangshan (laijs at cn.fujitsu.com) wrote:
>>>> we need function read the base type from ltt-relay buffer
>>>> in the kernel for text output
>>>>
>>>> Signed-off-by: Lai Jiangshan <laijs at cn.fujitsu.com>
>>>> ---
>>>>  ltt-serialize.c |   71 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>>>  1 file changed, 71 insertions(+)
>>>> diff --git a/ltt/ltt-serialize.c b/ltt/ltt-serialize.c
>>>> index 5c34899..deb9106 100644
>>>> --- a/ltt/ltt-serialize.c
>>>> +++ b/ltt/ltt-serialize.c
>>>> @@ -531,6 +538,77 @@
>>>>  }
>>>>  EXPORT_SYMBOL_GPL(ltt_serialize_data);
>>>>  
>>>> +static inline u64 serialize_read_base_type(struct rchan_buf *buf, size_t *ppos,
>>> Maybe the name "unserialize" would be more appropriate ?
>>>
>>>> +		char trace_size, enum ltt_type trace_type)
>>>> +{
>>>> +	union {
>>>> +		uint8_t  u_8;
>>>> +		uint16_t u_16;
>>>> +		uint32_t u_32;
>>>> +		uint64_t u_64;
>>>> +		int8_t   s_8;
>>>> +		int16_t  s_16;
>>>> +		int32_t  s_32;
>>>> +		int64_t  s_64;
>>>> +	} tmp;
>>>> +	uint64_t value;
>>>> +
>>>> +	if (ltt_get_alignment())
>>> This if () is unneeded. It's already in the ltt_align logic.
>>>
>>>> +		*ppos += ltt_align(*ppos, trace_size);
>>>> +
>>>> +	switch (trace_type) {
>>>> +	case LTT_TYPE_SIGNED_INT:
>>>> +		switch (trace_size) {
>>>> +		case 1:
>>>> +			ltt_relay_read(buf, *ppos, &tmp.s_8, trace_size);
>>>> +			value = tmp.s_8;
>>> I think we could separate that in two parts to make the code smaller :
>> separate it into 2 functions?
>>
> 
> Not necessarily 2 functions. Just separating it in two switch () statements
> would do the job.
> 

I don't understand what you mean.
My code is the smallest, if we don't use macro.

> Mathieu
> 
>>> 1 - 
>>> ltt_relay_read for u8, u16, u32, u64 (not caring about singedness)
>>>
>>> 2 - depending on the sign, cast to (s8, s16, s32) and then cast to a
>>> 64-bit signed value. Or if it was already 64-bits, no conversion is
>>> needed.
>>>
>>> The end result (64-bit signed or unsigned value) should in the end be
>>> casted to a u64.
>>>
>>> Mathieu
>>>
>>>
>>
>> _______________________________________________
>> 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