lib: Linux riscv64-mes-mescc support.
* lib/linux/riscv64-mes-mescc/_exit.c, lib/linux/riscv64-mes-mescc/_write.c, lib/linux/riscv64-mes-mescc/crt1.c, lib/linux/riscv64-mes-mescc/syscall-internal.c, lib/linux/riscv64-mes-mescc/syscall.c: New files. These add support for building for riscv64-mes-mescc and make it self-hosting.
This commit is contained in:
parent
e7aac5e8ba
commit
a1bc54bce8
31
lib/linux/riscv64-mes-mescc/_exit.c
Normal file
31
lib/linux/riscv64-mes-mescc/_exit.c
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
/* -*-comment-start: "//";comment-end:""-*-
|
||||||
|
* GNU Mes --- Maxwell Equations of Software
|
||||||
|
* Copyright © 2018,2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
|
* Copyright © 2021 W. J. van der Laan <laanwj@protonmail.com>
|
||||||
|
*
|
||||||
|
* This file is part of GNU Mes.
|
||||||
|
*
|
||||||
|
* GNU Mes is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or (at
|
||||||
|
* your option) any later version.
|
||||||
|
*
|
||||||
|
* GNU Mes is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with GNU Mes. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "mes/lib-mini.h"
|
||||||
|
|
||||||
|
void
|
||||||
|
_exit (int status)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a0,0x10(%fp)");
|
||||||
|
asm ("li_____%a7,SYS_exit");
|
||||||
|
asm ("ecall");
|
||||||
|
// no need to read return value
|
||||||
|
}
|
33
lib/linux/riscv64-mes-mescc/_write.c
Normal file
33
lib/linux/riscv64-mes-mescc/_write.c
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
/* -*-comment-start: "//";comment-end:""-*-
|
||||||
|
* GNU Mes --- Maxwell Equations of Software
|
||||||
|
* Copyright © 2018,2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
|
* Copyright © 2021 W. J. van der Laan <laanwj@protonmail.com>
|
||||||
|
*
|
||||||
|
* This file is part of GNU Mes.
|
||||||
|
*
|
||||||
|
* GNU Mes is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or (at
|
||||||
|
* your option) any later version.
|
||||||
|
*
|
||||||
|
* GNU Mes is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with GNU Mes. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "mes/lib-mini.h"
|
||||||
|
|
||||||
|
void
|
||||||
|
_write (int filedes, void const *buffer, size_t size)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a0,0x10(%fp)");
|
||||||
|
asm ("ld_____%a1,0x18(%fp)");
|
||||||
|
asm ("ld_____%a2,0x20(%fp)");
|
||||||
|
asm ("li_____%a7,SYS_write");
|
||||||
|
asm ("ecall");
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
70
lib/linux/riscv64-mes-mescc/crt1.c
Normal file
70
lib/linux/riscv64-mes-mescc/crt1.c
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
/* -*-comment-start: "//";comment-end:""-*-
|
||||||
|
* GNU Mes --- Maxwell Equations of Software
|
||||||
|
* Copyright © 2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
|
* Copyright © 2021 W. J. van der Laan <laanwj@protonmail.com>
|
||||||
|
*
|
||||||
|
* This file is part of GNU Mes.
|
||||||
|
*
|
||||||
|
* GNU Mes is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or (at
|
||||||
|
* your option) any later version.
|
||||||
|
*
|
||||||
|
* GNU Mes is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with GNU Mes. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "mes/lib-mini.h"
|
||||||
|
int main (int argc, char *argv[], char *envp[]);
|
||||||
|
|
||||||
|
/* mesc will generate the following preamble:
|
||||||
|
|
||||||
|
push ra
|
||||||
|
push fp
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
_start ()
|
||||||
|
{
|
||||||
|
asm ("li_____%t0,$i16_0000 @0");
|
||||||
|
asm ("li_____%t1,$i32 &__stdin");
|
||||||
|
asm ("sw_____%t0,0(%t1)");
|
||||||
|
|
||||||
|
asm ("li_____%t0,$i16_0000 @1");
|
||||||
|
asm ("srai___%t0,16");
|
||||||
|
asm ("li_____%t1,$i32 &__stdout");
|
||||||
|
asm ("sw_____%t0,0(%t1)");
|
||||||
|
|
||||||
|
asm ("li_____%t0,$i16_0000 @2");
|
||||||
|
asm ("srai___%t0,16");
|
||||||
|
asm ("li_____%t1,$i32 &__stderr");
|
||||||
|
asm ("sw_____%t0,0(%t1)");
|
||||||
|
|
||||||
|
// environ is &argv[argc + 1]
|
||||||
|
asm ("mv_____%t1,%fp");
|
||||||
|
asm ("addi___%t1,%t1,$i8_8 !0x1"); // 0x10 to skip over pushed fp+ra, 0x8 to skip over argc
|
||||||
|
asm ("addi___%t5,%fp,$i8_0 !0x1"); // 0x10 to skip over pushed fp+ra
|
||||||
|
asm ("ld_____%t0,0(%t5)");
|
||||||
|
asm ("addi___%t0,%t0,1");
|
||||||
|
asm ("li_____%t5,$i32 %0x3"); // skip over all arguments and the final NULL
|
||||||
|
asm ("sll____%t0,%t0,%t5");
|
||||||
|
asm ("add____%t0,%t0,%t1");
|
||||||
|
asm ("push___%t0"); // envp
|
||||||
|
asm ("push___%t1"); // argv
|
||||||
|
asm ("li_____%t1,$i32 &environ");
|
||||||
|
asm ("sd_____%t0,0(%t1)");
|
||||||
|
asm ("addi___%t5,%fp,$i8_0 !0x1"); // 0x10 to skip over pushed fp+ra
|
||||||
|
asm ("ld_____%t0,0(%t5)");
|
||||||
|
asm ("push___%t0"); // argc
|
||||||
|
|
||||||
|
main ();
|
||||||
|
|
||||||
|
asm ("mv_____%a0,%t0");
|
||||||
|
asm ("li_____%a7,SYS_exit");
|
||||||
|
asm ("ecall");
|
||||||
|
asm ("ebreak");
|
||||||
|
}
|
56
lib/linux/riscv64-mes-mescc/syscall-internal.c
Normal file
56
lib/linux/riscv64-mes-mescc/syscall-internal.c
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
/* -*-comment-start: "//";comment-end:""-*-
|
||||||
|
* GNU Mes --- Maxwell Equations of Software
|
||||||
|
* Copyright © 2016,2017,2018,2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
|
* Copyright © 2021 W. J. van der Laan <laanwj@protonmail.com>
|
||||||
|
*
|
||||||
|
* This file is part of GNU Mes.
|
||||||
|
*
|
||||||
|
* GNU Mes is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or (at
|
||||||
|
* your option) any later version.
|
||||||
|
*
|
||||||
|
* GNU Mes is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with GNU Mes. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <linux/riscv64/syscall.h>
|
||||||
|
|
||||||
|
static long
|
||||||
|
__sys_call_internal (long sys_call)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a7,0x10(%fp)");
|
||||||
|
|
||||||
|
asm ("ecall");
|
||||||
|
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
||||||
|
|
||||||
|
static long
|
||||||
|
__sys_call2_internal (long sys_call, long one, long two)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a7,0x10(%fp)");
|
||||||
|
asm ("ld_____%a0,0x18(%fp)");
|
||||||
|
asm ("ld_____%a1,0x20(%fp)");
|
||||||
|
|
||||||
|
asm ("ecall");
|
||||||
|
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Return < 0 on error (errno-like value from kernel), or 0 on success */
|
||||||
|
int
|
||||||
|
__raise (int signum)
|
||||||
|
{
|
||||||
|
long pid = __sys_call_internal (SYS_getpid);
|
||||||
|
if (pid < 0)
|
||||||
|
return pid;
|
||||||
|
else
|
||||||
|
return __sys_call2_internal (SYS_kill, pid, signum);
|
||||||
|
}
|
182
lib/linux/riscv64-mes-mescc/syscall.c
Normal file
182
lib/linux/riscv64-mes-mescc/syscall.c
Normal file
|
@ -0,0 +1,182 @@
|
||||||
|
/* -*-comment-start: "//";comment-end:""-*-
|
||||||
|
* GNU Mes --- Maxwell Equations of Software
|
||||||
|
* Copyright © 2016,2017,2018,2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
|
* Copyright © 2021 W. J. van der Laan <laanwj@protonmail.com>
|
||||||
|
*
|
||||||
|
* This file is part of GNU Mes.
|
||||||
|
*
|
||||||
|
* GNU Mes is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or (at
|
||||||
|
* your option) any later version.
|
||||||
|
*
|
||||||
|
* GNU Mes is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with GNU Mes. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <linux/riscv64/syscall.h>
|
||||||
|
|
||||||
|
long
|
||||||
|
__sys_call (long sys_call)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a7,0x10(%fp)");
|
||||||
|
|
||||||
|
asm ("ecall");
|
||||||
|
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
__sys_call1 (long sys_call, long one)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a7,0x10(%fp)");
|
||||||
|
asm ("ld_____%a0,0x18(%fp)");
|
||||||
|
|
||||||
|
asm ("ecall");
|
||||||
|
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
__sys_call2 (long sys_call, long one, long two)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a7,0x10(%fp)");
|
||||||
|
asm ("ld_____%a0,0x18(%fp)");
|
||||||
|
asm ("ld_____%a1,0x20(%fp)");
|
||||||
|
|
||||||
|
asm ("ecall");
|
||||||
|
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
__sys_call3 (long sys_call, long one, long two, long three)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a7,0x10(%fp)");
|
||||||
|
asm ("ld_____%a0,0x18(%fp)");
|
||||||
|
asm ("ld_____%a1,0x20(%fp)");
|
||||||
|
asm ("ld_____%a2,0x28(%fp)");
|
||||||
|
|
||||||
|
asm ("ecall");
|
||||||
|
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
__sys_call4 (long sys_call, long one, long two, long three, long four)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a7,0x10(%fp)");
|
||||||
|
asm ("ld_____%a0,0x18(%fp)");
|
||||||
|
asm ("ld_____%a1,0x20(%fp)");
|
||||||
|
asm ("ld_____%a2,0x28(%fp)");
|
||||||
|
asm ("ld_____%a3,0x30(%fp)");
|
||||||
|
|
||||||
|
asm ("ecall");
|
||||||
|
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
__sys_call5 (long sys_call, long one, long two, long three, long four, long five)
|
||||||
|
{
|
||||||
|
asm ("ld_____%a7,0x10(%fp)");
|
||||||
|
asm ("ld_____%a0,0x18(%fp)");
|
||||||
|
asm ("ld_____%a1,0x20(%fp)");
|
||||||
|
asm ("ld_____%a2,0x28(%fp)");
|
||||||
|
asm ("ld_____%a3,0x30(%fp)");
|
||||||
|
asm ("ld_____%a4,0x38(%fp)");
|
||||||
|
|
||||||
|
asm ("ecall");
|
||||||
|
|
||||||
|
asm ("mv_____%t0,%a0");
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
_sys_call (long sys_call)
|
||||||
|
{
|
||||||
|
long r = __sys_call (sys_call);
|
||||||
|
if (r < 0)
|
||||||
|
{
|
||||||
|
errno = -r;
|
||||||
|
r = -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
errno = 0;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
_sys_call1 (long sys_call, long one)
|
||||||
|
{
|
||||||
|
long r = __sys_call1 (sys_call, one);
|
||||||
|
if (r < 0)
|
||||||
|
{
|
||||||
|
errno = -r;
|
||||||
|
r = -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
errno = 0;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
_sys_call2 (long sys_call, long one, long two)
|
||||||
|
{
|
||||||
|
long r = __sys_call2 (sys_call, one, two);
|
||||||
|
if (r < 0)
|
||||||
|
{
|
||||||
|
errno = -r;
|
||||||
|
r = -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
errno = 0;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
_sys_call3 (long sys_call, long one, long two, long three)
|
||||||
|
{
|
||||||
|
long r = __sys_call3 (sys_call, one, two, three);
|
||||||
|
if (r < 0)
|
||||||
|
{
|
||||||
|
errno = -r;
|
||||||
|
r = -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
errno = 0;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
_sys_call4 (long sys_call, long one, long two, long three, long four)
|
||||||
|
{
|
||||||
|
long r = __sys_call4 (sys_call, one, two, three, four);
|
||||||
|
if (r < 0)
|
||||||
|
{
|
||||||
|
errno = -r;
|
||||||
|
r = -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
errno = 0;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
long
|
||||||
|
_sys_call5 (long sys_call, long one, long two, long three, long four, long five)
|
||||||
|
{
|
||||||
|
long r = __sys_call5 (sys_call, one, two, three, four, five);
|
||||||
|
if (r < 0)
|
||||||
|
{
|
||||||
|
errno = -r;
|
||||||
|
r = -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
errno = 0;
|
||||||
|
return r;
|
||||||
|
}
|
Loading…
Reference in a new issue