X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/5b3677b425b9cc6949c1573d59ac772540cbf4b2..5341c1e69bb03075ba5c9e5d250ed08788f8ba5b:/src/simix/smx_synchro_private.h diff --git a/src/simix/smx_synchro_private.h b/src/simix/smx_synchro_private.h index ad411fdf73..21e76b467c 100644 --- a/src/simix/smx_synchro_private.h +++ b/src/simix/smx_synchro_private.h @@ -7,14 +7,51 @@ #ifndef _SIMIX_SYNCHRO_PRIVATE_H #define _SIMIX_SYNCHRO_PRIVATE_H +#include + +#include "xbt/base.h" #include "xbt/swag.h" #include "xbt/xbt_os_thread.h" +#include "src/simix/popping_private.h" -typedef struct s_smx_mutex { - unsigned int locked; - smx_process_t owner; - xbt_swag_t sleeping; /* list of sleeping process */ -} s_smx_mutex_t; +namespace simgrid { +namespace simix { + +class XBT_PUBLIC() Mutex { +public: + Mutex(); + ~Mutex(); + Mutex(Mutex const&) = delete; + Mutex& operator=(Mutex const&) = delete; + + void lock(smx_process_t issuer); + bool try_lock(smx_process_t issuer); + void unlock(smx_process_t issuer); + + bool locked = false; + smx_process_t owner = nullptr; + // List of sleeping processes: + xbt_swag_t sleeping = nullptr; + + // boost::intrusive_ptr support: + friend void intrusive_ptr_add_ref(Mutex* mutex) + { + auto previous = (mutex->refcount_)++; + xbt_assert(previous != 0); + (void) previous; + } + friend void intrusive_ptr_release(Mutex* mutex) + { + auto count = --(mutex->refcount_); + if (count == 0) + delete mutex; + } +private: + std::atomic_int_fast32_t refcount_ { 1 }; +}; + +} +} typedef struct s_smx_cond { smx_mutex_t mutex; @@ -26,48 +63,18 @@ typedef struct s_smx_sem { xbt_swag_t sleeping; /* list of sleeping process */ } s_smx_sem_t; -void SIMIX_post_synchro(smx_action_t action); -void SIMIX_synchro_stop_waiting(smx_process_t process, smx_simcall_t simcall); -void SIMIX_synchro_destroy(smx_action_t action); - -smx_mutex_t SIMIX_mutex_init(void); -void SIMIX_mutex_destroy(smx_mutex_t mutex); -void SIMIX_pre_mutex_lock(smx_simcall_t simcall, smx_mutex_t mutex); -int SIMIX_mutex_trylock(smx_mutex_t mutex, smx_process_t issuer); -void SIMIX_mutex_unlock(smx_mutex_t mutex, smx_process_t issuer); - -smx_cond_t SIMIX_cond_init(void); -void SIMIX_cond_destroy(smx_cond_t cond); -void SIMIX_cond_signal(smx_cond_t cond); -void SIMIX_pre_cond_wait(smx_simcall_t simcall, smx_cond_t cond, smx_mutex_t mutex); -void SIMIX_pre_cond_wait_timeout(smx_simcall_t simcall, smx_cond_t cond, - smx_mutex_t mutex, double timeout); -void SIMIX_cond_broadcast(smx_cond_t cond); - -smx_sem_t SIMIX_sem_init(unsigned int value); -void SIMIX_sem_destroy(smx_sem_t sem); -void SIMIX_sem_release(smx_sem_t sem); -int SIMIX_sem_would_block(smx_sem_t sem); -void SIMIX_pre_sem_acquire(smx_simcall_t simcall, smx_sem_t sem); -void SIMIX_pre_sem_acquire_timeout(smx_simcall_t simcall, smx_sem_t sem, double timeout); -int SIMIX_sem_get_capacity(smx_sem_t sem); - -// pre prototypes -smx_mutex_t SIMIX_pre_mutex_init(smx_simcall_t simcall); -void SIMIX_pre_mutex_destroy(smx_simcall_t simcall, smx_mutex_t mutex); -int SIMIX_pre_mutex_trylock(smx_simcall_t simcall, smx_mutex_t mutex); -void SIMIX_pre_mutex_unlock(smx_simcall_t simcall, smx_mutex_t mutex); -smx_cond_t SIMIX_pre_cond_init(smx_simcall_t simcall); -void SIMIX_pre_cond_destroy(smx_simcall_t simcall, smx_cond_t cond); -void SIMIX_pre_cond_signal(smx_simcall_t simcall, smx_cond_t cond); -void SIMIX_pre_cond_broadcast(smx_simcall_t simcall, smx_cond_t cond); -smx_sem_t SIMIX_pre_sem_init(smx_simcall_t simcall, unsigned int value); -void SIMIX_pre_sem_destroy(smx_simcall_t simcall, smx_sem_t sem); -void SIMIX_pre_sem_release(smx_simcall_t simcall, smx_sem_t sem); -static XBT_INLINE int SIMIX_pre_sem_would_block(smx_simcall_t simcall, - smx_sem_t sem) -{ - return SIMIX_sem_would_block(sem); -} -int SIMIX_pre_sem_get_capacity(smx_simcall_t simcall, smx_sem_t sem); +XBT_PRIVATE void SIMIX_post_synchro(smx_synchro_t synchro); +XBT_PRIVATE void SIMIX_synchro_stop_waiting(smx_process_t process, smx_simcall_t simcall); +XBT_PRIVATE void SIMIX_synchro_destroy(smx_synchro_t synchro); +XBT_PRIVATE void SIMIX_synchro_finish(smx_synchro_t synchro); + +XBT_PRIVATE smx_cond_t SIMIX_cond_init(void); +XBT_PRIVATE void SIMIX_cond_broadcast(smx_cond_t cond); +XBT_PRIVATE void SIMIX_cond_signal(smx_cond_t cond); + +XBT_PRIVATE XBT_PRIVATE smx_sem_t SIMIX_sem_init(unsigned int value); +XBT_PRIVATE void SIMIX_sem_release(smx_sem_t sem); +XBT_PRIVATE int SIMIX_sem_would_block(smx_sem_t sem); +XBT_PRIVATE int SIMIX_sem_get_capacity(smx_sem_t sem); + #endif