2020-12-14 11:17:22 +01:00
|
|
|
#ifndef FSFW_OSAL_FREERTOS_BINSEMAPHUSINGTASK_H_
|
|
|
|
#define FSFW_OSAL_FREERTOS_BINSEMAPHUSINGTASK_H_
|
2020-09-18 13:15:14 +02:00
|
|
|
|
|
|
|
#include "../../returnvalues/HasReturnvaluesIF.h"
|
|
|
|
#include "../../tasks/SemaphoreIF.h"
|
|
|
|
|
|
|
|
#include <freertos/FreeRTOS.h>
|
|
|
|
#include <freertos/task.h>
|
|
|
|
|
2020-12-14 11:17:22 +01:00
|
|
|
// todo: does not work for older FreeRTOS version, so we should
|
|
|
|
// actually check whether tskKERNEL_VERSION_MAJOR is larger than.. 7 or 8 ?
|
|
|
|
|
2020-09-18 13:15:14 +02:00
|
|
|
/**
|
|
|
|
* @brief Binary Semaphore implementation using the task notification value.
|
|
|
|
* The notification value should therefore not be used
|
2020-12-14 11:17:22 +01:00
|
|
|
* for other purposes!
|
2020-09-18 13:15:14 +02:00
|
|
|
* @details
|
|
|
|
* Additional information: https://www.freertos.org/RTOS-task-notifications.html
|
|
|
|
* and general semaphore documentation.
|
2020-12-14 11:17:22 +01:00
|
|
|
* This semaphore is bound to the task it is created in!
|
|
|
|
* Take care of building this class with the correct executing task,
|
|
|
|
* (for example in the initializeAfterTaskCreation() function) or
|
|
|
|
* by calling refreshTaskHandle() with the correct executing task.
|
2020-09-18 13:15:14 +02:00
|
|
|
*/
|
|
|
|
class BinarySemaphoreUsingTask: public SemaphoreIF,
|
|
|
|
public HasReturnvaluesIF {
|
|
|
|
public:
|
|
|
|
static const uint8_t INTERFACE_ID = CLASS_ID::SEMAPHORE_IF;
|
|
|
|
|
|
|
|
//! @brief Default ctor
|
|
|
|
BinarySemaphoreUsingTask();
|
|
|
|
//! @brief Default dtor
|
|
|
|
virtual~ BinarySemaphoreUsingTask();
|
|
|
|
|
2020-12-14 11:17:22 +01:00
|
|
|
/**
|
|
|
|
* This function can be used to get the correct task handle from the
|
|
|
|
* currently executing task.
|
|
|
|
*
|
|
|
|
* This is required because the task notification value will be used
|
|
|
|
* as a binary semaphore, and the semaphore might be created by another
|
|
|
|
* task.
|
|
|
|
*/
|
|
|
|
void refreshTaskHandle();
|
|
|
|
|
2020-09-18 13:15:14 +02:00
|
|
|
ReturnValue_t acquire(TimeoutType timeoutType = TimeoutType::BLOCKING,
|
|
|
|
uint32_t timeoutMs = portMAX_DELAY) override;
|
|
|
|
ReturnValue_t release() override;
|
|
|
|
uint8_t getSemaphoreCounter() const override;
|
|
|
|
static uint8_t getSemaphoreCounter(TaskHandle_t taskHandle);
|
|
|
|
static uint8_t getSemaphoreCounterFromISR(TaskHandle_t taskHandle,
|
|
|
|
BaseType_t* higherPriorityTaskWoken);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Same as acquire() with timeout in FreeRTOS ticks.
|
|
|
|
* @param timeoutTicks
|
|
|
|
* @return - @c RETURN_OK on success
|
|
|
|
* - @c RETURN_FAILED on failure
|
|
|
|
*/
|
|
|
|
ReturnValue_t acquireWithTickTimeout(
|
|
|
|
TimeoutType timeoutType = TimeoutType::BLOCKING,
|
|
|
|
TickType_t timeoutTicks = portMAX_DELAY);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get handle to the task related to the semaphore.
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
TaskHandle_t getTaskHandle();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Wrapper function to give back semaphore from handle
|
|
|
|
* @param semaphore
|
|
|
|
* @return - @c RETURN_OK on success
|
|
|
|
* - @c RETURN_FAILED on failure
|
|
|
|
*/
|
|
|
|
static ReturnValue_t release(TaskHandle_t taskToNotify);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Wrapper function to give back semaphore from handle when called from an ISR
|
|
|
|
* @param semaphore
|
|
|
|
* @param higherPriorityTaskWoken This will be set to pdPASS if a task with
|
|
|
|
* a higher priority was unblocked. A context switch should be requested
|
|
|
|
* from an ISR if this is the case (see TaskManagement functions)
|
|
|
|
* @return - @c RETURN_OK on success
|
|
|
|
* - @c RETURN_FAILED on failure
|
|
|
|
*/
|
|
|
|
static ReturnValue_t releaseFromISR(TaskHandle_t taskToNotify,
|
2020-12-14 11:17:22 +01:00
|
|
|
BaseType_t* higherPriorityTaskWoken);
|
2020-09-18 13:15:14 +02:00
|
|
|
|
|
|
|
protected:
|
|
|
|
TaskHandle_t handle;
|
|
|
|
};
|
|
|
|
|
2020-12-14 11:17:22 +01:00
|
|
|
#endif /* FSFW_OSAL_FREERTOS_BINSEMAPHUSINGTASK_H_ */
|