Provided by: manpages-posix-dev_2017a-2_all bug

PROLOG

       This  manual  page  is part of the POSIX Programmer's Manual.  The Linux implementation of this interface
       may differ (consult the corresponding Linux manual page for details of Linux behavior), or the  interface
       may not be implemented on Linux.

NAME

       pthread_mutexattr_getrobust, pthread_mutexattr_setrobust — get and set the mutex robust attribute

SYNOPSIS

       #include <pthread.h>

       int pthread_mutexattr_getrobust(const pthread_mutexattr_t *restrict
           attr, int *restrict robust);
       int pthread_mutexattr_setrobust(pthread_mutexattr_t *attr,
           int robust);

DESCRIPTION

       The  pthread_mutexattr_getrobust()  and  pthread_mutexattr_setrobust() functions, respectively, shall get
       and set the mutex robust attribute. This attribute is set in  the  robust  parameter.  Valid  values  for
       robust include:

       PTHREAD_MUTEX_STALLED
             No  special actions are taken if the owner of the mutex is terminated while holding 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 terminates while  holding  the  mutex
             lock, the next thread that acquires the mutex shall be notified about the termination by the return
             value  [EOWNERDEAD]  from  the  locking function. If the owning thread of a robust mutex terminates
             while holding the mutex lock, the next thread that attempts to acquire the mutex  may  be  notified
             about  the  termination  by the return value [EOWNERDEAD].  The notified thread can then attempt to
             make the state protected by the mutex consistent again, and if successful can mark the mutex  state
             as  consistent  by  calling  pthread_mutex_consistent().   After  a  subsequent  successful call to
             pthread_mutex_unlock(), the mutex lock shall be released and can be used normally by other threads.
             If the mutex is unlocked without a call to pthread_mutex_consistent(), it shall be in a permanently
             unusable state and all attempts to lock the mutex shall fail with the error [ENOTRECOVERABLE].  The
             only permissible operation on such a mutex is pthread_mutex_destroy().

       The behavior is undefined if the value specified by the attr argument to pthread_mutexattr_getrobust() or
       pthread_mutexattr_setrobust() does not refer to an initialized mutex attributes object.

RETURN VALUE

       Upon successful completion, the pthread_mutexattr_getrobust() function shall return zero  and  store  the
       value  of  the robust attribute of attr into the object referenced by the robust parameter. Otherwise, an
       error value shall be returned to indicate the error.  If  successful,  the  pthread_mutexattr_setrobust()
       function shall return zero; otherwise, an error number shall be returned to indicate the error.

ERRORS

       The pthread_mutexattr_setrobust() function shall fail if:

       EINVAL The value of robust is invalid.

       These functions shall not return an error code of [EINTR].

       The following sections are informative.

EXAMPLES

       None.

APPLICATION USAGE

       The  actions  required  to make the state protected by the mutex consistent again are solely dependent on
       the application. If it is not possible to make the state of a mutex consistent,  robust  mutexes  can  be
       used   to   notify   this   situation   by   calling  pthread_mutex_unlock()  without  a  prior  call  to
       pthread_mutex_consistent().

       If the state is  declared  inconsistent  by  calling  pthread_mutex_unlock()  without  a  prior  call  to
       pthread_mutex_consistent(),  a  possible approach could be to destroy the mutex and then reinitialize it.
       However, it should be noted that this is possible only in certain situations where the state protected by
       the mutex has to be reinitialized and coordination achieved with other  threads  blocked  on  the  mutex,
       because  otherwise  a call to a locking function with a reference to a mutex object invalidated by a call
       to pthread_mutex_destroy() results in undefined behavior.

RATIONALE

       If   an   implementation   detects   that   the   value   specified   by    the    attr    argument    to
       pthread_mutexattr_getrobust()  or  pthread_mutexattr_setrobust()  does  not refer to an initialized mutex
       attributes object, it is recommended that the function should fail and report an [EINVAL] error.

FUTURE DIRECTIONS

       None.

SEE ALSO

       pthread_mutex_consistent(), pthread_mutex_destroy(), pthread_mutex_lock()

       The Base Definitions volume of POSIX.1‐2017, <pthread.h>

COPYRIGHT

       Portions of this text are reprinted and reproduced in electronic form from IEEE Std 1003.1-2017, Standard
       for Information  Technology  --  Portable  Operating  System  Interface  (POSIX),  The  Open  Group  Base
       Specifications  Issue  7, 2018 Edition, Copyright (C) 2018 by the Institute of Electrical and Electronics
       Engineers, Inc and The Open Group.  In the event of any discrepancy between this version and the original
       IEEE and The Open Group Standard, the original IEEE and The Open Group Standard is the referee  document.
       The original Standard can be obtained online at http://www.opengroup.org/unix/online.html .

       Any  typographical  or formatting errors that appear in this page are most likely to have been introduced
       during  the  conversion  of  the  source  files  to  man  page  format.  To  report  such   errors,   see
       https://www.kernel.org/doc/man-pages/reporting_bugs.html .

IEEE/The Open Group                                   2017                   PTHREAD_MUTEXATTR_GETROBUST(3POSIX)