| /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ |
| /* This Source Code Form is subject to the terms of the Mozilla Public |
| * License, v. 2.0. If a copy of the MPL was not distributed with this |
| * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
| |
| #ifndef prcmon_h___ |
| #define prcmon_h___ |
| |
| /* |
| ** Interface to cached monitors. Cached monitors use an address to find a |
| ** given PR monitor. In this way a monitor can be associated with another |
| ** object without preallocating a monitor for all objects. |
| ** |
| ** A hash table is used to quickly map addresses to individual monitors |
| ** and the system automatically grows the hash table as needed. |
| ** |
| ** Cache monitors are about 5 times slower to use than uncached monitors. |
| */ |
| #include "prmon.h" |
| #include "prinrval.h" |
| |
| PR_BEGIN_EXTERN_C |
| |
| /** |
| ** Like PR_EnterMonitor except use the "address" to find a monitor in the |
| ** monitor cache. If successful, returns the PRMonitor now associated |
| ** with "address". Note that you must PR_CExitMonitor the address to |
| ** release the monitor cache entry (otherwise the monitor cache will fill |
| ** up). This call will return NULL if the monitor cache needs to be |
| ** expanded and the system is out of memory. |
| */ |
| NSPR_API(PRMonitor*) PR_CEnterMonitor(void *address); |
| |
| /* |
| ** Like PR_ExitMonitor except use the "address" to find a monitor in the |
| ** monitor cache. |
| */ |
| NSPR_API(PRStatus) PR_CExitMonitor(void *address); |
| |
| /* |
| ** Like PR_Wait except use the "address" to find a monitor in the |
| ** monitor cache. |
| */ |
| NSPR_API(PRStatus) PR_CWait(void *address, PRIntervalTime timeout); |
| |
| /* |
| ** Like PR_Notify except use the "address" to find a monitor in the |
| ** monitor cache. |
| */ |
| NSPR_API(PRStatus) PR_CNotify(void *address); |
| |
| /* |
| ** Like PR_NotifyAll except use the "address" to find a monitor in the |
| ** monitor cache. |
| */ |
| NSPR_API(PRStatus) PR_CNotifyAll(void *address); |
| |
| /* |
| ** Set a callback to be invoked each time a monitor is recycled from the cache |
| ** freelist, with the monitor's cache-key passed in address. |
| */ |
| NSPR_API(void) PR_CSetOnMonitorRecycle(void (PR_CALLBACK *callback)(void *address)); |
| |
| PR_END_EXTERN_C |
| |
| #endif /* prcmon_h___ */ |