63 lines
1.1 KiB
C
63 lines
1.1 KiB
C
|
/**
|
||
|
* @file mutex.h
|
||
|
* FuriMutex
|
||
|
*/
|
||
|
#pragma once
|
||
|
|
||
|
#include "base.h"
|
||
|
#include "thread.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
typedef enum {
|
||
|
FuriMutexTypeNormal,
|
||
|
FuriMutexTypeRecursive,
|
||
|
} FuriMutexType;
|
||
|
|
||
|
typedef void FuriMutex;
|
||
|
|
||
|
/** Allocate FuriMutex
|
||
|
*
|
||
|
* @param[in] type The mutex type
|
||
|
*
|
||
|
* @return pointer to FuriMutex instance
|
||
|
*/
|
||
|
FuriMutex* furi_mutex_alloc(FuriMutexType type);
|
||
|
|
||
|
/** Free FuriMutex
|
||
|
*
|
||
|
* @param instance The pointer to FuriMutex instance
|
||
|
*/
|
||
|
void furi_mutex_free(FuriMutex* instance);
|
||
|
|
||
|
/** Acquire mutex
|
||
|
*
|
||
|
* @param instance The pointer to FuriMutex instance
|
||
|
* @param[in] timeout The timeout
|
||
|
*
|
||
|
* @return The furi status.
|
||
|
*/
|
||
|
FuriStatus furi_mutex_acquire(FuriMutex* instance, uint32_t timeout);
|
||
|
|
||
|
/** Release mutex
|
||
|
*
|
||
|
* @param instance The pointer to FuriMutex instance
|
||
|
*
|
||
|
* @return The furi status.
|
||
|
*/
|
||
|
FuriStatus furi_mutex_release(FuriMutex* instance);
|
||
|
|
||
|
/** Get mutex owner thread id
|
||
|
*
|
||
|
* @param instance The pointer to FuriMutex instance
|
||
|
*
|
||
|
* @return The furi thread identifier.
|
||
|
*/
|
||
|
FuriThreadId furi_mutex_get_owner(FuriMutex* instance);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|