[ltt-dev] [BABELTRACE PATCH] Extract int and char arrays from fields

Mathieu Desnoyers mathieu.desnoyers at efficios.com
Mon Sep 26 21:04:35 EDT 2011


* Julien Desfossez (julien.desfossez at polymtl.ca) wrote:
> Three helper functions to ease the extraction of basic types from event
> fields. For now we support signed and unsigned integers and strings.
> Other functions could be added following the same principle for other
> types.

FYI, I already started cleaning up ctf.c using these functions.

Thanks!

Mathieu

> 
> Signed-off-by: Julien Desfossez <julien.desfossez at polymtl.ca>
> ---
>  include/babeltrace/types.h |    3 +++
>  types/array.c              |   27 +++++++++++++++++++++++++++
>  types/integer.c            |   30 ++++++++++++++++++++++++++++++
>  3 files changed, 60 insertions(+), 0 deletions(-)
> 
> diff --git a/include/babeltrace/types.h b/include/babeltrace/types.h
> index a9fb5fe..62a0d4f 100644
> --- a/include/babeltrace/types.h
> +++ b/include/babeltrace/types.h
> @@ -383,6 +383,8 @@ void definition_unref(struct definition *definition);
>  struct declaration_integer *integer_declaration_new(size_t len, int byte_order,
>  				  int signedness, size_t alignment,
>  				  int base, enum ctf_string_encoding encoding);
> +uint64_t get_unsigned_int(struct definition *field);
> +int64_t get_signed_int(struct definition *field);
>  
>  /*
>   * mantissa_len is the length of the number of bytes represented by the mantissa
> @@ -493,6 +495,7 @@ struct declaration_array *
>  uint64_t array_len(struct definition_array *array);
>  struct definition *array_index(struct definition_array *array, uint64_t i);
>  int array_rw(struct stream_pos *pos, struct definition *definition);
> +GString *get_char_array(struct definition *field);
>  
>  /*
>   * int_declaration and elem_declaration passed as parameter now belong
> diff --git a/types/array.c b/types/array.c
> index db6853f..87b2083 100644
> --- a/types/array.c
> +++ b/types/array.c
> @@ -205,3 +205,30 @@ struct definition *array_index(struct definition_array *array, uint64_t i)
>  		return NULL;
>  	return g_ptr_array_index(array->elems, i);
>  }
> +
> +GString *get_char_array(struct definition *field)
> +{
> +	struct definition_array *array_definition;
> +	struct declaration_array *array_declaration;
> +	struct declaration *elem;
> +
> +	array_definition = container_of(field, struct definition_array, p);
> +	array_declaration = array_definition->declaration;
> +	elem = array_declaration->elem;
> +	if (elem->id == CTF_TYPE_INTEGER) {
> +		struct declaration_integer *integer_declaration =
> +			container_of(elem, struct declaration_integer, p);
> +
> +		if (integer_declaration->encoding == CTF_STRING_UTF8
> +				|| integer_declaration->encoding == CTF_STRING_ASCII) {
> +
> +			if (integer_declaration->len == CHAR_BIT
> +					&& integer_declaration->p.alignment == CHAR_BIT) {
> +
> +				return array_definition->string;
> +			}
> +		}
> +	}
> +	fprintf(stderr, "[warning] Extracting string\n");
> +	return NULL;
> +}
> diff --git a/types/integer.c b/types/integer.c
> index e55c03e..9e6df58 100644
> --- a/types/integer.c
> +++ b/types/integer.c
> @@ -103,3 +103,33 @@ void _integer_definition_free(struct definition *definition)
>  	declaration_unref(integer->p.declaration);
>  	g_free(integer);
>  }
> +
> +uint64_t get_unsigned_int(struct definition *field)
> +{
> +	struct definition_integer *integer_definition;
> +	const struct declaration_integer *integer_declaration;
> +
> +	integer_definition = container_of(field, struct definition_integer, p);
> +	integer_declaration = integer_definition->declaration;
> +
> +	if (!integer_declaration->signedness) {
> +		return integer_definition->value._unsigned;
> +	}
> +	fprintf(stderr, "[warning] Extracting unsigned value in a signed int\n");
> +	return (uint64_t)integer_definition->value._signed;
> +}
> +
> +int64_t get_signed_int(struct definition *field)
> +{
> +	struct definition_integer *integer_definition;
> +	const struct declaration_integer *integer_declaration;
> +
> +	integer_definition = container_of(field, struct definition_integer, p);
> +	integer_declaration = integer_definition->declaration;
> +
> +	if (integer_declaration->signedness) {
> +		return integer_definition->value._signed;
> +	}
> +	fprintf(stderr, "[warning] Extracting signed value in an unsigned int\n");
> +	return (int64_t)integer_definition->value._unsigned;
> +}
> -- 
> 1.7.5.4
> 

-- 
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com




More information about the lttng-dev mailing list