Wait for a notification that a monitor's state has changed.

Syntax

#include <prcmon.h>

PRStatus PR_CWait(
   void *address,
   PRIntervalTime timeout);

Parameters

The function has the following parameters:

address
The address of the protected object--the same address previously passed to PR_CEnterMonitor.
timeout
The amount of time (in PRIntervalTime units) that the thread is willing to wait for an explicit notification before being rescheduled. If you specify PR_INTERVAL_NO_TIMEOUT, the function returns if and only if the object is notified.

Returns

The function returns one of the following values:

Description

Using the value specified in the address parameter to find a monitor in the monitor cache, PR_CWait waits for a notification that the monitor's state has changed. While the thread is waiting, it exits the monitor (just as if it had called PR_CExitMonitor as many times as it had called PR_CEnterMonitor). When the wait has finished, the thread regains control of the monitor's lock with the same entry count as before the wait began.

The thread waiting on the monitor resumes execution when the monitor is notified (assuming the thread is the next in line to receive the notify) or when the interval specified in the timeout parameter has been exceeded. When the thread resumes execution, it is the caller's responsibility to test the state of the monitored data to determine the appropriate action.