diff options
author | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2011-04-17 13:55:31 +0000 |
---|---|---|
committer | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2011-04-17 13:55:31 +0000 |
commit | 6a57dd25e08f1a7164542751024429be814df5e3 (patch) | |
tree | 465b3de8a07f40cb53d649bb8ed17c1c2bea4b82 | |
parent | aeed6d78c11a287f010a55b58bb640f5b54d6254 (diff) | |
download | ChibiOS-6a57dd25e08f1a7164542751024429be814df5e3.tar.gz ChibiOS-6a57dd25e08f1a7164542751024429be814df5e3.tar.bz2 ChibiOS-6a57dd25e08f1a7164542751024429be814df5e3.zip |
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@2883 35acf78f-673a-0410-8e92-d51de3d6d3f4
-rw-r--r-- | demos/ARMCM3-STM32F103/ch.ld | 66 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/STM32/port.mk | 5 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/crt0.c | 77 | ||||
-rw-r--r-- | readme.txt | 3 |
4 files changed, 85 insertions, 66 deletions
diff --git a/demos/ARMCM3-STM32F103/ch.ld b/demos/ARMCM3-STM32F103/ch.ld index ae79ddd40..4d97e7682 100644 --- a/demos/ARMCM3-STM32F103/ch.ld +++ b/demos/ARMCM3-STM32F103/ch.ld @@ -38,11 +38,32 @@ __ram_end__ = __ram_start__ + __ram_size__; SECTIONS
{
. = 0;
+ _text = .;
- .text : ALIGN(16) SUBALIGN(16)
+ startup : ALIGN(16) SUBALIGN(16)
{
- _text = .;
KEEP(*(vectors))
+ } > flash
+
+ constructors : ALIGN(4) SUBALIGN(4)
+ {
+ PROVIDE(__init_array_start = .);
+ KEEP(*(SORT(.init_array.*)))
+ KEEP(*(.init_array))
+ PROVIDE(__init_array_end = .);
+ } > flash
+
+ destructors : ALIGN(4) SUBALIGN(4)
+ {
+ PROVIDE(__fini_array_start = .);
+ KEEP(*(.fini_array))
+ KEEP(*(SORT(.fini_array.*)))
+ PROVIDE(__fini_array_end = .);
+ } > flash
+
+ .text : ALIGN(16) SUBALIGN(16)
+ {
+ *(.text.startup.*)
*(.text)
*(.text.*)
*(.rodata)
@@ -52,31 +73,26 @@ SECTIONS *(.gcc*)
} > flash
- .ctors :
+ .ARM.extab :
{
- PROVIDE(_ctors_start_ = .);
- KEEP(*(SORT(.ctors.*)))
- KEEP(*(.ctors))
- PROVIDE(_ctors_end_ = .);
+ *(.ARM.extab* .gnu.linkonce.armextab.*)
} > flash
- .dtors :
+ .ARM.exidx : {
+ PROVIDE(__exidx_start = .);
+ *(.ARM.exidx* .gnu.linkonce.armexidx.*)
+ PROVIDE(__exidx_end = .);
+ } > flash
+
+ .eh_frame_hdr :
{
- PROVIDE(_dtors_start_ = .);
- KEEP(*(SORT(.dtors.*)))
- KEEP(*(.dtors))
- PROVIDE(_dtors_end_ = .);
+ *(.eh_frame_hdr)
} > flash
- .ARM.extab : {*(.ARM.extab* .gnu.linkonce.armextab.*)}
-
- __exidx_start = .;
- .ARM.exidx : {*(.ARM.exidx* .gnu.linkonce.armexidx.*)} > flash
- __exidx_end = .;
-
- .eh_frame_hdr : {*(.eh_frame_hdr)}
-
- .eh_frame : ONLY_IF_RO {*(.eh_frame)}
+ .eh_frame : ONLY_IF_RO
+ {
+ *(.eh_frame)
+ } > flash
. = ALIGN(4);
_etext = .;
@@ -84,26 +100,26 @@ SECTIONS .data :
{
- _data = .;
+ PROVIDE(_data = .);
*(.data)
. = ALIGN(4);
*(.data.*)
. = ALIGN(4);
*(.ramtext)
. = ALIGN(4);
- _edata = .;
+ PROVIDE(_edata = .);
} > ram AT > flash
.bss :
{
- _bss_start = .;
+ PROVIDE(_bss_start = .);
*(.bss)
. = ALIGN(4);
*(.bss.*)
. = ALIGN(4);
*(COMMON)
. = ALIGN(4);
- _bss_end = .;
+ PROVIDE(_bss_end = .);
} > ram
}
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();
}
/** @} */
diff --git a/readme.txt b/readme.txt index 0f5c72a30..f9bde293c 100644 --- a/readme.txt +++ b/readme.txt @@ -77,6 +77,9 @@ to 2.2.4).
- FIX: Fixed spurious characters generated by Serial over USB driver (bug
3276379).
+- NEW: New unified GCC startup file for Cortex-Mx processors, it is written
+ in C instead of asm and supports constructors/destructors. Improved the
+ Cortex-Mx linker scripts in all the GCC demos.
- NEW: Now it is possible to share DMA channels in the STM32 HAL thanks
to a centralized manager. Channels are allocated when the driver is
started and released when it is stopped.
|