KallistiOS
2.0.0
|
Definitions for a recursive mutex. More...
Go to the source code of this file.
Typedefs | |
typedef mutex_t | recursive_lock_t |
Recursive lock structure. |
Functions | |
recursive_lock_t * | rlock_create () __attribute__((deprecated)) |
Allocate a new recursive lock. | |
void | rlock_destroy (recursive_lock_t *l) __attribute__((deprecated)) |
Destroy a recursive lock. | |
int | rlock_lock (recursive_lock_t *l) __attribute__((deprecated)) |
Lock a recursive lock. | |
int | rlock_lock_timed (recursive_lock_t *l, int timeout) __attribute__((deprecated)) |
Lock a recursive lock (with a timeout). | |
int | rlock_unlock (recursive_lock_t *l) __attribute__((deprecated)) |
Unlock a recursive lock. | |
int | rlock_trylock (recursive_lock_t *l) __attribute__((deprecated)) |
Attempt to lock a recursive lock without blocking. | |
int | rlock_is_locked (recursive_lock_t *l) __attribute__((deprecated)) |
Check if a recursive lock is currently held by any thread. |
Definitions for a recursive mutex.
This file defines a recursive lock mechanism, similar to a mutex, but that a single thread can obtain as many times as it wants. A single thread is still limited to holding the lock at a time, but it can hold it an "unlimited" number of times (actually limited to INT_MAX, but who's counting).
These are now just wrappers around the MUTEX_TYPE_RECURSIVE that is now provided and will be removed at some point in the future. Please update your code to use that type instead.
typedef mutex_t recursive_lock_t |
Recursive lock structure.
Recursive locks are just a simple wrapper around mutexes at this point. You should not use this type in any new code.
recursive_lock_t* rlock_create | ( | ) |
Allocate a new recursive lock.
This function allocates a new recurisve lock that is initially not locked.
void rlock_destroy | ( | recursive_lock_t * | l | ) |
Destroy a recursive lock.
This function cleans up a recursive lock. It is an error to attempt to destroy a locked recursive lock.
l | The recursive lock to destroy. It must be unlocked. |
int rlock_is_locked | ( | recursive_lock_t * | l | ) |
Check if a recursive lock is currently held by any thread.
This function checks whether or not a lock is currently held by any thread, including the calling thread. Note that this is NOT a safe way to check if a lock will be held by the time you get around to locking it.
TRUE | If the lock is held by any thread. |
FALSE | If the lock is not currently held by any thread. |
int rlock_lock | ( | recursive_lock_t * | l | ) |
Lock a recursive lock.
This function attempts to lock the requested lock, and if it cannot it will block until that is possible.
l | The recursive lock to lock. |
-1 | On error, errno will be set to EPERM if this function is called inside an interrupt, or EINTR if it is interrupted. |
0 | On success. |
int rlock_lock_timed | ( | recursive_lock_t * | l, |
int | timeout | ||
) |
Lock a recursive lock (with a timeout).
This function attempts to lock the requested lock, and if it cannot it will block until either it is possible to acquire the lock or timeout milliseconds have elapsed.
l | The recursive lock to lock. |
timeout | The maximum number of milliseconds to wait. 0 is an unlimited timeout (equivalent to rlock_lock). |
-1 | On error, errno will be set to EPERM if this function is called inside an interrupt, EINTR if the function is interrupted, or EAGAIN if the timeout expires. |
0 | On success. |
int rlock_trylock | ( | recursive_lock_t * | l | ) |
Attempt to lock a recursive lock without blocking.
This function attempts to lock a recursive lock without blocking. This function, unlike rlock_lock and rlock_lock_timed is safe to call inside an interrupt.
l | The recursive lock to lock. |
-1 | On error, errno will be set to EWOULDBLOCK if the lock is currently held by another thread. |
0 | On success. |
int rlock_unlock | ( | recursive_lock_t * | l | ) |
Unlock a recursive lock.
This function releases the lock one time from the current thread.
l | The recursive lock to unlock. |
-1 | On error, errno will be set to EPERM if the lock is not held by the calling thread. |
0 | On success. |