main.c 3.38 KB
Newer Older
1
#include "modules/modules.h"
2
#include "modules/log.h"
koalo's avatar
koalo committed
3
#include "modules/filesystem.h"
swym's avatar
swym committed
4
#include "modules/config.h"
Rahix's avatar
Rahix committed
5
#include "card10-version.h"
schneider's avatar
schneider committed
6

7 8 9 10
#include "gfx.h"
#include "display.h"
#include "version-splash.h"

Rahix's avatar
Rahix committed
11 12
#include "FreeRTOS.h"
#include "task.h"
13
#include "mxc_delay.h"
Rahix's avatar
Rahix committed
14

15
#include <stdlib.h>
koalo's avatar
koalo committed
16
#include <string.h>
17

Rahix's avatar
Rahix committed
18 19
int main(void)
{
20 21
	watchdog_init();

22
	LOG_INFO("startup", "Epicardium startup ...");
Rahix's avatar
Rahix committed
23
	LOG_INFO("startup", "Version " CARD10_VERSION);
24

25
	LOG_DEBUG("startup", "Initializing hardware ...");
26 27
	hardware_early_init();

swym's avatar
swym committed
28 29
	load_config();

30 31 32 33
	/*
	 * Version Splash
	 */
	const char *version_buf = CARD10_VERSION;
34
	mxc_delay(500000);
35
	epic_disp_clear(0x0000);
36 37 38 39 40 41 42 43 44 45 46
	if (strcmp(CARD10_VERSION, "v1.10") == 0) {
		gfx_copy_region_raw(
			&display_screen, 0, 0, 160, 80, 2, 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
		);
	}
ch3's avatar
ch3 committed
47 48
	epic_disp_update();
	mxc_delay(2000000);
49

50
	LOG_DEBUG("startup", "Initializing tasks ...");
Rahix's avatar
Rahix committed
51 52 53

	/* Serial */
	if (xTaskCreate(
Rahix's avatar
Rahix committed
54 55
		    vSerialTask,
		    (const char *)"Serial",
56
		    configMINIMAL_STACK_SIZE * 2,
Rahix's avatar
Rahix committed
57
		    NULL,
58
		    tskIDLE_PRIORITY + 3,
Rahix's avatar
Rahix committed
59
		    NULL) != pdPASS) {
60
		LOG_CRIT("startup", "Failed to create %s task!", "Serial");
Rahix's avatar
Rahix committed
61 62 63
		abort();
	}

64 65 66 67 68 69
	/* PMIC */
	if (xTaskCreate(
		    vPmicTask,
		    (const char *)"PMIC",
		    configMINIMAL_STACK_SIZE,
		    NULL,
Rahix's avatar
Rahix committed
70
		    tskIDLE_PRIORITY + 4,
71
		    NULL) != pdPASS) {
72
		LOG_CRIT("startup", "Failed to create %s task!", "PMIC");
73 74 75
		abort();
	}

76 77 78 79 80 81 82 83
	/* BHI160 */
	if (xTaskCreate(
		    vBhi160Task,
		    (const char *)"BHI160 Driver",
		    configMINIMAL_STACK_SIZE * 2,
		    NULL,
		    tskIDLE_PRIORITY + 1,
		    NULL) != pdPASS) {
koalo's avatar
koalo committed
84
		LOG_CRIT("startup", "Failed to create %s task!", "BHI160");
85 86 87
		abort();
	}

schneider's avatar
schneider committed
88 89 90 91 92 93 94 95 96 97 98
	/* MAX30001 */
	if (xTaskCreate(
		    vMAX30001Task,
		    (const char *)"MAX30001 Driver",
		    configMINIMAL_STACK_SIZE * 2,
		    NULL,
		    tskIDLE_PRIORITY + 1,
		    NULL) != pdPASS) {
		LOG_CRIT("startup", "Failed to create %s task!", "MAX30001");
		abort();
	}
99
	/* API */
Rahix's avatar
Rahix committed
100
	if (xTaskCreate(
Rahix's avatar
Rahix committed
101 102
		    vApiDispatcher,
		    (const char *)"API Dispatcher",
swym's avatar
swym committed
103
		    configMINIMAL_STACK_SIZE * 16,
Rahix's avatar
Rahix committed
104 105 106
		    NULL,
		    tskIDLE_PRIORITY + 2,
		    &dispatcher_task_id) != pdPASS) {
q3k's avatar
q3k committed
107 108 109 110 111
		LOG_CRIT(
			"startup",
			"Failed to create %s task!",
			"API Dispatcher"
		);
Rahix's avatar
Rahix committed
112 113 114
		abort();
	}

schneider's avatar
schneider committed
115
	/* BLE */
116
	if (ble_shall_start()) {
koalo's avatar
koalo committed
117 118 119 120 121 122 123 124 125 126
		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();
		}
127 128
	}

129 130 131 132 133 134 135 136 137 138 139 140
	/* LEDs */
	if (xTaskCreate(
		    vLedTask,
		    (const char *)"LED",
		    configMINIMAL_STACK_SIZE,
		    NULL,
		    tskIDLE_PRIORITY + 1,
		    NULL) != pdPASS) {
		LOG_CRIT("startup", "Failed to create %s task!", "LED");
		abort();
	}

Rahix's avatar
Rahix committed
141 142 143 144 145 146
	/* Lifecycle */
	if (xTaskCreate(
		    vLifecycleTask,
		    (const char *)"Lifecycle",
		    configMINIMAL_STACK_SIZE * 4,
		    NULL,
147
		    tskIDLE_PRIORITY + 3,
Rahix's avatar
Rahix committed
148 149 150
		    NULL) != pdPASS) {
		LOG_CRIT("startup", "Failed to create %s task!", "Lifecycle");
		abort();
q3k's avatar
q3k committed
151 152
	}

153 154 155 156 157
	/*
	 * Initialize serial driver data structures.
	 */
	serial_init();

158
	LOG_DEBUG("startup", "Starting FreeRTOS ...");
Rahix's avatar
Rahix committed
159
	vTaskStartScheduler();
160 161 162

	LOG_CRIT("startup", "FreeRTOS did not start due to unknown error!");
	abort();
Rahix's avatar
Rahix committed
163
}