A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Added round trip time contraint to the SDP program, this parameter
[simgrid.git]
/
src
/
gras
/
DataDesc
/
datadesc_private.h
diff --git
a/src/gras/DataDesc/datadesc_private.h
b/src/gras/DataDesc/datadesc_private.h
index
d80b2aa
..
0e79380
100644
(file)
--- a/
src/gras/DataDesc/datadesc_private.h
+++ b/
src/gras/DataDesc/datadesc_private.h
@@
-4,32
+4,45
@@
/* module's private interface masked even to other parts of GRAS. */
/* module's private interface masked even to other parts of GRAS. */
-/* Authors: Olivier Aumage, Martin Quinson */
-/* Copyright (C) 2003, 2004 the GRAS posse. */
+/* Copyright (c) 2003 Olivier Aumage. */
+/* Copyright (c) 2003, 2004 Martin Quinson. */
+/* All rights reserved. */
/* This program is free software; you can redistribute it and/or modify it
/* This program is free software; you can redistribute it and/or modify it
-
under the terms of the license (GNU LGPL) which comes with this package. */
+
*
under the terms of the license (GNU LGPL) which comes with this package. */
#ifndef GRAS_DATADESC_PRIVATE_H
#define GRAS_DATADESC_PRIVATE_H
#ifndef GRAS_DATADESC_PRIVATE_H
#define GRAS_DATADESC_PRIVATE_H
-#include "gras_private.h"
-#include "DataDesc/datadesc_interface.h"
+#include "xbt/sysdep.h"
+#include "xbt/log.h"
+#include "xbt/dynar.h"
+#include "xbt/dict.h"
+#include "xbt/set.h"
+
+#include "portable.h" /* GRAS_THISARCH */
+
+#include "gras/transport.h" /* socket handling */
+
+#include "gras_modinter.h" /* module init/exit */
+#include "gras/datadesc.h" /* rest of module public interface */
+
+#include "gras/DataDesc/datadesc_interface.h" /* semi-public API */
/**
/**
- * aligned:
+ *
ddt_
aligned:
*
* Align the data v on the boundary a.
*/
*
* Align the data v on the boundary a.
*/
-#define aligned(v, a) (((v) + (a - 1)) & ~(a - 1))
+#define
ddt_
aligned(v, a) (((v) + (a - 1)) & ~(a - 1))
-
extern gras_set_t *
gras_datadesc_set_local;
+
/*@null@*/extern xbt_set_t
gras_datadesc_set_local;
void gras_ddt_freev(void *ddt);
/*******************************************
* Descriptions of all known architectures *
*******************************************/
void gras_ddt_freev(void *ddt);
/*******************************************
* Descriptions of all known architectures *
*******************************************/
-#define gras_arch_count
4
+#define gras_arch_count
11
typedef enum {
gras_ddt_scalar_char = 0,
gras_ddt_scalar_short = 1,
typedef enum {
gras_ddt_scalar_char = 0,
gras_ddt_scalar_short = 1,
@@
-49,11
+62,8
@@
typedef struct {
int endian;
int endian;
- int sizeof_scalars[9]; /* char,short,int,long,long_long,
- pdata,pfunc,
- float,double */
-
- int struct_boundary;
+ int sizeofs[9]; /* char,short,int,long,long_long,pdata,pfunc,float,double */
+ int boundaries[9]; /* idem */
} gras_arch_desc_t;
extern const gras_arch_desc_t gras_arches[gras_arch_count];
} gras_arch_desc_t;
extern const gras_arch_desc_t gras_arches[gras_arch_count];
@@
-79,9
+89,8
@@
typedef enum e_gras_datadesc_type_category {
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_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
+ e_gras_datadesc_type_cat_invalid =
6
} gras_datadesc_type_category_t;
/*------------------------------------------------*/
} gras_datadesc_type_category_t;
/*------------------------------------------------*/
@@
-96,12
+105,12
@@
typedef struct s_gras_dd_cat_field {
char *name;
long int offset[gras_arch_count];
char *name;
long int offset[gras_arch_count];
-
int cod
e;
+
gras_datadesc_type_t typ
e;
- gras_datadesc_type_cb_void_t
pre
;
- gras_datadesc_type_cb_void_t
post
;
+ gras_datadesc_type_cb_void_t
send
;
+ gras_datadesc_type_cb_void_t
recv
;
-} gras_dd_cat_field_t;
+}
s_gras_dd_cat_field_t,*
gras_dd_cat_field_t;
void gras_dd_cat_field_free(void *f);
void gras_dd_cat_field_free(void *f);
@@
-121,6
+130,7
@@
enum e_gras_dd_scalar_encoding {
};
typedef struct s_gras_dd_cat_scalar {
enum e_gras_dd_scalar_encoding encoding;
};
typedef struct s_gras_dd_cat_scalar {
enum e_gras_dd_scalar_encoding encoding;
+ gras_ddt_scalar_type_t type; /* to check easily that redefinition matches */
} gras_dd_cat_scalar_t;
/**
} gras_dd_cat_scalar_t;
/**
@@
-129,7
+139,7
@@
typedef struct s_gras_dd_cat_scalar {
* Specific fields of a struct
*/
typedef struct s_gras_dd_cat_struct {
* Specific fields of a struct
*/
typedef struct s_gras_dd_cat_struct {
-
gras_dynar_t *
fields; /* elm type = gras_dd_cat_field_t */
+
xbt_dynar_t
fields; /* elm type = gras_dd_cat_field_t */
int closed; /* gras_datadesc_declare_struct_close() was called */
} gras_dd_cat_struct_t;
int closed; /* gras_datadesc_declare_struct_close() was called */
} gras_dd_cat_struct_t;
@@
-140,7
+150,7
@@
typedef struct s_gras_dd_cat_struct {
*/
typedef struct s_gras_dd_cat_union {
gras_datadesc_type_cb_int_t selector;
*/
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 */
+
xbt_dynar_t
fields; /* elm type = gras_dd_cat_field_t */
int closed; /* gras_datadesc_declare_union_close() was called */
} gras_dd_cat_union_t;
int closed; /* gras_datadesc_declare_union_close() was called */
} gras_dd_cat_union_t;
@@
-150,10
+160,10
@@
typedef struct s_gras_dd_cat_union {
* Specific fields of a reference
*/
typedef struct s_gras_dd_cat_ref {
* Specific fields of a reference
*/
typedef struct s_gras_dd_cat_ref {
-
int cod
e;
+
gras_datadesc_type_t typ
e;
/* callback used to return the referenced type number */
/* callback used to return the referenced type number */
- gras_datadesc_
type_cb_int_t
selector;
+ gras_datadesc_
selector_t
selector;
} gras_dd_cat_ref_t;
} gras_dd_cat_ref_t;
@@
-163,27
+173,16
@@
typedef struct s_gras_dd_cat_ref {
* Specific fields of an array
*/
typedef struct s_gras_dd_cat_array {
* Specific fields of an array
*/
typedef struct s_gras_dd_cat_array {
-
int cod
e;
+
gras_datadesc_type_t typ
e;
- /* element_count
<
0 means dynamically defined */
-
long int
fixed_size;
+ /* element_count
==
0 means dynamically defined */
+
unsigned long int
fixed_size;
/* callback used to return the dynamic length */
gras_datadesc_type_cb_int_t dynamic_size;
} gras_dd_cat_array_t;
/* callback used to return the dynamic length */
gras_datadesc_type_cb_int_t dynamic_size;
} gras_dd_cat_array_t;
-/**
- * gras_dd_cat_ignored_t:
- *
- * Specific fields of an ignored field
- */
-typedef struct s_gras_dd_cat_ignored {
- void *default_value;
- void_f_pvoid_t *free_func;
-} gras_dd_cat_ignored_t;
-
-
/**
* u_gras_datadesc_category:
*
/**
* u_gras_datadesc_category:
*
@@
-196,10
+195,8
@@
union u_gras_datadesc_category {
gras_dd_cat_union_t union_data;
gras_dd_cat_ref_t ref_data;
gras_dd_cat_array_t array_data;
gras_dd_cat_union_t union_data;
gras_dd_cat_ref_t ref_data;
gras_dd_cat_array_t array_data;
- gras_dd_cat_ignored_t ignored_data;
};
};
-
/****************************************/
/* The holy grail: type descriptor type */
/****************************************/
/****************************************/
/* The holy grail: type descriptor type */
/****************************************/
@@
-208,51
+205,61
@@
union u_gras_datadesc_category {
*
* Type descriptor.
*/
*
* Type descriptor.
*/
-struct s_gras_datadesc_type {
+
typedef
struct s_gras_datadesc_type {
/* headers for the data set */
unsigned int code;
char *name;
unsigned int name_len;
/* headers for the data set */
unsigned int code;
char *name;
unsigned int name_len;
- unsigned int refcounter;
-
/* payload */
/* payload */
-
long int
size[gras_arch_count];
+
unsigned long int
size[gras_arch_count];
-
long int
alignment[gras_arch_count];
-
long int
aligned_size[gras_arch_count];
+
unsigned long int
alignment[gras_arch_count];
+
unsigned long int
aligned_size[gras_arch_count];
enum e_gras_datadesc_type_category category_code;
union u_gras_datadesc_category category;
gras_datadesc_type_cb_void_t send;
gras_datadesc_type_cb_void_t recv;
enum e_gras_datadesc_type_category category_code;
union u_gras_datadesc_category category;
gras_datadesc_type_cb_void_t send;
gras_datadesc_type_cb_void_t recv;
-};
+
+ /* flags */
+ int cycle :1;
+
+ /* random value for users (like default value or whatever) */
+ char extra[SIZEOF_MAX];
+
+} s_gras_datadesc_type_t;
/***************************
/***************************
- *
Type creation functions
*
+ *
constructor/desctructor
*
***************************/
***************************/
-gras_error_t
-gras_datadesc_scalar(const char *name,
- gras_ddt_scalar_type_t type,
- enum e_gras_dd_scalar_encoding encoding,
- gras_datadesc_type_t **dst);
+void gras_datadesc_free(gras_datadesc_type_t *type);
+
+ gras_datadesc_type_t
+ gras_datadesc_scalar(const char *name,
+ gras_ddt_scalar_type_t type,
+ enum e_gras_dd_scalar_encoding encoding);
/****************************************************
* Callback persistant state constructor/destructor *
****************************************************/
/****************************************************
* Callback persistant state constructor/destructor *
****************************************************/
-gras_error_t
-gras_cbps_new(gras_cbps_t **dst);
-void
-gras_cbps_free(gras_cbps_t **state);
+gras_cbps_t gras_cbps_new(void);
+void gras_cbps_free(gras_cbps_t *state);
+void gras_cbps_reset(gras_cbps_t state);
/***************
* Convertions *
***************/
/***************
* Convertions *
***************/
-gras_error_t
-gras_dd_convert_elm(gras_datadesc_type_t
*
type, int count,
+void
+gras_dd_convert_elm(gras_datadesc_type_t type, int count,
int r_arch,
void *src, void *dst);
int r_arch,
void *src, void *dst);
+/********************************************************************
+ * Dictionnary containing the constant values for the parsing macro *
+ ********************************************************************/
+extern xbt_dict_t gras_dd_constants; /* lives in ddt_parse.c of course */
+
#endif /* GRAS_DATADESC_PRIVATE_H */
#endif /* GRAS_DATADESC_PRIVATE_H */