pthread_cond_reltimedwait_np man page on SunOS

Man page or keyword search:  
man Server   20652 pages
apropos Keyword Search (all sections)
Output format
SunOS logo
[printable version]

pthread_cond_wait(3C)	 Standard C Library Functions	 pthread_cond_wait(3C)

NAME
       pthread_cond_wait, pthread_cond_timedwait, pthread_cond_reltimedwait_np
       - wait on a condition

SYNOPSIS
       cc -mt [ flag... ] file... -lpthread [ library... ]
       #include <pthread.h>

       int pthread_cond_wait(pthread_cond_t *restrict cond,
	   pthread_mutex_t *restrict mutex);

       int pthread_cond_timedwait(pthread_cond_t *restrict cond,
	   pthread_mutex_t *restrict mutex,
	   const struct timespec *restrict abstime);

       int pthread_cond_reltimedwait_np(pthread_cond_t *cond,
	   pthread_mutex_t *mutex, const struct timespec *reltime);

DESCRIPTION
       The	pthread_cond_wait(),	   pthread_cond_timedwait(),	   and
       pthread_cond_reltimedwait_np()  functions are used to block on a condi‐
       tion variable. They are called with mutex locked by the calling	thread
       or undefined behavior will result.

       These  functions	 atomically release mutex and cause the calling thread
       to block on the condition variable cond. Atomically here means ``atomi‐
       cally  with  respect to access by another  thread to the mutex and then
       the condition variable." That is, if another thread is able to  acquire
       the  mutex after the about-to-block thread has released it, then a sub‐
       sequent call to pthread_cond_signal()  or  pthread_cond_broadcast()  in
       that  thread  behaves  as  if  it  were issued after the about-to-block
       thread has blocked.

       Upon successful return, the mutex has been locked and is owned  by  the
       calling thread.

       When  using condition variables there is always a boolean predicate, an
       invariant, associated with each condition wait that must be true before
       the    thread	should	  proceed.    Spurious	  wakeups   from   the
       pthread_cond_wait(),  pthread_cond_timedwait(),	or   pthread_cond_rel‐
       timedwait_np()	functions   could   occur.   Since   the  return  from
       pthread_cond_wait(),  pthread_cond_timedwait(),	or   pthread_cond_rel‐
       timedwait_np()  does  not imply anything about the value of this predi‐
       cate, the predicate should always be reevaluated.

       The order in which blocked threads are  awakened	 by  pthread_cond_sig‐
       nal()  or pthread_cond_broadcast() is determined by the scheduling pol‐
       icy. See pthreads(5).

       The  effect   of	  using	  more	 than	one   mutex   for   concurrent
       pthread_cond_wait(),   pthread_cond_timedwait(),	 or  pthread_cond_rel‐
       timedwait_np() operations on the same condition variable will result in
       undefined behavior.

       A  condition  wait (whether timed or not) is a cancellation point. When
       the cancelability enable state of  a  thread  is	 set  to  PTHREAD_CAN‐
       CEL_DEFERRED, a side effect of acting upon a cancellation request while
       in a condition wait is that the mutex is reacquired before calling  the
       first cancellation cleanup handler.

       A  thread  that	has  been unblocked because it has been canceled while
       blocked in a call to  pthread_cond_wait()  or  pthread_cond_timedwait()
       does not consume any condition signal that may be directed concurrently
       at the condition variable if there are other  threads  blocked  on  the
       condition variable.

       The     pthread_cond_timedwait()	   function    is    the    same    as
       pthread_cond_wait() except that an error is returned  if	 the  absolute
       time  specified	by  abstime  passes  (that  is,	 system time equals or
       exceeds abstime) before the condition cond is signaled or broadcast, or
       if  the	absolute  time specified by abstime has already been passed at
       the time of the call. The abstime argument is of type struct  timespec,
       defined	   in	 time.h(3HEAD).	   When	   such	   time-outs	occur,
       pthread_cond_timedwait() will nonetheless  release  and	reacquire  the
       mutex  referenced  by  mutex.  The function pthread_cond_timedwait() is
       also a cancellation point.

       The pthread_cond_reltimedwait_np() function is a non-standard extension
       provided	 by  the  Solaris version of POSIX threads as indicated by the
       ``_np'' (non-portable) suffix. The pthread_cond_reltimedwait_np() func‐
       tion  is	 the  same as pthread_cond_timedwait() except that the reltime
       argument specifies a non-negative time relative to the  current	system
       time  rather  than  an  absolute	 time. The reltime argument is of type
       struct timespec, defined in time.h(3HEAD). An error value  is  returned
       if the relative time passes (that is, system time equals or exceeds the
       starting system time plus the relative time) before the condition  cond
       is  signaled or broadcast.  When such timeouts occur, pthread_cond_rel‐
       timedwait_np() releases and reacquires the mutex referenced  by	mutex.
       The  pthread_cond_reltimedwait_np()  function  is  also	a cancellation
       point.

       If a signal is delivered to a thread waiting for a condition  variable,
       upon  return from the signal handler the thread resumes waiting for the
       condition variable as if it was not interrupted, or it returns 0 due to
       spurious wakeup.

