summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/mips/crt0.S
diff options
context:
space:
mode:
authorEric Andersen <andersen@codepoet.org>2003-01-23 17:55:27 +0000
committerEric Andersen <andersen@codepoet.org>2003-01-23 17:55:27 +0000
commita3560dc47b3cf2eef3ebf0e0c9765e11bdf66b6a (patch)
treeb6a67f0d5748f0f69cb2b0a971e6f2c74da3065f /libc/sysdeps/linux/mips/crt0.S
parent100cc918a944bd0d40ecb2afc635f2b76d7cb577 (diff)
Update architecture specific support to consistantly
generate a crt0 and crt1 file. Most arches still need to be updated to call __uClibc_start_main() rather than __uClibc_main().
Diffstat (limited to 'libc/sysdeps/linux/mips/crt0.S')
-rw-r--r--libc/sysdeps/linux/mips/crt0.S21
1 files changed, 13 insertions, 8 deletions
diff --git a/libc/sysdeps/linux/mips/crt0.S b/libc/sysdeps/linux/mips/crt0.S
index fdb997b73..b24fe1d84 100644
--- a/libc/sysdeps/linux/mips/crt0.S
+++ b/libc/sysdeps/linux/mips/crt0.S
@@ -12,8 +12,19 @@
#include <sys/regdef.h>
.text
-.global __start
-.type __start,@function
+ .global __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:
#ifdef __PIC__
@@ -49,9 +60,3 @@ __start:
hlt:
b 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
-