mirror of
https://github.com/ByteWelder/Tactility.git
synced 2026-02-18 19:03:16 +00:00
* **New Features** * Plugin-style modules for platforms and devices with start/stop lifecycle and a runtime-consumable device tree array. * **Refactor** * Consolidated initialization into a kernel/module startup flow. * Generated devicetree artifacts moved to the build Generated directory. * **Changes** * Removed legacy no-op registration hooks and I2C lock/unlock wrappers. * Driver ownership and private state moved to explicit module/owner model. * Added ERROR_NOT_ALLOWED error code.
60 lines
1.6 KiB
C
60 lines
1.6 KiB
C
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
#pragma once
|
|
|
|
#include <tactility/freertos/semphr.h>
|
|
#include <tactility/check.h>
|
|
#include <stdbool.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
struct RecursiveMutex {
|
|
QueueHandle_t handle;
|
|
};
|
|
|
|
inline static void recursive_mutex_construct(struct RecursiveMutex* mutex) {
|
|
check(mutex->handle == NULL);
|
|
mutex->handle = xSemaphoreCreateRecursiveMutex();
|
|
}
|
|
|
|
inline static void recursive_mutex_destruct(struct RecursiveMutex* mutex) {
|
|
check(mutex->handle != NULL);
|
|
check(xPortInIsrContext() != pdTRUE);
|
|
vSemaphoreDelete(mutex->handle);
|
|
mutex->handle = NULL;
|
|
}
|
|
|
|
inline static void recursive_mutex_lock(struct RecursiveMutex* mutex) {
|
|
check(xPortInIsrContext() != pdTRUE);
|
|
xSemaphoreTakeRecursive(mutex->handle, portMAX_DELAY);
|
|
}
|
|
|
|
inline static bool recursive_mutex_is_locked(struct RecursiveMutex* mutex) {
|
|
if (xPortInIsrContext() == pdTRUE) {
|
|
return xSemaphoreGetMutexHolderFromISR(mutex->handle) != NULL;
|
|
} else {
|
|
return xSemaphoreGetMutexHolder(mutex->handle) != NULL;
|
|
}
|
|
}
|
|
|
|
inline static bool recursive_mutex_try_lock(struct RecursiveMutex* mutex) {
|
|
check(xPortInIsrContext() != pdTRUE);
|
|
return xSemaphoreTakeRecursive(mutex->handle, 0) == pdTRUE;
|
|
}
|
|
|
|
inline static bool recursive_mutex_try_lock_timed(struct RecursiveMutex* mutex, TickType_t timeout) {
|
|
check(xPortInIsrContext() != pdTRUE);
|
|
return xSemaphoreTakeRecursive(mutex->handle, timeout) == pdTRUE;
|
|
}
|
|
|
|
inline static void recursive_mutex_unlock(struct RecursiveMutex* mutex) {
|
|
check(xPortInIsrContext() != pdTRUE);
|
|
xSemaphoreGiveRecursive(mutex->handle);
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|