the only immediate effect of this commit is enabling PIE support on
some archs that did not previously have any Scrt1.s, since the
existing asm files for crt1 override this C code. so some of the
crt_arch.h files committed are only there for the sake of documenting
what their archs "would do" if they used the new C-based crt1.
the expectation is that new archs should use this new system rather
than using heavy asm for crt1. aside from being easier and less
error-prone, it also ensures that PIE support is available immediately
(since Scrt1.o is generated from the same C source, using -fPIC)
rather than having to be added as an afterthought in the porting
process.
src/ldso/dynlink.lo: arch/$(ARCH)/reloc.h
+crt/crt1.o crt/Scrt1.o: $(wildcard arch/$(ARCH)/crt_arch.h)
+
+crt/Scrt1.o: CFLAGS += -fPIC
+
OPTIMIZE_SRCS = $(wildcard $(OPTIMIZE_GLOBS:%=src/%))
$(OPTIMIZE_SRCS:%.c=%.o) $(OPTIMIZE_SRCS:%.c=%.lo): CFLAGS += -O3
--- /dev/null
+__asm__("\
+.global _start \n\
+_start: \n\
+ mov fp, #0 \n\
+ mov lr, #0 \n\
+ mov a1, sp \n\
+ and sp, sp, #-16 \n\
+ bl __cstart \n\
+");
--- /dev/null
+__asm__("\
+.text \n\
+.global _start \n\
+_start: \n\
+ xor %ebp,%ebp \n\
+ mov %esp,%eax \n\
+ and $-16,%esp \n\
+ push %eax \n\
+ push %eax \n\
+ push %eax \n\
+ push %eax \n\
+ call __cstart \n\
+");
--- /dev/null
+__asm__("\
+.global _start \n\
+.align 2 \n\
+_start: \n\
+ add r19, r0, r0 \n\
+ ori r5, r1, 0 \n\
+ andi r1, r1, -8 \n\
+ addik r1, r1, -8 \n\
+ bri __cstart \n\
+ nop \n\
+");
--- /dev/null
+__asm__("\n\
+.set push\n\
+.set noreorder\n\
+.global __start\n\
+.global _start\n\
+.type __start, @function\n\
+.type _start, @function\n\
+__start:\n\
+_start:\n\
+ bal 1f \n\
+ move $fp, $0 \n\
+2: .gpword 2b \n\
+1: lw $gp, 0($ra) \n\
+ subu $gp, $ra, $gp \n\
+ move $4, $sp \n\
+ subu $sp, $sp, 16 \n\
+ and $sp, $sp, -8 \n\
+ lw $25, %call16(__cstart)($gp) \n\
+ jalr $25 \n\
+ nop \n\
+.set pop");
--- /dev/null
+__asm__("\
+.global _start \n\
+.type _start, %function \n\
+_start: \n\
+ mr 3, 1 \n\
+ clrrwi 1, 1, 4 \n\
+ li 0, 0 \n\
+ stwu 1, -16(1) \n\
+ mtlr 0 \n\
+ stw 0, 0(1) \n\
+ bl __cstart \n\
+");
--- /dev/null
+__asm__("\
+.text \n\
+.global _start \n\
+_start: \n\
+ xor %rbp,%rbp \n\
+ mov %rsp,%rdi \n\
+ andq $-16,%rsp \n\
+ call __cstart \n\
+");
+#include <features.h>
+
+#include "crt_arch.h"
+
+int main();
+void _init() __attribute__((weak));
+void _fini() __attribute__((weak));
+_Noreturn int __libc_start_main(int (*)(), int, char **,
+ void (*)(), void(*)(), void(*)());
+
+void __cstart(long *p)
+{
+ int argc = p[0];
+ char **argv = (void *)(p+1);
+ __libc_start_main(main, argc, argv, _init, _fini, 0);
+}