104 lines
3.8 KiB
C
104 lines
3.8 KiB
C
/* Includes ------------------------------------------------------------------*/
|
|
#include "FreeRTOS.h"
|
|
#include "main.h"
|
|
#include "stdio.h"
|
|
#include "task.h"
|
|
|
|
/* FreeRTOS Heap */
|
|
uint8_t ucHeap[configTOTAL_HEAP_SIZE];
|
|
|
|
void SysTick_Handler(void) {
|
|
#if (INCLUDE_xTaskGetSchedulerState == 1)
|
|
if (xTaskGetSchedulerState() != taskSCHEDULER_NOT_STARTED) {
|
|
#endif /* INCLUDE_xTaskGetSchedulerState */
|
|
xPortSysTickHandler();
|
|
#if (INCLUDE_xTaskGetSchedulerState == 1)
|
|
}
|
|
#endif
|
|
}
|
|
|
|
void vApplicationStackOverflowHook(TaskHandle_t xTask, char *pcTaskName) {
|
|
/* Run time stack overflow checking is performed if
|
|
configCHECK_FOR_STACK_OVERFLOW is defined to 1 or 2. This hook function is
|
|
called if a stack overflow is detected. */
|
|
|
|
(void)xTask;
|
|
(void)pcTaskName;
|
|
taskDISABLE_INTERRUPTS();
|
|
while (1) {
|
|
printf("Stack overflow\r\n");
|
|
__set_PRIMASK(1);
|
|
|
|
SysTick->CTRL = 0;
|
|
SysTick->LOAD = 0;
|
|
SysTick->VAL = 0;
|
|
|
|
HAL_RCC_DeInit();
|
|
|
|
for (int i = 0; i < 8; i++) {
|
|
NVIC->ICER[i] = 0xFFFFFFFF;
|
|
NVIC->ICPR[i] = 0xFFFFFFFF;
|
|
}
|
|
|
|
__set_PRIMASK(0);
|
|
|
|
__set_MSP(*(__IO uint32_t *)0x1FFF0000);
|
|
void (*sys_mem_boot_jump)(void) =
|
|
(void (*)(void))(*((uint32_t *)0x1FFF0004));
|
|
sys_mem_boot_jump();
|
|
pcTaskName = NULL;
|
|
*pcTaskName = 0;
|
|
}
|
|
}
|
|
|
|
/* configSUPPORT_STATIC_ALLOCATION is set to 1, so the application must provide
|
|
* an implementation of vApplicationGetIdleTaskMemory() to provide the memory
|
|
* that is used by the Idle task. */
|
|
void vApplicationGetIdleTaskMemory(StaticTask_t **ppxIdleTaskTCBBuffer,
|
|
StackType_t **ppxIdleTaskStackBuffer,
|
|
uint32_t *pulIdleTaskStackSize) {
|
|
/* If the buffers to be provided to the Idle task are declared inside this
|
|
* function then they must be declared static - otherwise they will be
|
|
* allocated on the stack and so not exists after this function exits. */
|
|
static StaticTask_t xIdleTaskTCB;
|
|
static StackType_t uxIdleTaskStack[configMINIMAL_STACK_SIZE];
|
|
|
|
/* Pass out a pointer to the StaticTask_t structure in which the Idle task's
|
|
state will be stored. */
|
|
*ppxIdleTaskTCBBuffer = &xIdleTaskTCB;
|
|
|
|
/* Pass out the array that will be used as the Idle task's stack. */
|
|
*ppxIdleTaskStackBuffer = uxIdleTaskStack;
|
|
|
|
/* Pass out the size of the array pointed to by *ppxIdleTaskStackBuffer.
|
|
Note that, as the array is necessarily of type StackType_t,
|
|
configMINIMAL_STACK_SIZE is specified in words, not bytes. */
|
|
*pulIdleTaskStackSize = configMINIMAL_STACK_SIZE;
|
|
}
|
|
|
|
/* configSUPPORT_STATIC_ALLOCATION and configUSE_TIMERS are both set to 1, so
|
|
* the application must provide an implementation of
|
|
* vApplicationGetTimerTaskMemory() to provide the memory that is used by the
|
|
* Timer service task. */
|
|
void vApplicationGetTimerTaskMemory(StaticTask_t **ppxTimerTaskTCBBuffer,
|
|
StackType_t **ppxTimerTaskStackBuffer,
|
|
uint32_t *pulTimerTaskStackSize) {
|
|
/* If the buffers to be provided to the Timer task are declared inside this
|
|
* function then they must be declared static - otherwise they will be
|
|
* allocated on the stack and so not exists after this function exits. */
|
|
static StaticTask_t xTimerTaskTCB;
|
|
static StackType_t uxTimerTaskStack[configTIMER_TASK_STACK_DEPTH];
|
|
|
|
/* Pass out a pointer to the StaticTask_t structure in which the Timer
|
|
task's state will be stored. */
|
|
*ppxTimerTaskTCBBuffer = &xTimerTaskTCB;
|
|
|
|
/* Pass out the array that will be used as the Timer task's stack. */
|
|
*ppxTimerTaskStackBuffer = uxTimerTaskStack;
|
|
|
|
/* Pass out the size of the array pointed to by *ppxTimerTaskStackBuffer.
|
|
Note that, as the array is necessarily of type StackType_t,
|
|
configTIMER_TASK_STACK_DEPTH is specified in words, not bytes. */
|
|
*pulTimerTaskStackSize = configTIMER_TASK_STACK_DEPTH;
|
|
}
|