FreeBSD manual

download PDF document: pthread_mutexattr_setrobust.3.pdf

PTHREAD_MUTEXATTR(3) FreeBSD Library Functions Manual PTHREAD_MUTEXATTR(3)
NAME pthread_mutexattr_init, pthread_mutexattr_destroy, pthread_mutexattr_setprioceiling, pthread_mutexattr_getprioceiling, pthread_mutexattr_setprotocol, pthread_mutexattr_getprotocol, pthread_mutexattr_setpshared, pthread_mutexattr_getpshared, pthread_mutexattr_setrobust, pthread_mutexattr_getrobust, pthread_mutexattr_settype, pthread_mutexattr_gettype - mutex attribute operations
LIBRARY POSIX Threads Library (libpthread, -lpthread)
SYNOPSIS #include <pthread.h>
int pthread_mutexattr_init(pthread_mutexattr_t *attr);
int pthread_mutexattr_destroy(pthread_mutexattr_t *attr);
int pthread_mutexattr_setprioceiling(pthread_mutexattr_t *attr, int prioceiling);
int pthread_mutexattr_getprioceiling(const pthread_mutexattr_t *attr, int *prioceiling);
int pthread_mutexattr_setprotocol(pthread_mutexattr_t *attr, int protocol);
int pthread_mutexattr_getprotocol(const pthread_mutexattr_t *restrict attr, int *restrict protocol);
int pthread_mutexattr_setpshared(pthread_mutexattr_t *attr, int shared);
int pthread_mutexattr_getpshared(const pthread_mutexattr_t *attr, int *shared);
int pthread_mutexattr_setrobust(pthread_mutexattr_t *attr, int robust);
int pthread_mutexattr_getrobust(pthread_mutexattr_t *attr, int *robust);
int pthread_mutexattr_settype(pthread_mutexattr_t *attr, int type);
int pthread_mutexattr_gettype(const pthread_mutexattr_t *restrict attr, int *restrict type);
DESCRIPTION The pthread_mutexattr_destroy() function destroys attr.
The pthread_mutexattr_setprioceiling() function sets the priority ceiling for the mutex, used by threads executed under the PTHREAD_PRIO_PROTECT protocol.
The pthread_mutexattr_setprotocol() function specifies the protocol to be followed in utilizing mutexes. The protocol argument can take one of the following values:
PTHREAD_PRIO_NONE Priority and scheduling of the thread owning this mutex is not affected by its mutex ownership.
PTHREAD_PRIO_INHERIT Request priority-inheritance protocol, where the thread owning the mutex is executed at the highest priority among priorities of all threads waiting on any mutex owned by this thread.
PTHREAD_PRIO_PROTECT Request priority-inheritance protocol, where the thread owning the mutex is executed at highest priority among priorities or priority ceilings of all threads waiting on any mutex owned by this thread.
The pthread_mutexattr_setpshared() function sets the process-shared attribute of attr to the value specified in pshared. The argument pshared may have one of the following values:
PTHREAD_PROCESS_PRIVATE The mutex may only be used by threads in the same process as the one that created the object.
PTHREAD_PROCESS_SHARED The mutex may be used by threads in processes other than the one that created the object, assuming other processes share access to the memory where the mutex was allocated. See libthr(3) for details of the implementation of the shared mutexes, and their limitations.
The pthread_mutexattr_setrobust() function specifies robustness attribute of the mutex. Possible values for the robust argument are
PTHREAD_MUTEX_STALLED No special actions are taken if the thread owning the mutex is terminated without unlocking the mutex lock. This can lead to deadlocks if no other thread can unlock the mutex. This is the default value.
PTHREAD_MUTEX_ROBUST If the process containing the owning thread of a robust mutex, or owning thread, terminates while holding the mutex lock, the next thread that acquires the mutex is notified about the termination by the return value EOWNERDEAD from the locking function. Then, either pthread_mutex_consistent(3) can be used to repair the mutex lock state, or pthread_mutex_unlock(3) can unlock the mutex lock but also put it an unusable state, where all further attempts to acquire it result in the ENOTRECOVERABLE error.
functions. This matches PTHREAD_MUTEX_ERRORCHECK but somewhat contradicts the behavior mandated by POSIX.
PTHREAD_MUTEX_ERRORCHECK Both recursive locking, and unlocking when the lock is not owned by the current thread, cause an error returned from the corresponding functions.
PTHREAD_MUTEX_RECURSIVE Recursive locking is allowed. Attempt to unlock when current thread is not an owner of the lock causes an error to be returned.
PTHREAD_MUTEX_DEFAULT The FreeBSD implementation maps this type to PTHREAD_MUTEX_ERRORCHECK type.
The pthread_mutexattr_get*() functions copy the value of the attribute that corresponds to each function name to the location pointed to by the second function parameter.
RETURN VALUES If successful, these functions return 0. Otherwise, an error number is returned to indicate the error.
ERRORS The pthread_mutexattr_init() function will fail if:
[ENOMEM] Out of memory.
The pthread_mutexattr_destroy() function will fail if:
[EINVAL] Invalid value for attr.
The pthread_mutexattr_setprioceiling() function will fail if:
[EINVAL] Invalid value for attr, or invalid value for prioceiling.
The pthread_mutexattr_getprioceiling() function will fail if:
[EINVAL] Invalid value for attr.
The pthread_mutexattr_setprotocol() function will fail if:
[EINVAL] Invalid value for attr, or invalid value for protocol.
The pthread_mutexattr_getprotocol() function will fail if:
[EINVAL] Invalid value for attr.
The pthread_mutexattr_setpshared() function will fail if:
[EINVAL] Invalid value for attr, or invalid value for shared.
The pthread_mutexattr_getpshared() function will fail if:
[EINVAL] Invalid value for attr.
The pthread_mutexattr_settype() function will fail if: The pthread_mutexattr_setrobust() function will fail if:
[EINVAL] Invalid value for attr, or invalid value for robust.
The pthread_mutexattr_getrobust() function will fail if:
[EINVAL] Invalid value for attr.
SEE ALSO libthr(3), pthread_mutex_init(3)
STANDARDS The pthread_mutexattr_init() and pthread_mutexattr_destroy() functions conform to ISO/IEC 9945-1:1996 ("POSIX.1")
The pthread_mutexattr_setprioceiling(), pthread_mutexattr_getprioceiling(), pthread_mutexattr_setprotocol(), pthread_mutexattr_getprotocol(), pthread_mutexattr_setpshared(), pthread_mutexattr_getpshared(), pthread_mutexattr_settype(), and pthread_mutexattr_gettype() functions conform to Version 2 of the Single UNIX Specification ("SUSv2"). The pthread_mutexattr_setrobust() and pthread_mutexattr_getrobust() functions conform to Version 4 of the Single UNIX Specification ("SUSv4").
FreeBSD 14.2-RELEASE October 27, 2023 FreeBSD 14.2-RELEASE