zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit b56a667ecdb9f34dbd60d247d4237bc008755979 (tree)
parent cf691543323be9bb663aac2d19f62412435a4d39
Author: Alex Rønne Petersen <alex@alexrp.com>
Date:   Wed, 11 Sep 2024 07:32:44 +0200

start: Rewrite arm code to work for thumb1 too.

0ecc6332b4eb1ced547ffa38f57471134aaa4d13 improved things for thumb2, but thumb1
has a much smaller permissible instruction set. This commit makes that work.

Diffstat:
Mlib/std/start.zig | 12+++++++-----
1 file changed, 7 insertions(+), 5 deletions(-)

diff --git a/lib/std/start.zig b/lib/std/start.zig @@ -280,12 +280,14 @@ fn _start() callconv(.Naked) noreturn { \\ b %[posixCallMainAndExit] , .arm, .armeb, .thumb, .thumbeb => - \\ mov fp, #0 - \\ mov lr, #0 + // Note that this code must work for Thumb-1. + \\ movs v1, #0 + \\ mov fp, v1 + \\ mov lr, v1 \\ mov a1, sp - \\ mov ip, sp - \\ and ip, ip, #-16 - \\ mov sp, ip + \\ subs v1, #16 + \\ ands v1, a1 + \\ mov sp, v1 \\ b %[posixCallMainAndExit] , .csky =>