X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/76583d80b116f084836e915c1905fb3022699168..f4e0c87b35c22659b29ee4ea0452796a9282965e:/include/msg/datatypes.h diff --git a/include/msg/datatypes.h b/include/msg/datatypes.h index 020605076b..4741045893 100644 --- a/include/msg/datatypes.h +++ b/include/msg/datatypes.h @@ -7,6 +7,7 @@ #ifndef MSG_DATATYPE_H #define MSG_DATATYPE_H #include "xbt/misc.h" +#include "xbt/file_stat.h" #include "simgrid_config.h" // for HAVE_TRACING SG_BEGIN_DECL() @@ -40,18 +41,6 @@ typedef struct m_host { typedef struct m_host *m_host_t; /** @} */ - -/* ******************************** File ************************************ */ -/** @brief File datatype - @ingroup m_datatypes_management_details */ -typedef struct m_file { - char *name; /**< @brief file name */ - void *data; /**< @brief user data */ -} s_m_file_t; - -typedef struct m_file *m_file_t; - - /* ******************************** Task ************************************ */ typedef struct simdata_task *simdata_task_t; @@ -78,6 +67,49 @@ typedef struct m_task { @{ */ typedef struct m_task *m_task_t; +/* ******************************** File ************************************ */ + +typedef struct simdata_file *simdata_file_t; + +/** @brief File datatype + @ingroup m_datatypes_management_details */ +typedef struct msg_file { + char *name; /**< @brief file name */ + simdata_file_t simdata; /**< @brief simulator data */ + void *data; /**< @brief user data */ +} s_msg_file_t; +/** @brief File datatype + @ingroup m_datatypes_management_details */ + +typedef struct msg_file *msg_file_t; + +typedef s_file_stat_t s_msg_stat_t, *msg_stat_t; + + +/*************** Begin GPU ***************/ +typedef struct simdata_gpu_task *simdata_gpu_task_t; + +/** @brief GPU task datatype + @ingroup m_datatypes_management_details */ +typedef struct m_gpu_task { + char *name; /**< @brief task name if any */ + simdata_gpu_task_t simdata; /**< @brief simulator data */ +#ifdef HAVE_TRACING + long long int counter; /* task unique identifier for instrumentation */ + char *category; /* task category for instrumentation */ +#endif +} s_m_gpu_task_t; + +/** @brief GPU task datatype + @ingroup m_datatypes_management + + A task may then be defined by a computing + amount, a dispatch latency and a collect latency. + \see m_task_management + @{ */ +typedef struct m_gpu_task *m_gpu_task_t; +/*************** End GPU ***************/ + /** * \brief @brief Communication action * \ingroup m_datatypes_management @@ -106,9 +138,10 @@ typedef struct msg_comm *msg_comm_t; typedef struct s_smx_process *m_process_t; /** @} */ +#ifdef MSG_USE_DEPRECATED /* ********************************* Channel ******************************** */ /** @brief Channel datatype - @ingroup m_datatypes_management + @ingroup msg_deprecated_functions A channel is a number and identifies a mailbox type (just as a port number does). @@ -116,6 +149,7 @@ typedef struct s_smx_process *m_process_t; @{ */ typedef int m_channel_t; /** @} */ +#endif /* ******************************** Mailbox ************************************ */ @@ -143,7 +177,7 @@ typedef enum { MSG_HOST_FAILURE = 4, /**< @brief System shutdown. The host on which you are running has just been rebooted. Free your datastructures and return now !*/ - MSG_TASK_CANCELED = 8, /**< @brief Canceled task. This task has been canceled by somebody!*/ + MSG_TASK_CANCELED = 8 /**< @brief Canceled task. This task has been canceled by somebody!*/ } MSG_error_t; /** @} */