Go to the documentation of this file.
134 #if TN_MUTEX_DEADLOCK_DETECT
293 #endif // _TN_MUTEX_H
struct TN_ListItem mutex_queue
To include in task's locked mutexes list (if any)
enum TN_RCode tn_mutex_create(struct TN_Mutex *mutex, enum TN_MutexProtocol protocol, int ceil_priority)
Construct the mutex.
enum TN_RCode tn_mutex_lock_polling(struct TN_Mutex *mutex)
The same as tn_mutex_lock() with zero timeout.
@ TN_MUTEX_PROT_CEILING
Mutex uses priority ceiling protocol.
enum TN_RCode tn_mutex_unlock(struct TN_Mutex *mutex)
Unlock mutex.
int cnt
Lock count (for recursive locking)
enum TN_RCode tn_mutex_lock(struct TN_Mutex *mutex, TN_TickCnt timeout)
Lock mutex.
enum TN_ObjId id_mutex
id for object validity verification.
int ceil_priority
Used if only protocol is #TN_MUTEX_PROT_CEILING: maximum priority of task that may lock the mutex.
struct TN_Task * holder
Current mutex owner (task that locked mutex)
struct TN_ListItem wait_queue
List of tasks that wait a mutex.
TN_RCode
Result code returned by kernel services.
@ TN_MUTEX_PROT_INHERIT
Mutex uses priority inheritance protocol.
TN_MutexProtocol
Mutex protocol for avoid priority inversion.
unsigned long TN_TickCnt
Type for system tick count, it is used by the kernel to represent absolute tick count value as well a...
TN_ObjId
Magic number for object validity verification.
struct TN_ListItem deadlock_list
List of other mutexes involved in deadlock (normally, this list is empty)
enum TN_MutexProtocol protocol
Mutex protocol: priority ceiling or priority inheritance.
Circular doubly linked list item, for internal kernel usage.
enum TN_RCode tn_mutex_delete(struct TN_Mutex *mutex)
Destruct mutex.