freeRTOS task management init
This commit is contained in:
parent
3905b72b08
commit
e61fdd0d5e
24
osal/FreeRTOS/TaskManagement.cpp
Normal file
24
osal/FreeRTOS/TaskManagement.cpp
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
#include <framework/osal/FreeRTOS/TaskManagement.h>
|
||||||
|
|
||||||
|
void TaskManagement::vRequestContextSwitchFromTask() {
|
||||||
|
vTaskDelay(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TaskManagement::requestContextSwitch(
|
||||||
|
CallContext callContext = CallContext::TASK) {
|
||||||
|
if(callContext == CallContext::ISR) {
|
||||||
|
// This function depends on the partmacro.h definition for the specific device
|
||||||
|
vRequestContextSwitchFromISR();
|
||||||
|
} else {
|
||||||
|
vRequestContextSwitchFromTask();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TaskHandle_t TaskManagement::getCurrentTaskHandle() {
|
||||||
|
return xTaskGetCurrentTaskHandle();
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t TaskManagement::getTaskStackHighWatermark(
|
||||||
|
TaskHandle_t task) {
|
||||||
|
return uxTaskGetStackHighWaterMark(task) * sizeof(StackType_t);
|
||||||
|
}
|
64
osal/FreeRTOS/TaskManagement.h
Normal file
64
osal/FreeRTOS/TaskManagement.h
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
#ifndef FRAMEWORK_OSAL_FREERTOS_TASKMANAGEMENT_H_
|
||||||
|
#define FRAMEWORK_OSAL_FREERTOS_TASKMANAGEMENT_H_
|
||||||
|
|
||||||
|
#include <framework/returnvalues/HasReturnvaluesIF.h>
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#include <freertos/FreeRTOS.h>
|
||||||
|
#include <freertos/task.h>
|
||||||
|
}
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Architecture dependant portmacro.h function call.
|
||||||
|
* Should be implemented in bsp.
|
||||||
|
*/
|
||||||
|
extern void vRequestContextSwitchFromISR();
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Used by functions to tell if they are being called from
|
||||||
|
* within an ISR or from a regular task. This is required because FreeRTOS
|
||||||
|
* has different functions for handling semaphores and messages from within
|
||||||
|
* an ISR and task.
|
||||||
|
*/
|
||||||
|
enum class CallContext {
|
||||||
|
TASK = 0x00,//!< task_context
|
||||||
|
ISR = 0xFF //!< isr_context
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class TaskManagement {
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* @brief In this function, a function dependant on the portmacro.h header
|
||||||
|
* function calls to request a context switch can be specified.
|
||||||
|
* This can be used if sending to the queue from an ISR caused a task
|
||||||
|
* to unblock and a context switch is required.
|
||||||
|
*/
|
||||||
|
static void requestContextSwitch(CallContext callContext);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If task preemption in FreeRTOS is disabled, a context switch
|
||||||
|
* can be requested manually by calling this function.
|
||||||
|
*/
|
||||||
|
static void vRequestContextSwitchFromTask(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The current task handle
|
||||||
|
*/
|
||||||
|
static TaskHandle_t getCurrentTaskHandle();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get returns the minimum amount of remaining stack space in words
|
||||||
|
* that was a available to the task since the task started executing.
|
||||||
|
* Please note that the actual value in bytes depends
|
||||||
|
* on the stack depth type.
|
||||||
|
* E.g. on a 32 bit machine, a value of 200 means 800 bytes.
|
||||||
|
* @return Smallest value of stack remaining since the task was started in
|
||||||
|
* words.
|
||||||
|
*/
|
||||||
|
static size_t getTaskStackHighWatermark(
|
||||||
|
TaskHandle_t task = nullptr);
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* FRAMEWORK_OSAL_FREERTOS_TASKMANAGEMENT_H_ */
|
Loading…
Reference in New Issue
Block a user