/** * platform-independent kernel initialization * * Copyright (C) 2010 Freie Universität Berlin * * This file subject to the terms and conditions of the GNU General Public * License. See the file LICENSE in the top level directory for more details. * * @ingroup kernel * @{ * @file * @author Kaspar Schleiser * @} */ #include #include #include #include #include #include #include #include #include #include #include #include #ifdef MODULE_AUTO_INIT #include #endif #define ENABLE_DEBUG #include volatile tcb_t *sched_threads[MAXTHREADS]; volatile tcb_t *active_thread; volatile int lpm_prevent_sleep = 0; extern void main(void); extern void cpu_switch_context_exit(void); static void idle_thread(void) { while(1) { if (lpm_prevent_sleep) { lpm_set(LPM_IDLE); } else { lpm_set(LPM_IDLE); // lpm_set(LPM_SLEEP); // lpm_set(LPM_POWERDOWN); } } } const char *main_name = "main"; const char *idle_name = "idle"; static char main_stack[KERNEL_CONF_STACKSIZE_MAIN]; static char idle_stack[KERNEL_CONF_STACKSIZE_IDLE]; #ifdef MODULE_AUTO_INIT #define MAIN_FUNC auto_init #else #define MAIN_FUNC main #endif void kernel_init(void) { dINT(); printf("kernel_init(): This is ukleos!\n"); sched_init(); if (thread_create(idle_stack, sizeof(idle_stack), PRIORITY_IDLE, CREATE_WOUT_YIELD | CREATE_STACKTEST, idle_thread, idle_name) < 0) { printf("kernel_init(): error creating idle task.\n"); } if (thread_create(main_stack, sizeof(main_stack), PRIORITY_MAIN, CREATE_WOUT_YIELD | CREATE_STACKTEST, MAIN_FUNC, main_name) < 0) { printf("kernel_init(): error creating main task.\n"); } printf("kernel_init(): jumping into first task...\n"); cpu_switch_context_exit(); }