From 6a57dd25e08f1a7164542751024429be814df5e3 Mon Sep 17 00:00:00 2001 From: gdisirio Date: Sun, 17 Apr 2011 13:55:31 +0000 Subject: git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@2883 35acf78f-673a-0410-8e92-d51de3d6d3f4 --- os/ports/GCC/ARMCMx/STM32/port.mk | 5 ++- os/ports/GCC/ARMCMx/crt0.c | 77 +++++++++++++++++++-------------------- 2 files changed, 41 insertions(+), 41 deletions(-) (limited to 'os') diff --git a/os/ports/GCC/ARMCMx/STM32/port.mk b/os/ports/GCC/ARMCMx/STM32/port.mk index 80764b3d9..104b22e42 100644 --- a/os/ports/GCC/ARMCMx/STM32/port.mk +++ b/os/ports/GCC/ARMCMx/STM32/port.mk @@ -1,10 +1,11 @@ # List of the ChibiOS/RT Cortex-M3 STM32 port files. -PORTSRC = $(CHIBIOS)/os/ports/GCC/ARMCMx/STM32/vectors.c \ +PORTSRC = $(CHIBIOS)/os/ports/GCC/ARMCMx/crt0.c \ + $(CHIBIOS)/os/ports/GCC/ARMCMx/STM32/vectors.c \ ${CHIBIOS}/os/ports/GCC/ARMCMx/chcore.c \ ${CHIBIOS}/os/ports/GCC/ARMCMx/chcore_v7m.c \ ${CHIBIOS}/os/ports/GCC/ARMCMx/nvic.c -PORTASM = ${CHIBIOS}/os/ports/GCC/ARMCMx/crt0_v7m.s +PORTASM = PORTINC = ${CHIBIOS}/os/ports/GCC/ARMCMx \ ${CHIBIOS}/os/ports/GCC/ARMCMx/STM32 diff --git a/os/ports/GCC/ARMCMx/crt0.c b/os/ports/GCC/ARMCMx/crt0.c index a51f4dbfe..90f632271 100644 --- a/os/ports/GCC/ARMCMx/crt0.c +++ b/os/ports/GCC/ARMCMx/crt0.c @@ -27,6 +27,12 @@ #include "chtypes.h" +#define FALSE 0 +#define TRUE (!FALSE) + +typedef void (*funcp_t)(void); +typedef funcp_t * funcpp_t; + /** * @brief Control special register initialization value. * @details The system is setup to run in privileged mode using the PSP @@ -124,36 +130,33 @@ extern uint32_t _bss_end; * @brief Constructors table start. * @pre The symbol must be aligned to a 32 bits boundary. */ -extern void __init_array_start(void); +extern funcp_t __init_array_start; /** * @brief Constructors table end. * @pre The symbol must be aligned to a 32 bits boundary. */ -extern void __init_array_end(void); +extern funcp_t __init_array_end; /** * @brief Destructors table start. * @pre The symbol must be aligned to a 32 bits boundary. */ -extern void __fini_array_start(void); +extern funcp_t __fini_array_start; /** * @brief Destructors table end. * @pre The symbol must be aligned to a 32 bits boundary. */ -extern void __fini_array_end(void); +extern funcp_t __fini_array_end; /** * @brief Application @p main() function. - * - * @param[in] argc Number of arguments, always zero. - * @param[in] argv Pointer to an array of arguments, always @p NULL. */ -extern void main(int argc, char **argv); +extern void main(void); /** - * @brief Default initialization hook 0. + * @brief Early initialization. * @details This hook is invoked immediately after the stack initialization * and before the DATA and BSS segments initialization. The * default behavior is to do nothing. @@ -162,19 +165,19 @@ extern void main(int argc, char **argv); #if !defined(__DOXYGEN__) __attribute__((weak)) #endif -void hwinit0(void) {} +void __early_init(void) {} /** - * @brief Default initialization hook 1. - * @details This hook is invoked immediately after the DATA and BSS segments - * initialization and before entering the @p main() function. The + * @brief Late initialization. + * @details This hook is invoked after the DATA and BSS segments + * initialization and before any static constructor. The * default behavior is to do nothing. * @note This function is a weak symbol. */ #if !defined(__DOXYGEN__) __attribute__((weak)) #endif -void hwinit1(void) {} +void __late_init(void) {} /** * @brief Default @p main() function exit handler. @@ -183,9 +186,9 @@ void hwinit1(void) {} * @note This function is a weak symbol. */ #if !defined(__DOXYGEN__) -__attribute__((weak, naked)) +__attribute__((weak, noreturn)) #endif -void _main_exit_handler(void) { +void _default_exit(void) { while (1) ; } @@ -194,24 +197,24 @@ void _main_exit_handler(void) { * @brief Reset vector. */ #if !defined(__DOXYGEN__) -__attribute__((naked)) +__attribute__((noreturn)) #endif void ResetHandler(void) { - uint32_t sz, ctl; + uint32_t psp, ctl; /* Process Stack initialization, it is allocated below the main stack. The main stack is assumed to be allocated starting from @p __ram_end__ extending downward.*/ asm volatile ("cpsid i"); - sz = SYMVAL(__ram_end__) - SYMVAL(__main_stack_size__); - asm volatile ("msr PSP, %0" : : "r" (sz)); + psp = SYMVAL(__ram_end__) - SYMVAL(__main_stack_size__); + asm volatile ("msr PSP, %0" : : "r" (psp)); ctl = CRT0_CONTROL_INIT; asm volatile ("msr CONTROL, %0" : : "r" (ctl)); asm volatile ("isb"); - /* Initialization hook 0 invocation.*/ - hwinit0(); + /* Early initialization hook invocation.*/ + __early_init(); #if CRT0_INIT_DATA /* DATA segment initialization.*/ @@ -236,40 +239,36 @@ void ResetHandler(void) { } #endif - /* Initialization hook 1 invocation.*/ - hwinit1(); + /* Late initialization hook invocation.*/ + __late_init(); #if CRT0_CALL_CONSTRUCTORS /* Constructors invocation.*/ { - void (*dpp)(void); - - dpp = &__init_array_start; - while (dpp < &__init_array_end) { - (*dpp)(); - dpp++; + funcpp_t fpp = &__init_array_start; + while (fpp < &__init_array_end) { + (*fpp)(); + fpp++; } } #endif /* Invoking application main() function.*/ - main(0, 0); + main(); #if CRT0_CALL_DESTRUCTORS /* Destructors invocation.*/ { - void (*dpp)(void); - - dpp = &__fini_array_start; - while (dpp < &__fini_array_end) { - (*dpp)(); - dpp++; + funcpp_t fpp = &__fini_array_start; + while (fpp < &__fini_array_end) { + (*fpp)(); + fpp++; } } #endif - /* Invoking the main() exit handler.*/ - asm volatile ("b _main_exit_handler"); + /* Invoking the exit handler.*/ + _default_exit(); } /** @} */ -- cgit v1.2.3