X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/1bbfe6dff09cff639aaab8fd2898678a5a630c2b..5c808cbd02cbb8305a87172367afe6e29fae033e:/src/gras/DataDesc/datadesc_private.h diff --git a/src/gras/DataDesc/datadesc_private.h b/src/gras/DataDesc/datadesc_private.h index 8eef386803..d975b74f93 100644 --- a/src/gras/DataDesc/datadesc_private.h +++ b/src/gras/DataDesc/datadesc_private.h @@ -29,7 +29,7 @@ extern gras_set_t *gras_datadesc_set_local; * Descriptions of all known architectures * *******************************************/ -#define gras_arch_count 1 +#define gras_arch_count 4 typedef enum { gras_ddt_scalar_char = 0, gras_ddt_scalar_short = 1, @@ -52,10 +52,10 @@ typedef struct { int sizeof_scalars[9]; /* char,short,int,long,long_long, pdata,pfunc, float,double */ -} gras_arch_sizes_t; - -extern const gras_arch_sizes_t gras_arch_sizes[gras_arch_count]; +} gras_arch_desc_t; +extern const gras_arch_desc_t gras_arches[gras_arch_count]; +extern const char *gras_datadesc_cat_names[9]; /**********************************************************/ /* Actual definitions of the stuff in the type descriptor */ @@ -64,22 +64,24 @@ extern const gras_arch_sizes_t gras_arch_sizes[gras_arch_count]; /** * e_gras_datadesc_type_category: * - * Defines all possible type categories + * Defines all possible type categories. */ typedef enum e_gras_datadesc_type_category { - e_gras_datadesc_type_cat_undefined = 0, - - e_gras_datadesc_type_cat_scalar = 1, - e_gras_datadesc_type_cat_struct = 2, - e_gras_datadesc_type_cat_union = 3, - e_gras_datadesc_type_cat_ref = 4, /* ref to an uniq element */ - e_gras_datadesc_type_cat_array = 5, - e_gras_datadesc_type_cat_ignored = 6, + + /* if you edit this, also fix gras_datadesc_cat_names in ddt_exchange.c */ - e_gras_datadesc_type_cat_invalid = 7 + e_gras_datadesc_type_cat_undefined = 0, + + e_gras_datadesc_type_cat_scalar = 1, + e_gras_datadesc_type_cat_struct = 2, + e_gras_datadesc_type_cat_union = 3, + e_gras_datadesc_type_cat_ref = 4, /* ref to an uniq element */ + e_gras_datadesc_type_cat_array = 5, + e_gras_datadesc_type_cat_ignored = 6, + + e_gras_datadesc_type_cat_invalid = 7 } gras_datadesc_type_category_t; - /*------------------------------------------------*/ /* definitions of specific data for each category */ /*------------------------------------------------*/ @@ -207,6 +209,8 @@ struct s_gras_datadesc_type { char *name; unsigned int name_len; + unsigned int refcounter; + /* payload */ long int size[gras_arch_count]; @@ -224,65 +228,11 @@ struct s_gras_datadesc_type { * Type creation functions * ***************************/ gras_error_t -gras_ddt_new_scalar(const char *name, - gras_ddt_scalar_type_t type, - enum e_gras_dd_scalar_encoding encoding, - gras_datadesc_type_cb_void_t cb, - gras_datadesc_type_t **dst); -gras_error_t -gras_ddt_new_struct(const char *name, - gras_datadesc_type_cb_void_t pre, - gras_datadesc_type_cb_void_t post, - gras_datadesc_type_t **dst); -gras_error_t -gras_ddt_new_struct_append(gras_datadesc_type_t *struct_type, - const char *name, - gras_datadesc_type_t *field_type, - gras_datadesc_type_cb_void_t pre, - gras_datadesc_type_cb_void_t post); -gras_error_t -gras_ddt_new_union(const char *name, - gras_datadesc_type_cb_int_t field_count, - gras_datadesc_type_cb_void_t post, - gras_datadesc_type_t **dst); -gras_error_t -gras_ddt_new_union_append(gras_datadesc_type_t *union_type, - const char *name, - gras_datadesc_type_t *field_type, - gras_datadesc_type_cb_void_t pre, - gras_datadesc_type_cb_void_t post); -gras_error_t -gras_ddt_new_ref(const char *name, - gras_datadesc_type_t *referenced_type, - gras_datadesc_type_cb_int_t discriminant, - gras_datadesc_type_cb_void_t post, - gras_datadesc_type_t **dst); -gras_error_t -gras_ddt_new_array(const char *name, - gras_datadesc_type_t *element_type, - long int fixed_size, - gras_datadesc_type_cb_int_t dynamic_size, - gras_datadesc_type_cb_void_t post, - gras_datadesc_type_t **dst); -gras_error_t -gras_ddt_new_ignored(const char *name, - void *default_value, - void_f_pvoid_t *free_func, - long int size, - long int alignment, - gras_datadesc_type_cb_void_t post, - gras_datadesc_type_t **dst); - - -gras_error_t -gras_ddt_new_parse(const char *name, - const char *C_definition, - gras_datadesc_type_t **dst); -gras_error_t -gras_ddt_new_from_nws(const char *name, - const DataDescriptor *desc, - size_t howmany, - gras_datadesc_type_t **dst); +gras_datadesc_declare_scalar(const char *name, + gras_ddt_scalar_type_t type, + enum e_gras_dd_scalar_encoding encoding, + gras_datadesc_type_cb_void_t cb, + gras_datadesc_type_t **dst); /**************************************************** * Callback persistant state constructor/destructor * @@ -296,8 +246,9 @@ gras_dd_cbps_free(gras_dd_cbps_t **state); * Convertions * ***************/ gras_error_t -gras_dd_convert_elm(gras_datadesc_type_t *type, +gras_dd_convert_elm(gras_datadesc_type_t *type, int count, int r_arch, void *src, void *dst); #endif /* GRAS_DATADESC_PRIVATE_H */ +