From a81c2218a2c2eaa35559ea83338f2c30140a4810 Mon Sep 17 00:00:00 2001 From: Eric Andersen Date: Thu, 23 Jan 2003 13:18:58 +0000 Subject: simpler method for getting a 'main' reference. Make _init and _fini be weak so people won't need to fix their compilers --- libc/sysdeps/linux/i386/crt0.S | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) (limited to 'libc') diff --git a/libc/sysdeps/linux/i386/crt0.S b/libc/sysdeps/linux/i386/crt0.S index dab5426ff..71b7f6c70 100644 --- a/libc/sysdeps/linux/i386/crt0.S +++ b/libc/sysdeps/linux/i386/crt0.S @@ -37,6 +37,17 @@ Cambridge, MA 02139, USA. */ .globl _start .type _start,@function +#if defined L_crt0 || ! defined __UCLIBC_CTOR_DTOR__ + .type __uClibc_main,%function +#else + .weak _init + .weak _fini + .type __uClibc_start_main,%function +#endif +/* Stick in a dummy reference to main(), so that if an application + * is linking when the main() function is in a static library (.a) + * we can be sure that main() actually gets linked in */ + .type main,%function _start: /* locate the start of the environment variables */ @@ -86,10 +97,5 @@ _start: /* Crash if somehow `exit' returns anyways. */ hlt - -/* Stick in a dummy reference to main(), so that if an application - * is linking when the main() function is in a static library (.a) - * we can be sure that main() actually gets linked in */ -L_dummy_main_reference: - .long main +.size _start,.-_start -- cgit v1.2.3