main.c 3.16 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

Rahix's avatar
Rahix committed
7
8
#include "FreeRTOS.h"
#include "task.h"
9
#include "mxc_delay.h"
Rahix's avatar
Rahix committed
10

11
#include <stdlib.h>
koalo's avatar
koalo committed
12
#include <string.h>
13

Rahix's avatar
Rahix committed
14
15
int main(void)
{
16
17
	watchdog_init();

18
	LOG_INFO("startup", "Epicardium startup ...");
Rahix's avatar
Rahix committed
19
	LOG_INFO("startup", "Version " CARD10_VERSION);
20

21
	LOG_DEBUG("startup", "Initializing hardware ...");
22
23
	hardware_early_init();

swym's avatar
swym committed
24
25
	load_config();

26
27
28
29
	/*
	 * Version Splash
	 */
	const char *version_buf = CARD10_VERSION;
30
31
32
33
	const int off           = (160 - (int)strlen(version_buf) * 14) / 2;
	epic_disp_clear(0x9dc0);
	epic_disp_print(10, 20, "Epicardium", 0x6c20, 0x9dc0);
	epic_disp_print(off > 0 ? off : 0, 40, version_buf, 0x6c20, 0x9dc0);
ch3's avatar
ch3 committed
34
35
	epic_disp_update();
	mxc_delay(2000000);
36

37
	LOG_DEBUG("startup", "Initializing tasks ...");
Rahix's avatar
Rahix committed
38
39
40

	/* Serial */
	if (xTaskCreate(
Rahix's avatar
Rahix committed
41
42
		    vSerialTask,
		    (const char *)"Serial",
43
		    configMINIMAL_STACK_SIZE * 2,
Rahix's avatar
Rahix committed
44
		    NULL,
45
		    tskIDLE_PRIORITY + 3,
Rahix's avatar
Rahix committed
46
		    NULL) != pdPASS) {
47
		LOG_CRIT("startup", "Failed to create %s task!", "Serial");
Rahix's avatar
Rahix committed
48
49
50
		abort();
	}

51
52
53
54
55
56
	/* PMIC */
	if (xTaskCreate(
		    vPmicTask,
		    (const char *)"PMIC",
		    configMINIMAL_STACK_SIZE,
		    NULL,
Rahix's avatar
Rahix committed
57
		    tskIDLE_PRIORITY + 4,
58
		    NULL) != pdPASS) {
59
		LOG_CRIT("startup", "Failed to create %s task!", "PMIC");
60
61
62
		abort();
	}

63
64
65
66
67
68
69
70
	/* BHI160 */
	if (xTaskCreate(
		    vBhi160Task,
		    (const char *)"BHI160 Driver",
		    configMINIMAL_STACK_SIZE * 2,
		    NULL,
		    tskIDLE_PRIORITY + 1,
		    NULL) != pdPASS) {
koalo's avatar
koalo committed
71
		LOG_CRIT("startup", "Failed to create %s task!", "BHI160");
72
73
74
		abort();
	}

schneider's avatar
schneider committed
75
76
77
78
79
80
81
82
83
84
85
	/* 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();
	}
86
	/* API */
Rahix's avatar
Rahix committed
87
	if (xTaskCreate(
Rahix's avatar
Rahix committed
88
89
		    vApiDispatcher,
		    (const char *)"API Dispatcher",
swym's avatar
swym committed
90
		    configMINIMAL_STACK_SIZE * 16,
Rahix's avatar
Rahix committed
91
92
93
		    NULL,
		    tskIDLE_PRIORITY + 2,
		    &dispatcher_task_id) != pdPASS) {
q3k's avatar
q3k committed
94
95
96
97
98
		LOG_CRIT(
			"startup",
			"Failed to create %s task!",
			"API Dispatcher"
		);
Rahix's avatar
Rahix committed
99
100
101
		abort();
	}

schneider's avatar
schneider committed
102
	/* BLE */
103
	if (ble_shall_start()) {
koalo's avatar
koalo committed
104
105
106
107
108
109
110
111
112
113
		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();
		}
114
115
	}

116
117
118
119
120
121
122
123
124
125
126
127
	/* 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
128
129
130
131
132
133
	/* Lifecycle */
	if (xTaskCreate(
		    vLifecycleTask,
		    (const char *)"Lifecycle",
		    configMINIMAL_STACK_SIZE * 4,
		    NULL,
134
		    tskIDLE_PRIORITY + 3,
Rahix's avatar
Rahix committed
135
136
137
		    NULL) != pdPASS) {
		LOG_CRIT("startup", "Failed to create %s task!", "Lifecycle");
		abort();
q3k's avatar
q3k committed
138
139
	}

140
141
142
143
144
	/*
	 * Initialize serial driver data structures.
	 */
	serial_init();

145
	LOG_DEBUG("startup", "Starting FreeRTOS ...");
Rahix's avatar
Rahix committed
146
	vTaskStartScheduler();
147
148
149

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