mirror of
https://github.com/ByteWelder/Tactility.git
synced 2026-04-18 17:35:05 +00:00
Replace LGPL from past commit with Apache License 2.0 for the newly created projects: - in Platforms/* - TactilityKernel Add license headers to source code in: - in Platforms/* - TactilityKernel - TactilityFreeRtos Updated LICENSE.md
55 lines
1.4 KiB
C++
55 lines
1.4 KiB
C++
// SPDX-License-Identifier: Apache-2.0
|
|
#pragma once
|
|
|
|
#include "Lock.h"
|
|
#include "freertoscompat/PortCompat.h"
|
|
#include "freertoscompat/Semaphore.h"
|
|
|
|
#include <memory>
|
|
#include <cassert>
|
|
|
|
namespace tt {
|
|
|
|
/**
|
|
* Wrapper for FreeRTOS xSemaphoreCreateRecursiveMutex
|
|
* Cannot be used from ISR context
|
|
*/
|
|
class RecursiveMutex final : public Lock {
|
|
|
|
std::unique_ptr<std::remove_pointer_t<QueueHandle_t>, SemaphoreHandleDeleter> handle = std::unique_ptr<std::remove_pointer_t<QueueHandle_t>, SemaphoreHandleDeleter>(xSemaphoreCreateRecursiveMutex());
|
|
|
|
public:
|
|
|
|
using Lock::lock;
|
|
|
|
explicit RecursiveMutex() {
|
|
assert(handle != nullptr);
|
|
}
|
|
|
|
~RecursiveMutex() override = default;
|
|
|
|
/**
|
|
* Attempt to lock the mutex. Blocks until timeout passes or lock is acquired.
|
|
* @param[in] timeout
|
|
* @return success result
|
|
*/
|
|
bool lock(TickType_t timeout) const override {
|
|
assert(xPortInIsrContext() == pdFALSE);
|
|
return xSemaphoreTakeRecursive(handle.get(), timeout) == pdPASS;
|
|
}
|
|
|
|
/** Unlock the mutex */
|
|
void unlock() const override {
|
|
assert(xPortInIsrContext() == pdFALSE);
|
|
xSemaphoreGiveRecursive(handle.get());
|
|
}
|
|
|
|
/** @return the owner of the thread */
|
|
TaskHandle_t getOwner() const {
|
|
assert(xPortInIsrContext() == pdFALSE);
|
|
return xSemaphoreGetMutexHolder(handle.get());
|
|
}
|
|
};
|
|
|
|
} // namespace
|