X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/18c57b27dd71ee7839c6a90368c845886a87d638..45c3f1cfee86fb48c96d53f8267f99b6db6e3d7a:/src/simix/smx_synchro_private.h diff --git a/src/simix/smx_synchro_private.h b/src/simix/smx_synchro_private.h index f3ec15c14b..ad411fdf73 100644 --- a/src/simix/smx_synchro_private.h +++ b/src/simix/smx_synchro_private.h @@ -1,3 +1,9 @@ +/* Copyright (c) 2012, 2014. 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. */ + #ifndef _SIMIX_SYNCHRO_PRIVATE_H #define _SIMIX_SYNCHRO_PRIVATE_H @@ -26,23 +32,42 @@ 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); +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); -void SIMIX_pre_cond_wait_timeout(smx_simcall_t simcall); +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); -void SIMIX_pre_sem_acquire_timeout(smx_simcall_t simcall); +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); #endif