|
NAMEsem_timedwait , sem_clockwait_np
—
lock a semaphore
LIBRARYStandard C Library (libc, -lc)SYNOPSIS#include <semaphore.h>
#include <time.h>
int
int
DESCRIPTIONThesem_timedwait () function locks the semaphore
referenced by sem, as in the
sem_wait(3)
function. However, if the semaphore cannot be locked without waiting for
another process or thread to unlock the semaphore by performing a
sem_post(3)
function, this wait will be terminated when the specified timeout expires.
The timeout will expire when the absolute time specified by abs_timeout passes, as measured by the clock on which timeouts are based (that is, when the value of that clock equals or exceeds abs_timeout), or if the absolute time specified by abs_timeout has already been passed at the time of the call. Note that the timeout is based on the
The validity of the abs_timeout is not checked if the semaphore can be locked immediately. The RETURN VALUESThese functions return zero if the calling process successfully performed the semaphore lock operation on the semaphore designated by sem. If the call was unsuccessful, the state of the semaphore is unchanged, and the function returns a value of -1 and sets the global variable errno to indicate the error.ERRORSThese functions will fail if:
SEE ALSOsem_post(3), sem_trywait(3), sem_wait(3)STANDARDSThesem_timedwait () function conforms to
IEEE Std 1003.1-2004 (“POSIX.1”). The
sem_clockwait_np () function is not specified by any
standard; it exists only on FreeBSD at the time of
this writing.
HISTORYThesem_timedwait () function first appeared in
FreeBSD 5.0. The
sem_clockwait_np () function first appeared in
FreeBSD 11.1.
Visit the GSP FreeBSD Man Page Interface. |