diff options
Diffstat (limited to 'libc/sysdeps/linux/mips/crt0.S')
-rw-r--r-- | libc/sysdeps/linux/mips/crt0.S | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/libc/sysdeps/linux/mips/crt0.S b/libc/sysdeps/linux/mips/crt0.S index 6770ab0b1..7ff3b253f 100644 --- a/libc/sysdeps/linux/mips/crt0.S +++ b/libc/sysdeps/linux/mips/crt0.S @@ -30,9 +30,22 @@ __start: addu a2, a0, 1 /* load envp */ sll a2, a2, 2 add a2, a2, a1 + + /* Store the address of _init in a3 as an argument to __uClibc_start_main() */ + la a3, _init + + /* Push _fini onto the stack as the final argument to __uClibc_start_main() + I don't think I am doing this properly but it at least compiles... + */ + la t0, _fini + sw t0,16(sp) + /* Ok, now run uClibc's main() -- shouldn't return */ - jal __uClibc_main - hlt: b hlt /* Crash if somehow it does return. */ + jal __uClibc_start_main + + /* Crash if somehow `exit' returns anyways. */ +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) |