Skip to content
Snippets Groups Projects
Select Git revision
  • schneider/ir
  • master default protected
  • rahix/user-space-ctx
  • schneider/iaq-python
  • schneider/ble-mini-demo
  • schneider/ble-ecg-stream-visu
  • schneider/mp-exception-print
  • schneider/sleep-display
  • schneider/deepsleep4
  • schneider/deepsleep2
  • schneider/deepsleep
  • schneider/ble-central
  • rahix/bluetooth-app-favorite
  • schneider/v1.17-changelog
  • schneider/ancs
  • schneider/png
  • schneider/freertos-list-debug
  • schneider/212-reset-hardware-when-entering-repl
  • schneider/bonding-fail-if-full
  • schneider/ble-fixes-2020-3
  • v1.18
  • v1.17
  • v1.16
  • v1.15
  • v1.14
  • v1.13
  • v1.12
  • v1.11
  • v1.10
  • v1.9
  • v1.8
  • v1.7
  • v1.6
  • v1.5
  • v1.4
  • v1.3
  • v1.2
  • v1.1
  • v1.0
  • release-1
40 results

main.c

Blame
  • main.c 4.25 KiB
    #include "modules/modules.h"
    #include "modules/log.h"
    #include "modules/filesystem.h"
    #include "modules/config.h"
    #include "card10-version.h"
    
    #include "gfx.h"
    #include "display.h"
    #include "leds.h"
    #include "version-splash.h"
    
    #include "FreeRTOS.h"
    #include "task.h"
    #include "mxc_delay.h"
    
    #include <stdlib.h>
    #include <string.h>
    
    int main(void)
    {
    	watchdog_init();
    
    	LOG_INFO("startup", "Epicardium startup ...");
    	LOG_INFO("startup", "Version " CARD10_VERSION);
    
    	LOG_DEBUG("startup", "Initializing hardware ...");
    	hardware_early_init();
    
    	load_config();
    
    	/*
    	 * Version Splash
    	 */
    	const char *version_buf = CARD10_VERSION;
    
    	//LED feedback in case of dead display
    	epic_leds_set(11, 0, 0, 1);
    	epic_leds_set(12, 0, 0, 1);
    	epic_leds_set(13, 0, 0, 1);
    	epic_leds_set(14, 0, 0, 1);
    	for (int i = 0; i < 3; i++) {
    		epic_leds_set_rocket(i, 31);
    		mxc_delay(166666);
    		epic_leds_set_rocket(i, 0);
    	}
    	epic_leds_clear_all(0, 0, 0);
    
    	epic_disp_clear(0x0000);
    
    	if (strcmp(CARD10_VERSION, "v1.16") == 0) {
    		gfx_copy_region(
    			&display_screen,
    			0,
    			0,
    			160,
    			80,
    			GFX_RAW,
    			sizeof(version_splash),
    			version_splash
    		);
    	} else {
    		const int off = (160 - (int)strlen(version_buf) * 14) / 2;
    		epic_disp_print(10, 20, "Epicardium", 0xfe20, 0x0000);
    		epic_disp_print(
    			off > 0 ? off : 0, 40, version_buf, 0xfe20, 0x0000
    		);
    	}
    	epic_disp_update();
    	mxc_delay(2000000);
    
    	LOG_DEBUG("startup", "Initializing tasks ...");
    
    	/* Serial */
    	if (xTaskCreate(
    		    vSerialTask,
    		    (const char *)"Serial",
    		    configMINIMAL_STACK_SIZE * 2,
    		    NULL,
    		    tskIDLE_PRIORITY + 3,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "Serial");
    	}
    
    	/* PMIC */
    	if (xTaskCreate(
    		    vPmicTask,
    		    (const char *)"PMIC",
    		    configMINIMAL_STACK_SIZE,
    		    NULL,
    		    tskIDLE_PRIORITY + 4,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "PMIC");
    	}
    
    	/* BHI160 */
    	if (xTaskCreate(
    		    vBhi160Task,
    		    (const char *)"BHI160 Driver",
    		    configMINIMAL_STACK_SIZE * 2,
    		    NULL,
    		    tskIDLE_PRIORITY + 1,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "BHI160");
    	}
    
    	/* MAX30001 */
    	if (xTaskCreate(
    		    vMAX30001Task,
    		    (const char *)"MAX30001 Driver",
    		    configMINIMAL_STACK_SIZE * 2,
    		    NULL,
    		    tskIDLE_PRIORITY + 1,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "MAX30001");
    	}
    	/* MAX86150 */
    	if (xTaskCreate(
    		    vMAX86150Task,
    		    (const char *)"MAX86150 Driver",
    		    configMINIMAL_STACK_SIZE * 2,
    		    NULL,
    		    tskIDLE_PRIORITY + 1,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "MAX86150");
    	}
    	/* API */
    	if (xTaskCreate(
    		    vApiDispatcher,
    		    (const char *)"API Dispatcher",
    		    configMINIMAL_STACK_SIZE * 16,
    		    NULL,
    		    tskIDLE_PRIORITY + 2,
    		    &dispatcher_task_id) != pdPASS) {
    		panic("Failed to create %s task!", "API Dispatcher");
    	}
    	/* Interrupts */
    	if (xTaskCreate(
    		    vInterruptsTask,
    		    (const char *)"Interrupt Dispatcher",
    		    configMINIMAL_STACK_SIZE,
    		    NULL,
    		    tskIDLE_PRIORITY + 2,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "Interrupt Dispatcher");
    	}
    
    	/* BLE */
    	if (ble_shall_start()) {
    		if (xTaskCreate(
    			    vBleTask,
    			    (const char *)"BLE",
    			    configMINIMAL_STACK_SIZE * 10,
    			    NULL,
    			    tskIDLE_PRIORITY + 3,
    			    NULL) != pdPASS) {
    			panic("Failed to create %s task!", "BLE");
    		}
    	}
    
    	/* LEDs */
    	if (xTaskCreate(
    		    vLedTask,
    		    (const char *)"LED",
    		    configMINIMAL_STACK_SIZE,
    		    NULL,
    		    tskIDLE_PRIORITY + 1,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "LED");
    	}
    
    	/* Lifecycle */
    	if (xTaskCreate(
    		    vLifecycleTask,
    		    (const char *)"Lifecycle",
    		    configMINIMAL_STACK_SIZE * 4,
    		    NULL,
    		    tskIDLE_PRIORITY + 3,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "Lifecycle");
    	}
    
    	/* Work Queue */
    	if (xTaskCreate(
    		    vWorkQueueTask,
    		    (const char *)"Work Queue",
    		    configMINIMAL_STACK_SIZE,
    		    NULL,
    		    tskIDLE_PRIORITY + 1,
    		    NULL) != pdPASS) {
    		panic("Failed to create %s task!", "Work Queue");
    	}
    	workqueue_init();
    
    	/*
    	 * Initialize serial driver data structures.
    	 */
    	serial_init();
    
    	LOG_DEBUG("startup", "Starting FreeRTOS ...");
    	vTaskStartScheduler();
    
    	panic("FreeRTOS did not start due to unknown error!");
    }