RETURN VALUES
       Except in the case of ETIMEDOUT, EOWNERDEAD, or ENOTRECOVERABLE, all of
       these error checks act as if they were  performed  immediately  at  the
       beginning  of processing for the function and cause an error return, in
       effect, prior to modifying the state of the mutex specified by mutex or
       the condition variable specified by cond.

       Upon successful completion, 0 is returned. Otherwise, an error value is
       returned to indicate the error.

ERRORS
       The  pthread_cond_timedwait() function will fail if:

       ETIMEDOUT    The	  absolute    time    specified	   by	 abstime    to
		    pthread_cond_timedwait() has passed.

       The pthread_cond_reltimedwait_np() function will fail if:

       EINVAL	    The value specified by reltime is invalid.

       ETIMEDOUT    The	   relative    time    specified    by	  reltime   to
		    pthread_cond_reltimedwait_np() has passed.

       The pthread_cond_wait() and pthread_cond_timedwait() functions may fail
       if:

       EINVAL	 The value specified by cond, mutex, or abstime is invalid.

       EINVAL	 Different    mutexes	 were	 supplied    for    concurrent
		 pthread_cond_wait() or	 pthread_cond_timedwait(),  operations
		 on the same condition variable.

       EPERM	 The  mutex was not owned by the current thread at the time of
		 the call.

       If the mutex specified by mutex is a robust mutex (initialized with the
       robustness attribute PTHREAD_MUTEX_ROBUST_NP), the pthread_cond_wait(),
       pthread_cond_timedwait(), and pthread_cond_reltimedwait_np()  functions
       will,  under  the specified conditions, return the following error val‐
       ues.  For complete  information,	 see  the  pthread_mutex_lock(3C)  and
       pthread_mutexattr_setrobust_np(3C) manual pages.

       EOWNERDEAD	  The  last owner of this mutex died while holding the
			  mutex, leaving the state it was protecting  possibly
			  inconsistent. The mutex is now owned by the caller.

       ENOTRECOVERABLE	  The  mutex  was  protecting  state that has now been
			  left irrecoverable. The mutex has not been acquired.

ATTRIBUTES
       See attributes(5) for descriptions of the following attributes:

       ┌─────────────────────────────┬─────────────────────────────┐
       │      ATTRIBUTE TYPE	     │	    ATTRIBUTE VALUE	   │
       ├─────────────────────────────┼─────────────────────────────┤
       │Interface Stability	     │Standard			   │
       ├─────────────────────────────┼─────────────────────────────┤
       │MT-Level		     │MT-Safe			   │
       └─────────────────────────────┴─────────────────────────────┘

SEE ALSO
       pthread_cond_signal(3C),			   pthread_cond_broadcast(3C),
       pthread_mutex_lock(3C),		   pthread_mutexattr_getrobust_np(3C),
       time.h(3HEAD), attributes(5), condition(5), pthreads(5), standards(5)

SunOS 5.10			  5 Jun 2007		 pthread_cond_wait(3C)
[top]

List of man pages available for SunOS

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net