2017-09-10 19:17:46 +03:00
|
|
|
/*
|
|
|
|
Test FreeRTOS support for core dump.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "soc/cpu.h"
|
|
|
|
#include "freertos/FreeRTOS.h"
|
2021-08-04 10:56:37 +08:00
|
|
|
#include "freertos/task_snapshot.h"
|
2017-09-10 19:17:46 +03:00
|
|
|
#include "unity.h"
|
2018-12-05 20:22:25 +08:00
|
|
|
#include "sdkconfig.h"
|
2017-09-10 19:17:46 +03:00
|
|
|
|
|
|
|
#define TEST_MAX_TASKS_NUM 32
|
|
|
|
|
|
|
|
/* simple test to check that in normal conditions uxTaskGetSnapshotAll does not generate exception */
|
|
|
|
TEST_CASE("Tasks snapshot", "[freertos]")
|
|
|
|
{
|
|
|
|
TaskSnapshot_t tasks[TEST_MAX_TASKS_NUM];
|
|
|
|
UBaseType_t tcb_sz;
|
2018-12-05 20:22:25 +08:00
|
|
|
#ifndef CONFIG_FREERTOS_UNICORE
|
2017-09-10 19:17:46 +03:00
|
|
|
int other_core_id = xPortGetCoreID() == 0 ? 1 : 0;
|
2018-12-05 20:22:25 +08:00
|
|
|
#endif
|
2017-09-10 19:17:46 +03:00
|
|
|
|
2020-11-10 18:40:01 +11:00
|
|
|
// uxTaskGetSnapshotAll is supposed to be called when all tasks on both CPUs are
|
2017-09-10 19:17:46 +03:00
|
|
|
// inactive and can not alter FreeRTOS internal tasks lists, e.g. from panic handler
|
2021-10-16 00:14:27 +08:00
|
|
|
unsigned state = portSET_INTERRUPT_MASK_FROM_ISR();
|
2018-12-05 20:22:25 +08:00
|
|
|
#ifndef CONFIG_FREERTOS_UNICORE
|
2017-09-10 19:17:46 +03:00
|
|
|
esp_cpu_stall(other_core_id);
|
|
|
|
#endif
|
|
|
|
UBaseType_t task_num = uxTaskGetSnapshotAll(tasks, TEST_MAX_TASKS_NUM, &tcb_sz);
|
2018-12-05 20:22:25 +08:00
|
|
|
#ifndef CONFIG_FREERTOS_UNICORE
|
2017-09-10 19:17:46 +03:00
|
|
|
esp_cpu_unstall(other_core_id);
|
|
|
|
#endif
|
2021-10-16 00:14:27 +08:00
|
|
|
portCLEAR_INTERRUPT_MASK_FROM_ISR(state);
|
2017-09-10 19:17:46 +03:00
|
|
|
|
|
|
|
printf("Dumped %d tasks. TCB size %d\n", task_num, tcb_sz);
|
|
|
|
TEST_ASSERT_NOT_EQUAL(0, task_num);
|
|
|
|
TEST_ASSERT_NOT_EQUAL(0, tcb_sz);
|
|
|
|
}
|