cc [options] -Kthread file#include <semaphore.h>
int sem_wait(sem_t *sem); int sem_trywait(sem_t *sem);
If the semaphore is available (that is, if the semaphore value is greater than zero), sem_wait decrements the semaphore value and returns to the caller.
If the semaphore is unavailable (that is, the semaphore value is zero or less), sem_wait decrements the semaphore value and suspends execution of the calling thread until the semaphore becomes available to the caller or the call is interrupted by a signal.
If a thread waiting on a semaphore is interrupted by a signal, sem_wait returns EINTR.
sem_trywait makes a single attempt to acquire the semaphore pointed to by sem. If the semaphore is available, sem_trywait decrements the semaphore value and returns to the caller. sem_trywait is used when the caller does not want to block if the semaphore is unavailable. If sem_trywait cannot immediately acquire the semaphore, it returns EAGAIN to the caller, it does not block the caller to wait for the semaphore or decrement the semaphore value.
sem is a pointer to the semaphore to acquire, which must previously have been initialized by sem_init.
sem_wait returns a value of -1 and sets errno to the following value if the corresponding condition is detected:
sem_trywait returns the following value if the corresponding condition is detected: