X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/ddb9b227cc31cdf0f74b65b9c0312fd416417c57..0eb04ef20fbaf4f46bdb4389c4ff24c32b23b040:/src/simix/smx_context_sysv_private.h diff --git a/src/simix/smx_context_sysv_private.h b/src/simix/smx_context_sysv_private.h index 2d2aea04ca..745df05038 100644 --- a/src/simix/smx_context_sysv_private.h +++ b/src/simix/smx_context_sysv_private.h @@ -10,7 +10,7 @@ #define _XBT_CONTEXT_SYSV_PRIVATE_H #include "xbt/swag.h" -#include "bindings/smx_context.h" +#include "simix/context.h" #include "portable.h" SG_BEGIN_DECL() @@ -29,12 +29,15 @@ SG_BEGIN_DECL() typedef struct s_smx_ctx_sysv { s_smx_ctx_base_t super; /* Fields of super implementation */ ucontext_t uc; /* the thread that execute the code */ + ucontext_t old_uc; /* the context that was swapped with */ #ifdef HAVE_VALGRIND_VALGRIND_H unsigned int valgrind_stack_id; /* the valgrind stack id */ #endif char stack[CONTEXT_STACK_SIZE]; /* the thread stack size */ } s_smx_ctx_sysv_t, *smx_ctx_sysv_t; +smx_ctx_sysv_t maestro_context; + void SIMIX_ctx_sysv_factory_init(smx_context_factory_t *factory); int smx_ctx_sysv_factory_finalize(smx_context_factory_t *factory); @@ -48,8 +51,10 @@ void smx_ctx_sysv_free(smx_context_t context); void smx_ctx_sysv_stop(smx_context_t context); void smx_ctx_sysv_suspend(smx_context_t context); void smx_ctx_sysv_resume(smx_context_t new_context); -void smx_ctx_sysv_runall(xbt_swag_t processes); -void smx_ctx_sysv_runall_parallel(xbt_swag_t processes); +void smx_ctx_sysv_runall(xbt_dynar_t processes); +void smx_ctx_sysv_resume_parallel(smx_process_t new_context); +void smx_ctx_sysv_runall_parallel(xbt_dynar_t processes); +smx_context_t smx_ctx_sysv_self_parallel(void); SG_END_DECL()