/** * ARM architecture common support functions * * Copyright (C) 2008, 2009 Heiko Will * Copyright (C) 2009 Kaspar Schleiser * * This file is subject to the terms and conditions of the GNU Lesser General * Public License. See the file LICENSE in the top level directory for more * details. * * @ingroup arm_common * @{ * @file * @author Kaspar Schleiser * @author Heiko Will * @} */ #include #include "arm_cpu.h" #include "sched.h" #include "kernel.h" #include "kernel_internal.h" #define STACK_MARKER (0x77777777) #define REGISTER_CNT (12) void thread_yield(void) { asm("svc 0\n"); } /*---------------------------------------------------------------------------- * Processor specific routine - here for ARM7 * sizeof(void*) = sizeof(int) *--------------------------------------------------------------------------*/ char *thread_stack_init(void (*task_func)(void), void *stack_start, int stack_size) { unsigned int *stk; int i; stk = (unsigned int *)((unsigned int)stack_start + stack_size); stk--; *stk = STACK_MARKER; /* set the return address (LR) */ stk--; *stk = (unsigned int) sched_task_exit; /* set the stack pointer (SP) */ stk--; *stk = (unsigned int)((unsigned int)stack_start + stack_size) - 4; /* build base stack */ for (i = REGISTER_CNT; i >= 0 ; i--) { stk--; *stk = i; } /* set the entry point */ stk--; *stk = ((unsigned int) task_func); /* set the saved program status register */ stk--; *stk = (unsigned int) NEW_TASK_CPSR; return (char *)stk; } void thread_print_stack(void) { register void *stack = 0; asm("mov %0, sp" : "=r"(stack)); register unsigned int *s = (unsigned int *)stack; printf("task: %X SP: %X\n", (unsigned int) sched_active_thread, (unsigned int) stack); register int i = 0; s += 5; while (*s != STACK_MARKER) { printf("STACK (%d) addr=%X = %X \n", i, (unsigned int) s, (unsigned int) *s); s++; i++; } printf("STACK (%d)= %X \n", i, *s); } int reboot_arch(int mode) { (void) mode; while (1) { arm_reset(); } return -1; }