cc [options] -Kthread file#include <pthread.h>
int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock);
The calling thread acquires the write lock if no other thread (reader or writer) holds the read-write lock rwlock. Otherwise, the thread blocks (that is, does not return from the pthread_rwlock_wrlock call) until it can acquire the lock.
Deadlock will occur if the calling thread holds the read-write lock (whether a read or write lock) at the time the call is made.
If the lock is held by any readers when pthread_rwlock_wrlock is called, and no writer is waiting for the lock, the caller blocks until all the current readers have released the lock. If the lock is held by another writer, or if there are any other writers already waiting for the lock, the caller blocks to wait for the lock.
From the point of view of the application, this function is atomic: even if interrupted by a signal or forkall, pthread_rwlock_wrlock will not return until it holds the lock. As a consequence, if pthread_rwlock_wrlock is interrupted, an error indication such as EINTR is never returned to the user.
pthread_rwlock_trywrlock is used when the caller does not want to block if the lock is unavailable. It makes a single attempt to acquire the reader-writer lock pointed to by rwlock in write mode; it does not block the caller if the lock is unavailable.
If the lock is free, pthread_rwlock_trywrlock acquires the lock in write mode and the caller proceeds. If the lock is currently held, pthread_rwlock_trywrlock immediately returns EBUSY to the caller, without acquiring the lock.
Results are undefined if any of these functions are called with an uninitialized read-write lock.
Only one writer at a time can hold a reader-writer lock, although any number of readers can hold the lock at any time. Once a writer has requested the lock with pthread_rwlock_wrlock, all subsequent requests for the lock in either read or write mode are blocked.
For consistency, locks acquired with pthread_rwlock_wrlock or pthread_rwlock_trywrlock should be released with pthread_rwlock_unlock.
pthread_rwlock_wrlock returns the following value if the corresponding condition is detected:
pthread_rwlock_trywrlock returns the following value if the corresponding condition is detected: