11. Mutex Manager

11.1. Introduction

The mutex manager implements the functionality required of the mutex manager as defined by POSIX 1003.1b-1996. This standard requires that a compliant operating system provide the facilties to ensure that threads can operate with mutual exclusion from one another and defines the API that must be provided.

The services provided by the mutex manager are:

11.2. Background

11.2.1. Mutex Attributes

Mutex attributes are utilized only at mutex creation time. A mutex attribute structure may be initialized and passed as an argument to the mutex_init routine. Note that the priority ceiling of a mutex may be set at run-time.

blocking protcol is the XXX
priority ceiling is the XXX
pshared is the XXX

11.2.2. PTHREAD_MUTEX_INITIALIZER

This is a special value that a variable of type pthread_mutex_t may be statically initialized to as shown below:

pthread_mutex_t my_mutex = PTHREAD_MUTEX_INITIALIZER;

This indicates that my_mutex will be automatically initialized by an implicit call to pthread_mutex_init the first time the mutex is used.

Note that the mutex will be initialized with default attributes.

11.3. Operations

There is currently no text in this section.

11.4. Services

This section details the mutex manager’s services. A subsection is dedicated to each of this manager’s services and describes the calling sequence, related constants, usage, and status codes.

11.4.1. pthread_mutexattr_init - Initialize a Mutex Attribute Set

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutexattr_init(
    pthread_mutexattr_t *attr
);

STATUS CODES:

EINVAL
The attribute pointer argument is invalid.

DESCRIPTION:

The pthread_mutexattr_init routine initializes the mutex attributes object specified by attr with the default value for all of the individual attributes.

NOTES:

XXX insert list of default attributes here.

11.4.2. pthread_mutexattr_destroy - Destroy a Mutex Attribute Set

CALLING SEQUENCE:

#include <pthread.h>
    int pthread_mutexattr_destroy(
    pthread_mutexattr_t *attr
);

STATUS CODES:

EINVAL The attribute pointer argument is invalid.
EINVAL The attribute set is not initialized.

DESCRIPTION:

The pthread_mutex_attr_destroy routine is used to destroy a mutex attributes object. The behavior of using an attributes object after it is destroyed is implementation dependent.

NOTES:

NONE

11.4.3. pthread_mutexattr_setprotocol - Set the Blocking Protocol

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutexattr_setprotocol(
    pthread_mutexattr_t *attr,
    int                  protocol
);

STATUS CODES:

EINVAL The attribute pointer argument is invalid.
EINVAL The attribute set is not initialized.
EINVAL The protocol argument is invalid.

DESCRIPTION:

The pthread_mutexattr_setprotocol routine is used to set value of the protocol attribute. This attribute controls the order in which threads waiting on this mutex will receive it.

The protocol can be one of the following:

PTHREAD_PRIO_NONE in which case blocking order is FIFO.
PTHREAD_PRIO_INHERIT in which case blocking order is priority with the priority inheritance protocol in effect.
PTHREAD_PRIO_PROTECT in which case blocking order is priority with the priority ceiling protocol in effect.

NOTES:

There is currently no way to get simple priority blocking ordering with POSIX mutexes even though this could easily by supported by RTEMS.

11.4.4. pthread_mutexattr_getprotocol - Get the Blocking Protocol

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutexattr_getprotocol(
    pthread_mutexattr_t *attr,
    int                 *protocol
);

STATUS CODES:

EINVAL The attribute pointer argument is invalid.
EINVAL The attribute set is not initialized.
EINVAL The protocol pointer argument is invalid.

DESCRIPTION:

The pthread_mutexattr_getprotocol routine is used to obtain the value of the protocol attribute. This attribute controls the order in which threads waiting on this mutex will receive it.

NOTES:

NONE

11.4.5. pthread_mutexattr_setprioceiling - Set the Priority Ceiling

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutexattr_setprioceiling(
    pthread_mutexattr_t *attr,
    int                  prioceiling
);

STATUS CODES:

EINVAL The attribute pointer argument is invalid.
EINVAL The attribute set is not initialized.
EINVAL The prioceiling argument is invalid.

DESCRIPTION:

The pthread_mutexattr_setprioceiling routine is used to set value of the prioceiling attribute. This attribute specifies the priority that is the ceiling for threads obtaining this mutex. Any task obtaining this mutex may not be of greater priority that the ceiling. If it is of lower priority, then its priority will be elevated to prioceiling.

NOTES:

NONE

11.4.6. pthread_mutexattr_getprioceiling - Get the Priority Ceiling

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutexattr_getprioceiling(
    const pthread_mutexattr_t *attr,
    int                       *prioceiling
);

STATUS CODES:

EINVAL The attribute pointer argument is invalid.
EINVAL The attribute set is not initialized.
EINVAL The prioceiling pointer argument is invalid.

DESCRIPTION:

The pthread_mutexattr_getprioceiling routine is used to obtain the value of the prioceiling attribute. This attribute specifies the priority ceiling for this mutex.

NOTES:

NONE

11.4.7. pthread_mutexattr_setpshared - Set the Visibility

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutexattr_setpshared(
    pthread_mutexattr_t *attr,
    int                  pshared
);

STATUS CODES:

EINVAL The attribute pointer argument is invalid.
EINVAL The attribute set is not initialized.
EINVAL The pshared argument is invalid.

DESCRIPTION:

NOTES:

11.4.8. pthread_mutexattr_getpshared - Get the Visibility

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutexattr_getpshared(
    const pthread_mutexattr_t *attr,
    int                       *pshared
);

STATUS CODES:

EINVAL The attribute pointer argument is invalid.
EINVAL The attribute set is not initialized.
EINVAL The pshared pointer argument is invalid.

DESCRIPTION:

NOTES:

11.4.9. pthread_mutex_init - Initialize a Mutex

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutex_init(
    pthread_mutex_t           *mutex,
    const pthread_mutexattr_t *attr
);

STATUS CODES:

EINVAL The attribute set is not initialized.
EINVAL The specified protocol is invalid.
EAGAIN The system lacked the necessary resources to initialize another mutex.
ENOMEM Insufficient memory exists to initialize the mutex.
EBUSY Attempted to reinialize the object reference by mutex, a previously initialized, but not yet destroyed.

DESCRIPTION:

NOTES:

11.4.10. pthread_mutex_destroy - Destroy a Mutex

CALLING SEQUENCE:

#include <pthread.h>
    int pthread_mutex_destroy(
    pthread_mutex_t *mutex
);

STATUS CODES:

EINVAL The specified mutex is invalid.
EBUSY Attempted to destroy the object reference by mutex, while it is locked or referenced by another thread.

DESCRIPTION:

NOTES:

11.4.11. pthread_mutex_lock - Lock a Mutex

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutex_lock(
    pthread_mutex_t *mutex
);

STATUS CODES:

EINVAL The specified mutex is invalid.
EINVAL The mutex has the protocol attribute of PTHREAD_PRIO_PROTECT and the priority of the calling thread is higher than the current priority ceiling.
EDEADLK The current thread already owns the mutex.

DESCRIPTION:

NOTES:

11.4.12. pthread_mutex_trylock - Poll to Lock a Mutex

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutex_trylock(
    pthread_mutex_t *mutex
);

STATUS CODES:

EINVAL The specified mutex is invalid.
EINVAL The mutex has the protocol attribute of PTHREAD_PRIO_PROTECT and the priority of the calling thread is higher than the current priority ceiling.
EBUSY The mutex is already locked.

DESCRIPTION:

NOTES:

11.4.13. pthread_mutex_timedlock - Lock a Mutex with Timeout

CALLING SEQUENCE:

#include <pthread.h>
#include <time.h>
int pthread_mutex_timedlock(
    pthread_mutex_t       *mutex,
    const struct timespec *timeout
);

STATUS CODES:

EINVAL The specified mutex is invalid.
EINVAL The nanoseconds field of timeout is invalid.
EINVAL The mutex has the protocol attribute of PTHREAD_PRIO_PROTECT and the priority of the calling thread is higher than the current priority ceiling.
EDEADLK The current thread already owns the mutex.
ETIMEDOUT The calling thread was unable to obtain the mutex within the specified timeout period.

DESCRIPTION:

NOTES:

11.4.14. pthread_mutex_unlock - Unlock a Mutex

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutex_unlock(
    pthread_mutex_t *mutex
);

STATUS CODES:

EINVAL The specified mutex is invalid.

DESCRIPTION:

NOTES:

11.4.15. pthread_mutex_setprioceiling - Dynamically Set the Priority Ceiling

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutex_setprioceiling(
    pthread_mutex_t *mutex,
    int              prioceiling,
    int             *oldceiling
);

STATUS CODES:

EINVAL The oldceiling pointer parameter is invalid.
EINVAL The prioceiling parameter is an invalid priority.
EINVAL The specified mutex is invalid.

DESCRIPTION:

NOTES:

11.4.16. pthread_mutex_getprioceiling - Get the Current Priority Ceiling

CALLING SEQUENCE:

#include <pthread.h>
int pthread_mutex_getprioceiling(
    pthread_mutex_t *mutex,
    int             *prioceiling
);

STATUS CODES:

EINVAL The prioceiling pointer parameter is invalid.
EINVAL The specified mutex is invalid.

DESCRIPTION:

NOTES: