X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/3b026a6cdd673b16c8c23c5c1319b12b2585adf8..6399b037de5d22e37584d156b87f293dbfa16df7:/src/include/mc/datatypes.h diff --git a/src/include/mc/datatypes.h b/src/include/mc/datatypes.h index 6fe65fd27a..baeb22d8cc 100644 --- a/src/include/mc/datatypes.h +++ b/src/include/mc/datatypes.h @@ -6,10 +6,16 @@ #ifndef MC_DATATYPE_H #define MC_DATATYPE_H + +#define UNW_LOCAL_ONLY + #include "xbt/misc.h" #include "xbt/swag.h" #include "xbt/fifo.h" +#include +#include + SG_BEGIN_DECL() /******************************* Transitions **********************************/ @@ -37,23 +43,17 @@ typedef struct s_stack_region{ void heap_ignore_region_free(mc_heap_ignore_region_t r); void heap_ignore_region_free_voidp(void *r); +/************ Object info *************/ + +typedef struct s_mc_object_info s_mc_object_info_t, *mc_object_info_t; + /************ DWARF structures *************/ -typedef enum{ - e_dw_base_type = 0, - e_dw_enumeration_type, - e_dw_enumerator, - e_dw_typedef, - e_dw_const_type, - e_dw_array_type, - e_dw_pointer_type, - e_dw_structure_type, - e_dw_union_type, - e_dw_subroutine_type, - e_dw_volatile_type -}e_dw_type_type; - -typedef struct s_dw_type{ +typedef int e_dw_type_type; + +typedef struct s_dw_type s_dw_type_t, *dw_type_t; + +struct s_dw_type{ e_dw_type_type type; void *id; /* Offset in the section (in hexadecimal form) */ char *name; /* Name of the type */ @@ -63,9 +63,11 @@ typedef struct s_dw_type{ xbt_dynar_t members; /* if DW_TAG_structure_type, DW_TAG_union_type*/ int is_pointer_type; int offset; -}s_dw_type_t, *dw_type_t; + dw_type_t subtype; + dw_type_t other_object_same_type; // The same (but more complete) type in the other object. +}; -char* get_type_description(xbt_dict_t types, char *type_name); +char* get_type_description(mc_object_info_t info, char *type_name); SG_END_DECL() #endif /* _MC_MC_H */