X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9f15820876bd61e9b3d7bb9c4e0b9b5e77553be6..1abb173bf353d2796fef41a227c3b3adcb6586d2:/include/xbt/synchro.h diff --git a/include/xbt/synchro.h b/include/xbt/synchro.h index 2855f544b6..333df9562f 100644 --- a/include/xbt/synchro.h +++ b/include/xbt/synchro.h @@ -32,11 +32,18 @@ SG_BEGIN_DECL() /** \brief Thread data type (opaque structure) */ typedef struct s_xbt_thread_ *xbt_thread_t; - XBT_PUBLIC(xbt_thread_t) xbt_thread_create(pvoid_f_pvoid_t start_routine,void* param); - XBT_PUBLIC(void) xbt_thread_exit(int *retcode); + XBT_PUBLIC(xbt_thread_t) xbt_thread_create(const char *name, void_f_pvoid_t start_routine,void* param); + XBT_PUBLIC(void) xbt_thread_exit(); XBT_PUBLIC(xbt_thread_t) xbt_thread_self(void); + XBT_PUBLIC(const char*) xbt_thread_name(xbt_thread_t t); + XBT_PUBLIC(const char*) xbt_thread_self_name(void); /* xbt_thread_join frees the joined thread (ie the XBT wrapper around it, the OS frees the rest) */ - XBT_PUBLIC(void) xbt_thread_join(xbt_thread_t thread,void ** thread_return); + XBT_PUBLIC(void) xbt_thread_join(xbt_thread_t thread); + /* Ends the life of the poor victim (not always working if it's computing, but working if it's blocked in the OS) */ + XBT_PUBLIC(void) xbt_thread_cancel(xbt_thread_t thread); + /* suicide */ + XBT_PUBLIC(void) xbt_thread_exit(void); + /* current thread pass control to any possible thread wanting it */ XBT_PUBLIC(void) xbt_thread_yield(void);