Newer
Older
#include <Heart.h>
#include "GUI_Paint.h"
TaskHandle_t dispatcher_task_id;
/*
* API dispatcher task. This task will sleep until an API call is issued and
* then wake up to dispatch it.
*/
LOG_DEBUG("dispatcher", "Ready.");
if (api_dispatcher_poll()) {
api_dispatcher_exec();
}
ulTaskNotifyTake(pdTRUE, portMAX_DELAY);
LOG_INFO("startup", "Epicardium startup ...");
Paint_DrawImage(Heart, 0, 0, 160, 80);
LCD_Update();
/* TODO: Move this to its own function */
SCB->SCR |= SCB_SCR_SEVONPEND_Msk;
if (cdcacm_init() < 0) {
LOG_ERR("startup", "USB-Serial unavailable");
}
LOG_INFO("startup", "Initializing tasks ...");
vSerialTask,
(const char *)"Serial",
configMINIMAL_STACK_SIZE,
NULL,
tskIDLE_PRIORITY + 1,
NULL) != pdPASS) {
LOG_CRIT("startup", "Failed to create %s task!", "Serial");
/* PMIC */
if (xTaskCreate(
vPmicTask,
(const char *)"PMIC",
configMINIMAL_STACK_SIZE,
NULL,
tskIDLE_PRIORITY + 1,
NULL) != pdPASS) {
LOG_CRIT("startup", "Failed to create %s task!", "PMIC");
NULL,
tskIDLE_PRIORITY + 2,
&dispatcher_task_id) != pdPASS) {
LOG_CRIT("startup", "Failed to create %s task!", "API Dispatcher");
LOG_INFO("startup", "Initializing dispatcher ...");
LOG_INFO("startup", "Starting core1 payload ...");
LOG_INFO("startup", "Starting FreeRTOS ...");
LOG_CRIT("startup", "FreeRTOS did not start due to unknown error!");
abort();