X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/77bbf3027c4240a2e833209a3a3f186589da8577..f67e9f5d0e553ae935bd6cad29df46f1565173bf:/include/xbt/xbt_os_thread.h diff --git a/include/xbt/xbt_os_thread.h b/include/xbt/xbt_os_thread.h index 23b8fc8339..95a3377adb 100644 --- a/include/xbt/xbt_os_thread.h +++ b/include/xbt/xbt_os_thread.h @@ -1,6 +1,6 @@ /* xbt/xbt_os_thread.h -- Thread portability layer */ -/* Copyright (c) 2007-2017. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2007-2019. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -8,12 +8,12 @@ #ifndef XBT_OS_THREAD_H #define XBT_OS_THREAD_H -#include "xbt/base.h" - -SG_BEGIN_DECL() +#include +#include #include -typedef pthread_key_t xbt_os_thread_key_t; + +SG_BEGIN_DECL() /** @addtogroup XBT_thread * @brief Thread portability layer @@ -24,50 +24,14 @@ typedef pthread_key_t xbt_os_thread_key_t; * @{ */ -XBT_PUBLIC(int) xbt_os_get_numcores(void); +XBT_PUBLIC int xbt_os_thread_atfork(void (*prepare)(void), void (*parent)(void), void (*child)(void)); - /** \brief Thread data type (opaque structure) */ -typedef struct xbt_os_thread_ *xbt_os_thread_t; -XBT_PUBLIC(xbt_os_thread_t) xbt_os_thread_create(const char *name, pvoid_f_pvoid_t start_routine, void *param, void *data); -XBT_PUBLIC(void) xbt_os_thread_exit(int *retcode); - -XBT_PUBLIC(xbt_os_thread_t) xbt_os_thread_self(void); -XBT_PUBLIC(const char *) xbt_os_thread_self_name(void); -XBT_PUBLIC(void) xbt_os_thread_set_extra_data(void *data); -XBT_PUBLIC(void *) xbt_os_thread_get_extra_data(void); -XBT_PUBLIC(void) xbt_os_thread_key_create(xbt_os_thread_key_t* key); -XBT_PUBLIC(void) xbt_os_thread_key_destroy(xbt_os_thread_key_t key); -XBT_PUBLIC(void) xbt_os_thread_set_specific(xbt_os_thread_key_t key, void* value); -XBT_PUBLIC(void*) xbt_os_thread_get_specific(xbt_os_thread_key_t key); - /* xbt_os_thread_join frees the joined thread (ie the XBT wrapper around it, the OS frees the rest) */ -XBT_PUBLIC(void) xbt_os_thread_join(xbt_os_thread_t thread, void **thread_return); -XBT_PUBLIC(void) xbt_os_thread_yield(void); -XBT_PUBLIC(void) xbt_os_thread_setstacksize(int stack_size); -XBT_PUBLIC(void) xbt_os_thread_setguardsize(int guard_size); -XBT_PUBLIC(int) xbt_os_thread_bind(xbt_os_thread_t thread, int core); -XBT_PUBLIC(int) xbt_os_thread_atfork(void (*prepare)(void), void (*parent)(void), void (*child)(void)); - - /** \brief Thread mutex data type (opaque structure) */ +/** @brief Thread mutex data type (opaque structure) */ typedef struct xbt_os_mutex_ *xbt_os_mutex_t; -XBT_PUBLIC(xbt_os_mutex_t) xbt_os_mutex_init(void); -XBT_PUBLIC(void) xbt_os_mutex_acquire(xbt_os_mutex_t mutex); -XBT_PUBLIC(void) xbt_os_mutex_release(xbt_os_mutex_t mutex); -XBT_PUBLIC(void) xbt_os_mutex_destroy(xbt_os_mutex_t mutex); - -/** \brief Thread condition data type (opaque structure) */ -typedef struct xbt_os_cond_ *xbt_os_cond_t; -XBT_PUBLIC(xbt_os_cond_t) xbt_os_cond_init(void); -XBT_PUBLIC(void) xbt_os_cond_wait(xbt_os_cond_t cond, xbt_os_mutex_t mutex); -XBT_PUBLIC(void) xbt_os_cond_signal(xbt_os_cond_t cond); -XBT_PUBLIC(void) xbt_os_cond_broadcast(xbt_os_cond_t cond); -XBT_PUBLIC(void) xbt_os_cond_destroy(xbt_os_cond_t cond); - -/** \brief Semaphore data type (opaque structure) */ -typedef struct xbt_os_sem_ *xbt_os_sem_t; -XBT_PUBLIC(xbt_os_sem_t) xbt_os_sem_init(unsigned int value); -XBT_PUBLIC(void) xbt_os_sem_acquire(xbt_os_sem_t sem); -XBT_PUBLIC(void) xbt_os_sem_release(xbt_os_sem_t sem); -XBT_PUBLIC(void) xbt_os_sem_destroy(xbt_os_sem_t sem); +XBT_PUBLIC xbt_os_mutex_t xbt_os_mutex_init(void); +XBT_PUBLIC void xbt_os_mutex_acquire(xbt_os_mutex_t mutex); +XBT_PUBLIC void xbt_os_mutex_release(xbt_os_mutex_t mutex); +XBT_PUBLIC void xbt_os_mutex_destroy(xbt_os_mutex_t mutex); /** @} */