Re: [PATCH] tools/nolibc: Add support for SPARC

From: Thomas Weißschuh
Date: Mon Mar 17 2025 - 13:53:56 EST


On 2025-03-17 08:37:46+0100, Willy Tarreau wrote:
> On Sun, Mar 16, 2025 at 02:55:02PM +0100, Thomas Weißschuh wrote:
> > Add support for 32bit and 64bit SPARC to nolibc.
>
> Oh nice!
>
> > Signed-off-by: Thomas Weißschuh <linux@xxxxxxxxxxxxxx>
> > ---
> > This is only tested on QEMU.
> > Any tests on real hardware would be very welcome.
>
> I still have a working U60 here, but under solaris. Such machines are
> not trivial to boot on alternate OSes (and when you find a working
> image usually it's based on an old kernel).

An old kernel should be perfectly fine, no?

> But I've run it under
> Linux 20 years ago, so I know it was supported. I may give it a try
> when I find a moment, but let's not wait for this!

Thanks!

> A few comments below:
>
> > diff --git a/tools/include/nolibc/arch-sparc.h b/tools/include/nolibc/arch-sparc.h
> > new file mode 100644
> > index 0000000000000000000000000000000000000000..cb5543eca87bb4d52cfba4c0668e35cbbf6dd124
> > --- /dev/null
> > +++ b/tools/include/nolibc/arch-sparc.h
> > @@ -0,0 +1,191 @@
> > +/* SPDX-License-Identifier: LGPL-2.1 OR MIT */
> > +/*
> > + * SPARC (32bit and 64bit) specific definitions for NOLIBC
> > + * Copyright (C) 2025 Thomas Weißschuh <linux@xxxxxxxxxxxxxx>
> > + */
> > +
> > +#ifndef _NOLIBC_ARCH_SPARC_H
> > +#define _NOLIBC_ARCH_SPARC_H
> > +
> > +#include <linux/unistd.h>
> > +
> > +#include "compiler.h"
> > +#include "crt.h"
> > +
> > +/*
> > + * Syscalls for SPARC:
> > + * - registers are native word size
> > + * - syscall number is passed in g1
> > + * - arguments are in o0-o5
> > + * - the system call is performed by calling a trap instruction
> > + * - syscall return value is in 0a
> ^^
> What is "0a" here ? I suspect a typo and you meant "o0".

Correct, will fix.

> > +/* startup code */
> > +void __attribute__((weak, noreturn)) __nolibc_entrypoint __no_stack_protector _start(void)
> > +{
> > + __asm__ volatile (
> > + /*
> > + * Save stack pointer to o0, as arg1 of _start_c.
> > + * Account for window save area and stack bias.
> > + */
> > +#ifdef __arch64__
> > + "add %sp, 128 + 2047, %o0\n"
>
> It's really unclear where this magical 2047 comes from, I think it must
> be explained in the comment above so that someone disagreeing with it
> later can figure whether it's right or wrong.

128 is the context window and 2047 is the stack bias.
I'll try to make it clearer.

>
> > +#else
> > + "add %sp, 64, %o0\n"
> > +#endif
>
> Also, I could be wrong, but from my old memories of playing with the
> stack on SPARC long ago, I seem to remember that the stack is growing
> down. Thus I find these "add" suspicious or at least confusing. You
> mention "window save area and stack bias" above, I'm not sure what it
> refers to, but if we can safely erase parts of the stack because too
> much was preserved, maybe some more explanation about the initial and
> target layouts is deserved here.

There is a graphic in the psABI [0] under "Process Stack and Registers".
I'll write something based on that.

> > + "b,a _start_c\n" /* transfer to c runtime */
>
> OK great, the delayed slot is covered! (that type of thing can work
> by pure luck in one test and fail in another one depending on what
> bytes follow the jump).

Yeah, it brings memories to the work on MIPS support.

> Thanks!
>
> Acked-by: Willy Tarreau <w@xxxxxx>

Thanks!

[0] https://uclibc.org/docs/psABI-sparc.pdf