diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2012-04-07 22:06:39 +0000 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2012-04-07 22:06:39 +0000 |
commit | 130cf77b86a7777994f1e1e8dcb646f366a2d294 (patch) | |
tree | a37fe24d4852af00f87b7dc0864d1f28a968f474 /libddekit/ddekit/semaphore.h | |
parent | 4057679b76ae5e1f7e79802be8399396f29c0b09 (diff) | |
parent | 06fe9218fd82aeae688cfba5bda512d808bd443f (diff) |
Merge branch 'dde' of git.savannah.gnu.org:/srv/git/hurd/incubator into dde
Diffstat (limited to 'libddekit/ddekit/semaphore.h')
-rw-r--r-- | libddekit/ddekit/semaphore.h | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/libddekit/ddekit/semaphore.h b/libddekit/ddekit/semaphore.h new file mode 100644 index 00000000..c959919d --- /dev/null +++ b/libddekit/ddekit/semaphore.h @@ -0,0 +1,50 @@ +#ifndef _ddekit_semaphore_h +#define _ddekit_semaphore_h + +/** \defgroup DDEKit_synchronization */ + +struct ddekit_sem; +typedef struct ddekit_sem ddekit_sem_t; + +/** Initialize DDEKit semaphore. + * + * \ingroup DDEKit_synchronization + * + * \param value initial semaphore counter + */ +ddekit_sem_t *ddekit_sem_init(int value); + +/** Uninitialize semaphore. + * + * \ingroup DDEKit_synchronization + */ +void ddekit_sem_deinit(ddekit_sem_t *sem); + +/** Semaphore down method. */ +void ddekit_sem_down(ddekit_sem_t *sem); + +/** Semaphore down method, non-blocking. + * + * \ingroup DDEKit_synchronization + * + * \return 0 success + * \return !=0 would block + */ +int ddekit_sem_down_try(ddekit_sem_t *sem); + +/** Semaphore down with timeout. + * + * \ingroup DDEKit_synchronization + * + * \return 0 success + * \return !=0 would block + */ +int ddekit_sem_down_timed(ddekit_sem_t *sem, int timo); + +/** Semaphore up method. + * + * \ingroup DDEKit_synchronization + */ +void ddekit_sem_up(ddekit_sem_t *sem); + +#endif |