1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/core/lib/init.c

131 lines
2.7 KiB
C
Raw Normal View History

/*
2017-01-09 17:07:03 +01:00
* Copyright (C) 2016 Kaspar Schleiser <kaspar@schleiser.de>
* 2013 Freie Universität Berlin
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @ingroup core_internal
* @{
*
* @file
2019-10-23 21:21:04 +02:00
* @brief Platform-independent kernel initialization
*
* @author Kaspar Schleiser <kaspar@schleiser.de>
*
* @}
*/
#include <errno.h>
2022-01-12 16:15:48 +01:00
#include <stdbool.h>
#include <stdint.h>
#include "auto_init.h"
2014-12-04 17:17:24 +01:00
#include "irq.h"
2022-01-12 16:15:48 +01:00
#include "kernel_init.h"
2015-02-25 16:31:03 +01:00
#include "log.h"
#include "periph/pm.h"
2022-01-12 16:15:48 +01:00
#include "thread.h"
#include "stdio_base.h"
#if IS_USED(MODULE_VFS)
#include "vfs.h"
#endif
#define ENABLE_DEBUG 0
#include "debug.h"
#ifndef CONFIG_BOOT_MSG_STRING
2021-01-19 17:47:23 +01:00
#define CONFIG_BOOT_MSG_STRING "main(): This is RIOT! (Version: " \
RIOT_VERSION ")"
#endif
extern int main(void);
2020-01-31 10:12:49 +01:00
static char main_stack[THREAD_STACKSIZE_MAIN];
static char idle_stack[THREAD_STACKSIZE_IDLE];
static void *main_trampoline(void *arg)
{
2020-01-31 10:12:49 +01:00
(void)arg;
2022-01-12 16:15:48 +01:00
if (IS_USED(MODULE_AUTO_INIT)) {
auto_init();
}
if (!IS_ACTIVE(CONFIG_SKIP_BOOT_MSG) && !IS_USED(MODULE_STDIO_NULL)) {
LOG_INFO(CONFIG_BOOT_MSG_STRING "\n");
}
int res = main();
if (IS_USED(MODULE_TEST_UTILS_MAIN_EXIT_CB)) {
void test_utils_main_exit_cb(int res);
test_utils_main_exit_cb(res);
}
2020-01-31 10:12:49 +01:00
#ifdef MODULE_TEST_UTILS_PRINT_STACK_USAGE
void print_stack_usage_metric(const char *name, void *stack, unsigned max_size);
if (IS_USED(MODULE_CORE_IDLE_THREAD)) {
print_stack_usage_metric("idle", idle_stack, THREAD_STACKSIZE_IDLE);
}
#endif
return NULL;
}
static void *idle_thread(void *arg)
{
2020-01-31 10:12:49 +01:00
(void)arg;
while (1) {
pm_set_lowest();
}
return NULL;
}
void kernel_init(void)
{
if (!IS_USED(MODULE_CORE_THREAD)) {
/* RIOT without threads */
main_trampoline(NULL);
while (1) {}
return;
}
2020-01-31 10:12:49 +01:00
irq_disable();
2020-06-04 21:52:57 +02:00
if (IS_USED(MODULE_CORE_IDLE_THREAD)) {
thread_create(idle_stack, sizeof(idle_stack),
THREAD_PRIORITY_IDLE,
THREAD_CREATE_WOUT_YIELD | THREAD_CREATE_STACKTEST,
idle_thread, NULL, "idle");
}
thread_create(main_stack, sizeof(main_stack),
THREAD_PRIORITY_MAIN,
THREAD_CREATE_WOUT_YIELD | THREAD_CREATE_STACKTEST,
main_trampoline, NULL, "main");
2010-10-28 11:22:57 +02:00
cpu_switch_context_exit();
}
void early_init(void)
{
/* initialize leds */
if (IS_USED(MODULE_PERIPH_INIT_LEDS)) {
extern void led_init(void);
led_init();
}
stdio_init();
#if MODULE_VFS
vfs_bind_stdio();
#endif
}