for connected embedded systems
![]() |
![]() |
![]() |
![]() |
PtCondWait()
Block a thread on a conditional variable
Synopsis:
int PtCondWait( pthread_cond_t *cond );
Arguments:
- cond
- The condition variable to wait on.
Library:
ph
Description:
PtCondWait() is an equivalent of pthread_cond_wait() that uses the Photon library lock instead of a mutex, which has the effect of an implicit PtLeave() when you block, and PtEnter() when you unblock.
The calling thread is blocked until:
- another thread performs a signal or broadcast on the condition variable
(using
pthread_cond_signal()
or
pthread_cond_broadcast())
Or:
- a signal is delivered to the thread.
In all cases, the thread reacquires the Photon library lock before being unblocked.
The implicit PtLeave() call that PtCondWait() makes before blocking turns the calling thread into an event non-reader. If you passed the Pt_DELAY_EXIT flag to PtEnter() before calling PtCondWait(), it also disables the effect of that flag. Before returning, PtCondWait() turns the thread back into an event reader if it was an event reader before, but will not turn the Pt_DELAY_EXIT flag back on. In particular, this means that if another thread has called PtExit(), this function does not return, even if a third thread signals the condvar.
Returns:
- EOK
- Success, or the call was interrupted by a signal.
- EAGAIN
- Insufficient system resources are available to wait on the condition.
- EFAULT
- A fault occurred trying to access the buffers provided.
- EINVAL
- One or more of cond or mutex is invalid.
Concurrent waits on cond used different mutexes.
The current thread doesn't own mutex.
Classification:
Photon
| Safety: | |
|---|---|
| Interrupt handler | No |
| Signal handler | No |
| Thread | Yes |
See also:
PtCondTimedWait(), PtEnter(), PtLeave()
pthread_cond_wait() in the QNX Neutrino Library Reference
"Threads" in the Parallel Operations chapter of the Photon Programmer's Guide
![]() |
![]() |
![]() |
![]() |

![[Previous]](../prev.gif)
![[Contents]](../contents.gif)
![[Index]](../keyword_index.gif)
![[Next]](../next.gif)