PTHREAD_COND_BROADCAST man page on Pidora

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

PTHREAD_COND_BROADCAST(3P) POSIX Programmer's ManualPTHREAD_COND_BROADCAST(3P)

PROLOG
       This  manual  page is part of the POSIX Programmer's Manual.  The Linux
       implementation of this interface may differ (consult the	 corresponding
       Linux  manual page for details of Linux behavior), or the interface may
       not be implemented on Linux.

NAME
       pthread_cond_broadcast, pthread_cond_signal -  broadcast	 or  signal  a
       condition

SYNOPSIS
       #include <pthread.h>

       int pthread_cond_broadcast(pthread_cond_t *cond);
       int pthread_cond_signal(pthread_cond_t *cond);

DESCRIPTION
       These functions shall unblock threads blocked on a condition variable.

       The  pthread_cond_broadcast()  function	shall unblock all threads cur‐
       rently blocked on the specified condition variable cond.

       The pthread_cond_signal() function shall unblock at least  one  of  the
       threads	that  are blocked on the specified condition variable cond (if
       any threads are blocked on cond).

       If more than one thread is blocked on a condition variable, the	sched‐
       uling  policy shall determine the order in which threads are unblocked.
       When each thread unblocked as a result of a pthread_cond_broadcast() or
       pthread_cond_signal()  returns  from its call to pthread_cond_wait() or
       pthread_cond_timedwait(), the thread shall own the mutex with which  it
       called  pthread_cond_wait()  or pthread_cond_timedwait(). The thread(s)
       that are unblocked shall contend for the mutex according to the	sched‐
       uling   policy	(if   applicable),   and   as	if   each  had	called
       pthread_mutex_lock().

       The pthread_cond_broadcast() or pthread_cond_signal() functions may  be
       called  by  a  thread  whether  or not it currently owns the mutex that
       threads calling pthread_cond_wait()  or	pthread_cond_timedwait()  have
       associated  with the condition variable during their waits; however, if
       predictable scheduling behavior is required, then that mutex  shall  be
       locked	 by    the    thread   calling	 pthread_cond_broadcast()   or
       pthread_cond_signal().

       The pthread_cond_broadcast() and pthread_cond_signal() functions	 shall
       have no effect if there are no threads currently blocked on cond.

RETURN VALUE
       If  successful,	the pthread_cond_broadcast() and pthread_cond_signal()
       functions shall return  zero;  otherwise,  an  error  number  shall  be
       returned to indicate the error.

ERRORS
       The  pthread_cond_broadcast()  and  pthread_cond_signal()  function may
       fail if:

       EINVAL The value cond does not refer to an initialized condition	 vari‐
	      able.

       These functions shall not return an error code of [EINTR].

       The following sections are informative.

EXAMPLES
       None.

APPLICATION USAGE
       The pthread_cond_broadcast() function is used whenever the shared-vari‐
       able state has been changed in a way that more than one thread can pro‐
       ceed  with its task. Consider a single producer/multiple consumer prob‐
       lem, where the producer can insert multiple items on  a	list  that  is
       accessed	 one  item  at	a  time	 by  the  consumers.   By  calling the
       pthread_cond_broadcast() function, the producer would notify  all  con‐
       sumers that might be waiting, and thereby the application would receive
       more throughput on a multi-processor. In addition,  pthread_cond_broad‐
       cast()	makes	it   easier   to  implement  a	read-write  lock.  The
       pthread_cond_broadcast() function is needed in order  to	 wake  up  all
       waiting	readers	 when  a  writer releases its lock.  Finally, the two-
       phase commit algorithm can use this broadcast function  to  notify  all
       clients of an impending transaction commit.

       It  is  not  safe to use the pthread_cond_signal() function in a signal
       handler that is invoked asynchronously. Even if	it  were  safe,	 there
       would   still   be   a	race   between	 the   test   of  the  Boolean
       pthread_cond_wait() that could not be efficiently eliminated.

       Mutexes and condition variables are thus not suitable for  releasing  a
       waiting thread by signaling from code running in a signal handler.

RATIONALE
   Multiple Awakenings by Condition Signal
       On  a  multi-processor,	it  may be impossible for an implementation of
       pthread_cond_signal() to avoid the unblocking of more than  one	thread
       blocked	on  a  condition variable. For example, consider the following
       partial implementation  of  pthread_cond_wait()	and  pthread_cond_sig‐
       nal(), executed by two threads in the order given. One thread is trying
       to wait on the condition variable, another  is  concurrently  executing
       pthread_cond_signal(), while a third thread is already waiting.

	      pthread_cond_wait(mutex, cond):
		  value = cond->value; /* 1 */
		  pthread_mutex_unlock(mutex); /* 2 */
		  pthread_mutex_lock(cond->mutex); /* 10 */
		  if (value == cond->value) { /* 11 */
		      me->next_cond = cond->waiter;
		      cond->waiter = me;
		      pthread_mutex_unlock(cond->mutex);
		      unable_to_run(me);
		  } else
		      pthread_mutex_unlock(cond->mutex); /* 12 */
		  pthread_mutex_lock(mutex); /* 13 */

	      pthread_cond_signal(cond):
		  pthread_mutex_lock(cond->mutex); /* 3 */
		  cond->value++; /* 4 */
		  if (cond->waiter) { /* 5 */
		      sleeper = cond->waiter; /* 6 */
		      cond->waiter = sleeper->next_cond; /* 7 */
		      able_to_run(sleeper); /* 8 */
		  }
		  pthread_mutex_unlock(cond->mutex); /* 9 */

       The  effect  is	that  more than one thread can return from its call to
       pthread_cond_wait() or pthread_cond_timedwait() as a result of one call
       to  pthread_cond_signal().  This	 effect	 is  called "spurious wakeup".
       Note that the situation	is  self-correcting  in	 that  the  number  of
       threads that are so awakened is finite; for example, the next thread to
       call pthread_cond_wait() after the sequence of events above blocks.

       While this problem could be resolved, the  loss	of  efficiency	for  a
       fringe  condition  that	occurs only rarely is unacceptable, especially
       given that one has to check the predicate associated with  a  condition
       variable anyway. Correcting this problem would unnecessarily reduce the
       degree of concurrency in this basic building block for all higher-level
       synchronization operations.

       An  added benefit of allowing spurious wakeups is that applications are
       forced to code a predicate-testing-loop around the condition wait. This
       also makes the application tolerate superfluous condition broadcasts or
       signals on the same condition variable that may be coded in some	 other
       part  of	 the  application.  The	 resulting  applications are thus more
       robust. Therefore, IEEE Std 1003.1-2001 explicitly documents that  spu‐
       rious wakeups may occur.

FUTURE DIRECTIONS
       None.

SEE ALSO
       pthread_cond_destroy(),	pthread_cond_timedwait(), the Base Definitions
       volume of IEEE Std 1003.1-2001, <pthread.h>

COPYRIGHT
       Portions of this text are reprinted and reproduced in  electronic  form
       from IEEE Std 1003.1, 2003 Edition, Standard for Information Technology
       -- Portable Operating System Interface (POSIX),	The  Open  Group  Base
       Specifications  Issue  6,  Copyright  (C) 2001-2003 by the Institute of
       Electrical and Electronics Engineers, Inc and The Open  Group.  In  the
       event of any discrepancy between this version and the original IEEE and
       The Open Group Standard, the original IEEE and The Open Group  Standard
       is  the	referee document. The original Standard can be obtained online
       at http://www.opengroup.org/unix/online.html .

IEEE/The Open Group		     2003	    PTHREAD_COND_BROADCAST(3P)
[top]

List of man pages available for Pidora

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