Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
please close the structure behind you
[simgrid.git] / src / gras / DataDesc / datadesc_private.h
index 2d2bc70..37075aa 100644 (file)
 #define aligned(v, a) (((v) + (a - 1)) & ~(a - 1))
 
 extern gras_set_t *gras_datadesc_set_local;
-
+void gras_ddt_freev(void *ddt);
 /*******************************************
  * Descriptions of all known architectures *
  *******************************************/
 
-#define gras_arch_count 3
+#define gras_arch_count 4
 typedef enum {
   gras_ddt_scalar_char      = 0,
   gras_ddt_scalar_short     = 1,
@@ -52,6 +52,8 @@ typedef struct {
   int sizeof_scalars[9]; /* char,short,int,long,long_long,
                            pdata,pfunc,
                            float,double */
+
+  int struct_boundary;
 } gras_arch_desc_t;
 
 extern const gras_arch_desc_t gras_arches[gras_arch_count];
@@ -92,9 +94,9 @@ typedef enum e_gras_datadesc_type_category {
  */
 typedef struct s_gras_dd_cat_field {
 
-  char                               *name;
-  long int                    offset[gras_arch_count]; /* only for struct */
-  int                          code;
+  char            *name;
+  long int  offset[gras_arch_count];
+  int       code;
   
   gras_datadesc_type_cb_void_t pre;
   gras_datadesc_type_cb_void_t post;
@@ -128,6 +130,7 @@ typedef struct s_gras_dd_cat_scalar {
  */
 typedef struct s_gras_dd_cat_struct {
   gras_dynar_t *fields; /* elm type = gras_dd_cat_field_t */
+  int closed; /* gras_datadesc_declare_struct_close() was called */
 } gras_dd_cat_struct_t;
 
 /**
@@ -138,6 +141,7 @@ typedef struct s_gras_dd_cat_struct {
 typedef struct s_gras_dd_cat_union {
   gras_datadesc_type_cb_int_t selector;
   gras_dynar_t *fields; /* elm type = gras_dd_cat_field_t */
+  int closed; /* gras_datadesc_declare_union_close() was called */
 } gras_dd_cat_union_t;
 
 /**
@@ -166,6 +170,7 @@ typedef struct s_gras_dd_cat_array {
 
   /* callback used to return the dynamic length */
   gras_datadesc_type_cb_int_t dynamic_size;
+
 } gras_dd_cat_array_t;
 
 /**
@@ -214,7 +219,7 @@ struct s_gras_datadesc_type {
   /* payload */
   long int                             size[gras_arch_count];
   
-  long int                             alignment[gras_arch_count];
+  long int                             alignment[gras_arch_count];  
   long int                             aligned_size[gras_arch_count];
   
   enum  e_gras_datadesc_type_category  category_code;
@@ -246,7 +251,7 @@ 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);