From 00e50ff0cda40ee1736887e83465e7e5c77aaa3f Mon Sep 17 00:00:00 2001 From: Nicolas Schodet Date: Tue, 19 Mar 2013 18:22:15 +0100 Subject: Add support for static constructors and destructors 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 --- lib/lm3s/vector.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'lib/lm3s/vector.c') diff --git a/lib/lm3s/vector.c b/lib/lm3s/vector.c index b7c92ae..43c7952 100644 --- a/lib/lm3s/vector.c +++ b/lib/lm3s/vector.c @@ -21,6 +21,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); @@ -309,6 +313,7 @@ void (*const vector_table[]) (void) = { void reset_handler(void) { volatile unsigned *src, *dest; + funcp_t *fp; __asm__("MSR msp, %0" : : "r"(&_stack)); @@ -318,8 +323,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) -- cgit v1.2.3