From 108c682df0ec6908695e55d3c3f50fe158a5d502 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alex=20R=C3=B8nne=20Petersen?= Date: Wed, 24 Jul 2024 23:25:19 +0200 Subject: [PATCH] start: Add POSIX csky support. --- lib/std/start.zig | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/lib/std/start.zig b/lib/std/start.zig index 74e177ce0b..76789bc5fc 100644 --- a/lib/std/start.zig +++ b/lib/std/start.zig @@ -316,6 +316,24 @@ fn _start() callconv(.Naked) noreturn { \\ and sp, #-16 \\ b %[posixCallMainAndExit] , + // zig fmt: off + .csky => + if (builtin.position_independent_code) + // The CSKY ABI assumes that `gb` is set to the address of the GOT in order for + // position-independent code to work. We depend on this in `std.os.linux.start_pie` + // to locate `_DYNAMIC` as well. + \\ grs t0, 1f + \\ 1: + \\ lrw gb, 1b@GOTPC + \\ addu gb, t0 + else "" + ++ + \\ movi lr, 0 + \\ mov a0, sp + \\ andi sp, sp, -8 + \\ jmpi %[posixCallMainAndExit] + , + // zig fmt: on .hexagon => // r29 = SP, r30 = FP \\ r30 = #0