Skip to content
Snippets Groups Projects
main.c 2.82 KiB
Newer Older
  • Learn to ignore specific revisions
  • #include "modules/modules.h"
    
    #include "modules/log.h"
    
    koalo's avatar
    koalo committed
    #include "modules/filesystem.h"
    
    #include "card10-version.h"
    
    #include "FreeRTOS.h"
    #include "task.h"
    
    #include <stdlib.h>
    
    koalo's avatar
    koalo committed
    #include <string.h>
    
    TaskHandle_t dispatcher_task_id;
    
    schneider's avatar
    schneider committed
    void vBleTask(void *pvParameters);
    
    koalo's avatar
    koalo committed
    #define BLEMAXCFGBYTES 100
    int bleShallStart(void)
    {
    	int bleConfigFile = epic_file_open("ble.txt", "r");
    	if (bleConfigFile < 0) {
    		LOG_INFO(
    			"startup",
    			"can not open ble.txt -> BLE is not started"
    		);
    		epic_file_close(bleConfigFile);
    		return 0;
    	}
    
    	char cfgBuf[BLEMAXCFGBYTES + 1];
    	int readNum = epic_file_read(bleConfigFile, cfgBuf, BLEMAXCFGBYTES);
    	epic_file_close(bleConfigFile);
    	if (readNum < 0) {
    		LOG_INFO(
    			"startup",
    			"can not read ble.txt -> BLE is not started"
    		);
    		return 0;
    	}
    	cfgBuf[readNum] = '\0';
    
    	char bleActiveStr[]              = "active=true";
    	cfgBuf[sizeof(bleActiveStr) - 1] = '\0';
    
    	if (strcmp(cfgBuf, "active=true") != 0) {
    		LOG_INFO(
    			"startup",
    			"ble.txt is not \"active=true\" -> BLE is not started"
    		);
    		return 0;
    	}
    
    	LOG_INFO("startup", "ble.txt is \"active=true\" -> BLE is starting");
    	return 1;
    }
    
    
    rahix's avatar
    rahix committed
    int main(void)
    {
    
    	LOG_INFO("startup", "Epicardium startup ...");
    
    	LOG_INFO("startup", "Version " CARD10_VERSION);
    
    	LOG_INFO("startup", "Initializing hardware ...");
    
    	hardware_early_init();
    
    
    	LOG_INFO("startup", "Initializing tasks ...");
    
    
    	/* Serial */
    	if (xTaskCreate(
    
    rahix's avatar
    rahix committed
    		    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 + 4,
    
    		    NULL) != pdPASS) {
    
    		LOG_CRIT("startup", "Failed to create %s task!", "PMIC");
    
    	if (xTaskCreate(
    
    rahix's avatar
    rahix committed
    		    vApiDispatcher,
    		    (const char *)"API Dispatcher",
    
    		    configMINIMAL_STACK_SIZE * 16,
    
    rahix's avatar
    rahix committed
    		    NULL,
    		    tskIDLE_PRIORITY + 2,
    		    &dispatcher_task_id) != pdPASS) {
    
    q3k's avatar
    q3k committed
    		LOG_CRIT(
    			"startup",
    			"Failed to create %s task!",
    			"API Dispatcher"
    		);
    
    schneider's avatar
    schneider committed
    	/* BLE */
    
    koalo's avatar
    koalo committed
    	if (bleShallStart()) {
    		if (xTaskCreate(
    			    vBleTask,
    			    (const char *)"BLE",
    			    configMINIMAL_STACK_SIZE * 10,
    			    NULL,
    			    tskIDLE_PRIORITY + 1,
    			    NULL) != pdPASS) {
    			LOG_CRIT("startup", "Failed to create %s task!", "BLE");
    			abort();
    		}
    
    	/* Lifecycle */
    	if (xTaskCreate(
    		    vLifecycleTask,
    		    (const char *)"Lifecycle",
    		    configMINIMAL_STACK_SIZE * 4,
    		    NULL,
    		    tskIDLE_PRIORITY + 1,
    		    NULL) != pdPASS) {
    		LOG_CRIT("startup", "Failed to create %s task!", "Lifecycle");
    		abort();
    
    q3k's avatar
    q3k committed
    	}
    
    
    	LOG_INFO("startup", "Starting FreeRTOS ...");
    
    	vTaskStartScheduler();
    
    
    	LOG_CRIT("startup", "FreeRTOS did not start due to unknown error!");
    	abort();
    
    rahix's avatar
    rahix committed
    }