diff options
| author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2012-02-19 06:16:15 +0000 |
|---|---|---|
| committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2012-02-19 06:16:15 +0000 |
| commit | 34e3b522eca7e8741cecb7c2241091f181d1bd1f (patch) | |
| tree | 3b64ac3aa4603539b8f8f384bc39998e29948900 /libddekit/initcall.c | |
| parent | d4e6a14eb3fad1b43a21214db139db441025baf5 (diff) | |
| parent | 6fafeb146e9efd59140ea58cebd7dd38ae9a6379 (diff) | |
Merge branch 'upstream-merged'
Diffstat (limited to 'libddekit/initcall.c')
| -rw-r--r-- | libddekit/initcall.c | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/libddekit/initcall.c b/libddekit/initcall.c new file mode 100644 index 00000000..9195243d --- /dev/null +++ b/libddekit/initcall.c @@ -0,0 +1,27 @@ +#include <ddekit/initcall.h> + +#define BEG { (crt0_hook) ~1U } +#define END { (crt0_hook) 0 } + +#if (__GNUC__ == 3 && __GNUC_MINOR__ >= 3) || __GNUC__ >= 4 +#define SECTION(x) __attribute__((used, section( x ))) +#else +#define SECTION(x) __attribute__((section( x ))) +#endif + +typedef void (*crt0_hook)(void); + +static crt0_hook __L4DDE_CTOR_BEG__[1] SECTION(".mark_beg_l4dde_ctors") = BEG; +static crt0_hook __l4DDE_CTOR_END__[1] SECTION(".mark_end_l4dde_ctors") = END; + +void ddekit_do_initcalls() { + crt0_hook *list = __L4DDE_CTOR_BEG__; + + list++; + while (*list) + { + (**list)(); + list++; + } +} + |
