aboutsummaryrefslogtreecommitdiff
path: root/lib/stm32/f2/vector.c
diff options
context:
space:
mode:
authorNicolas Schodet2013-03-19 18:22:15 +0100
committerNicolas Schodet2013-03-19 18:22:15 +0100
commit00e50ff0cda40ee1736887e83465e7e5c77aaa3f (patch)
tree59f1d525f946e2f2a18a6109be81b007686f7f22 /lib/stm32/f2/vector.c
parent4e4496f70d00fe24b2c5d594d6500f537eeb6478 (diff)
Add support for static constructors and destructorsinit-fini
Conflicts: lib/efm32/efm32g/libopencm3_efm32g.ld lib/efm32/efm32gg/libopencm3_efm32gg.ld lib/efm32/efm32lg/libopencm3_efm32lg.ld lib/efm32/efm32tg/libopencm3_efm32tg.ld lib/lpc17xx/vector.c lib/stm32/l1/libopencm3_stm32l1.ld
Diffstat (limited to 'lib/stm32/f2/vector.c')
-rw-r--r--lib/stm32/f2/vector.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/lib/stm32/f2/vector.c b/lib/stm32/f2/vector.c
index 3429bfb..d24fcae 100644
--- a/lib/stm32/f2/vector.c
+++ b/lib/stm32/f2/vector.c
@@ -22,6 +22,10 @@
/* Symbols exported by the linker script(s): */
extern unsigned _data_loadaddr, _data, _edata, _ebss, _stack;
+typedef void (*funcp_t) (void);
+extern funcp_t __preinit_array_start, __preinit_array_end;
+extern funcp_t __init_array_start, __init_array_end;
+extern funcp_t __fini_array_start, __fini_array_end;
void main(void);
void reset_handler(void);
@@ -221,6 +225,7 @@ void (*const vector_table[]) (void) = {
void reset_handler(void)
{
volatile unsigned *src, *dest;
+ funcp_t *fp;
__asm__("MSR msp, %0" : : "r"(&_stack));
@@ -230,8 +235,18 @@ void reset_handler(void)
while (dest < &_ebss)
*dest++ = 0;
+ /* Constructors. */
+ for (fp = &__preinit_array_start; fp < &__preinit_array_end; fp++)
+ (*fp)();
+ for (fp = &__init_array_start; fp < &__init_array_end; fp++)
+ (*fp)();
+
/* Call the application's entry point. */
main();
+
+ /* Destructors. */
+ for (fp = &__fini_array_start; fp < &__fini_array_end; fp++)
+ (*fp)();
}
void blocking_handler(void)