diff options
author | Eric Andersen <andersen@codepoet.org> | 2002-04-14 03:32:14 +0000 |
---|---|---|
committer | Eric Andersen <andersen@codepoet.org> | 2002-04-14 03:32:14 +0000 |
commit | 5ce9147ea3796f0dca7f8fffce8b4c398eb08915 (patch) | |
tree | 2be24c643076c82822ab78c0bd07ab74a48ec9f0 /libc/sysdeps/linux/arm | |
parent | ed44f35a1aa84c6e42dac46aab75e9f8fcc6d7b7 (diff) |
Manuel and I were looking into a problem with applications failing to link
(undefined reference to `main') when the .o file containing main was contained
in an static library(a '.a' ar archive). It turns out that due to its single
pass nature, GNU ld was failing to pull it into the build. This sticks a dummy
reference to main() into crt0.o, so that when an application is linked with the
main() function in a static library, we can be sure that main() actually gets
linked in.
-Erik
Diffstat (limited to 'libc/sysdeps/linux/arm')
-rw-r--r-- | libc/sysdeps/linux/arm/crt0.S | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/libc/sysdeps/linux/arm/crt0.S b/libc/sysdeps/linux/arm/crt0.S index 0d4031eaf..442c9e84b 100644 --- a/libc/sysdeps/linux/arm/crt0.S +++ b/libc/sysdeps/linux/arm/crt0.S @@ -92,3 +92,9 @@ _start: /* Ok, now run uClibc's main() -- shouldn't return */ bl __uClibc_main +/* 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 + |