X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9f15820876bd61e9b3d7bb9c4e0b9b5e77553be6..0ff37f6b97d13786335a6e1397cba376f39afd2d:/include/xbt/synchro.h diff --git a/include/xbt/synchro.h b/include/xbt/synchro.h index 2855f544b6..d77af7e043 100644 --- a/include/xbt/synchro.h +++ b/include/xbt/synchro.h @@ -32,11 +32,16 @@ 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_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);