X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/50078f18c7f2fcbe42db89adb2005e9f7d38c301..6ebcf09b6c37399ca597870339c1c5e60b1f774b:/src/simix/smx_private.h diff --git a/src/simix/smx_private.h b/src/simix/smx_private.h index 9c25e4838e..824239f438 100644 --- a/src/simix/smx_private.h +++ b/src/simix/smx_private.h @@ -46,6 +46,26 @@ typedef struct s_smx_global { extern smx_global_t simix_global; extern unsigned long simix_process_maxpid; +/******************************** Exceptions *********************************/ + +#define SMX_EXCEPTION(issuer, c, v, m) \ + if (1) { \ + smx_process_t _smx_throw_issuer = (issuer); \ + THROW_PREPARE(_smx_throw_issuer->running_ctx, (c), (v), xbt_strdup(m)); \ + _smx_throw_issuer->doexception = 1; \ + } else ((void)0) + +#define SMX_THROW() RETHROW + +/* ******************************** File ************************************ */ +typedef struct s_smx_file { + surf_file_t surf_file; +} s_smx_file_t; + +typedef struct s_smx_stat { + s_file_stat_t surf_stat; +} s_smx_stat_t; + /*********************************** Time ************************************/ /** @brief Timer datatype */ @@ -73,6 +93,13 @@ typedef enum { SIMIX_COMM_DONE } e_smx_comm_type_t; +typedef enum { + SIMIX_IO_OPEN, + SIMIX_IO_WRITE, + SIMIX_IO_READ, + SIMIX_IO_STAT +} e_smx_io_type_t; + /** @brief Action datatype */ typedef struct s_smx_action { @@ -242,7 +269,7 @@ static XBT_INLINE void SIMIX_context_suspend(smx_context_t context) /** \brief Executes all the processes to run (in parallel if possible). */ -static XBT_INLINE void SIMIX_context_runall() +static XBT_INLINE void SIMIX_context_runall(void) { simix_global->context_factory->runall(); }