toolchain: bump RISC-V support to a more recent staging branch
authorZoltan HERPAI <[email protected]>
Mon, 13 May 2019 22:50:03 +0000 (00:50 +0200)
committerZoltan HERPAI <[email protected]>
Mon, 13 May 2019 22:50:03 +0000 (00:50 +0200)
Signed-off-by: Zoltan HERPAI <[email protected]>
16 files changed:
toolchain/musl/patches/801-unistd-renameat-use-renameat2-when-appropriate.patch [new file with mode: 0644]
toolchain/musl/patches/802-stdio-rename-use-renameat2-when-appropriate.patch [new file with mode: 0644]
toolchain/musl/patches/803-mman-mlock-use-mlock2-when-appropriate.patch [new file with mode: 0644]
toolchain/musl/patches/804-RISC-V-add-riscv64-architecture-support.patch [new file with mode: 0644]
toolchain/musl/patches/805-riscv64-Fix-syscall_cp.patch [new file with mode: 0644]
toolchain/musl/patches/806-riscv64-add-cache-flush-syscall.patch [new file with mode: 0644]
toolchain/musl/patches/807-riscv64-don-t-define-SYS_renameat.patch [new file with mode: 0644]
toolchain/musl/patches/808-riscv64-Fix-fcntl-constants.patch [new file with mode: 0644]
toolchain/musl/patches/809-riscv64-Fix-soft-float-check.patch [new file with mode: 0644]
toolchain/musl/patches/810-riscv64-Support-soft-float.patch [new file with mode: 0644]
toolchain/musl/patches/811-riscv64-Fix-inline-asm-for-sqrt.patch [new file with mode: 0644]
toolchain/musl/patches/812-riscv64-jmp_buf-reorganization.patch [new file with mode: 0644]
toolchain/musl/patches/813-riscv64-Scrub-usage-of-j-jal.patch [new file with mode: 0644]
toolchain/musl/patches/814-riscv64-simplify-longjmp-return-value-assignment.patch [new file with mode: 0644]
toolchain/musl/patches/815-riscv64-s-scall-ecall-g.patch [new file with mode: 0644]
toolchain/musl/patches/902-RISC-V-add-riscv32-and-riscv64.patch [deleted file]

diff --git a/toolchain/musl/patches/801-unistd-renameat-use-renameat2-when-appropriate.patch b/toolchain/musl/patches/801-unistd-renameat-use-renameat2-when-appropriate.patch
new file mode 100644 (file)
index 0000000..82279a4
--- /dev/null
@@ -0,0 +1,26 @@
+From 79aae4f28f12ea23590fabc26e1e60514a7303c7 Mon Sep 17 00:00:00 2001
+From: Drew DeVault <[email protected]>
+Date: Thu, 21 Mar 2019 11:30:28 -0400
+Subject: [PATCH 01/15] unistd/renameat: use renameat2 when appropriate
+
+---
+ src/unistd/renameat.c | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+diff --git a/src/unistd/renameat.c b/src/unistd/renameat.c
+index 1257482..c3b40a2 100644
+--- a/src/unistd/renameat.c
++++ b/src/unistd/renameat.c
+@@ -3,5 +3,9 @@
+ int renameat(int oldfd, const char *old, int newfd, const char *new)
+ {
++#ifdef SYS_renameat
+       return syscall(SYS_renameat, oldfd, old, newfd, new);
++#else
++      return syscall(SYS_renameat2, oldfd, old, newfd, new, 0);
++#endif
+ }
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/802-stdio-rename-use-renameat2-when-appropriate.patch b/toolchain/musl/patches/802-stdio-rename-use-renameat2-when-appropriate.patch
new file mode 100644 (file)
index 0000000..cc71713
--- /dev/null
@@ -0,0 +1,30 @@
+From 4a8a79f6f3a52f10abe5cbe6204bc9b4180522a7 Mon Sep 17 00:00:00 2001
+From: Drew DeVault <[email protected]>
+Date: Thu, 21 Mar 2019 11:30:11 -0400
+Subject: [PATCH 02/15] stdio/rename: use renameat2 when appropriate
+
+---
+ src/stdio/rename.c | 6 ++++--
+ 1 file changed, 4 insertions(+), 2 deletions(-)
+
+diff --git a/src/stdio/rename.c b/src/stdio/rename.c
+index 04c90c0..f540adb 100644
+--- a/src/stdio/rename.c
++++ b/src/stdio/rename.c
+@@ -4,9 +4,11 @@
+ int rename(const char *old, const char *new)
+ {
+-#ifdef SYS_rename
++#if defined(SYS_rename)
+       return syscall(SYS_rename, old, new);
+-#else
++#elif defined(SYS_renameat)
+       return syscall(SYS_renameat, AT_FDCWD, old, AT_FDCWD, new);
++#else
++      return syscall(SYS_renameat2, AT_FDCWD, old, AT_FDCWD, new, 0);
+ #endif
+ }
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/803-mman-mlock-use-mlock2-when-appropriate.patch b/toolchain/musl/patches/803-mman-mlock-use-mlock2-when-appropriate.patch
new file mode 100644 (file)
index 0000000..1225b45
--- /dev/null
@@ -0,0 +1,26 @@
+From 5ffd928d81315911773b770fd5083b1cdf0e3184 Mon Sep 17 00:00:00 2001
+From: Drew DeVault <[email protected]>
+Date: Thu, 21 Mar 2019 11:29:59 -0400
+Subject: [PATCH 03/15] mman/mlock: use mlock2 when appropriate
+
+---
+ src/mman/mlock.c | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+diff --git a/src/mman/mlock.c b/src/mman/mlock.c
+index e683a44..71af582 100644
+--- a/src/mman/mlock.c
++++ b/src/mman/mlock.c
+@@ -3,5 +3,9 @@
+ int mlock(const void *addr, size_t len)
+ {
++#ifdef SYS_mlock
+       return syscall(SYS_mlock, addr, len);
++#else
++      return syscall(SYS_mlock2, addr, len, 0);
++#endif
+ }
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/804-RISC-V-add-riscv64-architecture-support.patch b/toolchain/musl/patches/804-RISC-V-add-riscv64-architecture-support.patch
new file mode 100644 (file)
index 0000000..e1b06bf
--- /dev/null
@@ -0,0 +1,1741 @@
+From 15f7339916c29c64b5c66439fab7383b434b02c2 Mon Sep 17 00:00:00 2001
+From: Drew DeVault <[email protected]>
+Date: Thu, 21 Mar 2019 12:21:49 -0400
+Subject: [PATCH 04/15] RISC-V: add riscv64 architecture support
+
+Author: Alex Suykov <[email protected]>
+Author: Aric Belsito <[email protected]>
+Author: Michael Clark <[email protected]>
+---
+ arch/riscv64/atomic_arch.h             |  66 ++++++++
+ arch/riscv64/bits/alltypes.h.in        |  29 ++++
+ arch/riscv64/bits/endian.h             |   5 +
+ arch/riscv64/bits/fcntl.h              |  38 +++++
+ arch/riscv64/bits/fenv.h               |  17 ++
+ arch/riscv64/bits/float.h              |  16 ++
+ arch/riscv64/bits/ipc.h                |  14 ++
+ arch/riscv64/bits/limits.h             |   7 +
+ arch/riscv64/bits/mman.h               |   1 +
+ arch/riscv64/bits/msg.h                |  13 ++
+ arch/riscv64/bits/posix.h              |   2 +
+ arch/riscv64/bits/reg.h                |   8 +
+ arch/riscv64/bits/sem.h                |   9 ++
+ arch/riscv64/bits/setjmp.h             |   1 +
+ arch/riscv64/bits/shm.h                |  26 +++
+ arch/riscv64/bits/signal.h             | 113 ++++++++++++++
+ arch/riscv64/bits/socket.h             |  33 ++++
+ arch/riscv64/bits/stat.h               |  18 +++
+ arch/riscv64/bits/stdint.h             |  20 +++
+ arch/riscv64/bits/syscall.h.in         | 278 +++++++++++++++++++++++++++++++++
+ arch/riscv64/bits/user.h               |  43 +++++
+ arch/riscv64/crt_arch.h                |  18 +++
+ arch/riscv64/pthread_arch.h            |  12 ++
+ arch/riscv64/reloc.h                   |  27 ++++
+ arch/riscv64/syscall_arch.h            |  76 +++++++++
+ configure                              |   6 +
+ crt/riscv64/crti.s                     |  11 ++
+ crt/riscv64/crtn.s                     |   0
+ include/elf.h                          |  56 +++++++
+ src/fenv/riscv64/fenv-sf.c             |   3 +
+ src/fenv/riscv64/fenv.S                |  53 +++++++
+ src/internal/riscv64/syscall.s         |  15 ++
+ src/ldso/riscv64/dlsym.s               |   6 +
+ src/math/riscv64/copysign.s            |   5 +
+ src/math/riscv64/copysignf.s           |   5 +
+ src/math/riscv64/fabs.s                |   5 +
+ src/math/riscv64/fabsf.s               |   5 +
+ src/math/riscv64/fma.s                 |   5 +
+ src/math/riscv64/fmaf.s                |   5 +
+ src/math/riscv64/fmax.s                |   5 +
+ src/math/riscv64/fmaxf.s               |   5 +
+ src/math/riscv64/fmin.s                |   5 +
+ src/math/riscv64/fminf.s               |   5 +
+ src/math/riscv64/sqrt.s                |   5 +
+ src/math/riscv64/sqrtf.s               |   5 +
+ src/setjmp/riscv64/longjmp.S           |  44 ++++++
+ src/setjmp/riscv64/setjmp.S            |  42 +++++
+ src/signal/riscv64/restore.s           |   8 +
+ src/signal/riscv64/sigsetjmp.s         |  21 +++
+ src/thread/riscv64/__set_thread_area.s |   6 +
+ src/thread/riscv64/__unmapself.s       |   7 +
+ src/thread/riscv64/clone.s             |  34 ++++
+ src/thread/riscv64/syscall_cp.s        |  29 ++++
+ 53 files changed, 1291 insertions(+)
+ create mode 100644 arch/riscv64/atomic_arch.h
+ create mode 100644 arch/riscv64/bits/alltypes.h.in
+ create mode 100644 arch/riscv64/bits/endian.h
+ create mode 100644 arch/riscv64/bits/fcntl.h
+ create mode 100644 arch/riscv64/bits/fenv.h
+ create mode 100644 arch/riscv64/bits/float.h
+ create mode 100644 arch/riscv64/bits/ipc.h
+ create mode 100644 arch/riscv64/bits/limits.h
+ create mode 100644 arch/riscv64/bits/mman.h
+ create mode 100644 arch/riscv64/bits/msg.h
+ create mode 100644 arch/riscv64/bits/posix.h
+ create mode 100644 arch/riscv64/bits/reg.h
+ create mode 100644 arch/riscv64/bits/sem.h
+ create mode 100644 arch/riscv64/bits/setjmp.h
+ create mode 100644 arch/riscv64/bits/shm.h
+ create mode 100644 arch/riscv64/bits/signal.h
+ create mode 100644 arch/riscv64/bits/socket.h
+ create mode 100644 arch/riscv64/bits/stat.h
+ create mode 100644 arch/riscv64/bits/stdint.h
+ create mode 100644 arch/riscv64/bits/syscall.h.in
+ create mode 100644 arch/riscv64/bits/user.h
+ create mode 100644 arch/riscv64/crt_arch.h
+ create mode 100644 arch/riscv64/pthread_arch.h
+ create mode 100644 arch/riscv64/reloc.h
+ create mode 100644 arch/riscv64/syscall_arch.h
+ create mode 100644 crt/riscv64/crti.s
+ create mode 100644 crt/riscv64/crtn.s
+ create mode 100644 src/fenv/riscv64/fenv-sf.c
+ create mode 100644 src/fenv/riscv64/fenv.S
+ create mode 100644 src/internal/riscv64/syscall.s
+ create mode 100644 src/ldso/riscv64/dlsym.s
+ create mode 100644 src/math/riscv64/copysign.s
+ create mode 100644 src/math/riscv64/copysignf.s
+ create mode 100644 src/math/riscv64/fabs.s
+ create mode 100644 src/math/riscv64/fabsf.s
+ create mode 100644 src/math/riscv64/fma.s
+ create mode 100644 src/math/riscv64/fmaf.s
+ create mode 100644 src/math/riscv64/fmax.s
+ create mode 100644 src/math/riscv64/fmaxf.s
+ create mode 100644 src/math/riscv64/fmin.s
+ create mode 100644 src/math/riscv64/fminf.s
+ create mode 100644 src/math/riscv64/sqrt.s
+ create mode 100644 src/math/riscv64/sqrtf.s
+ create mode 100644 src/setjmp/riscv64/longjmp.S
+ create mode 100644 src/setjmp/riscv64/setjmp.S
+ create mode 100644 src/signal/riscv64/restore.s
+ create mode 100644 src/signal/riscv64/sigsetjmp.s
+ create mode 100644 src/thread/riscv64/__set_thread_area.s
+ create mode 100644 src/thread/riscv64/__unmapself.s
+ create mode 100644 src/thread/riscv64/clone.s
+ create mode 100644 src/thread/riscv64/syscall_cp.s
+
+diff --git a/arch/riscv64/atomic_arch.h b/arch/riscv64/atomic_arch.h
+new file mode 100644
+index 0000000..018c7fd
+--- /dev/null
++++ b/arch/riscv64/atomic_arch.h
+@@ -0,0 +1,66 @@
++#define a_barrier a_barrier
++static inline void a_barrier()
++{
++      __asm__ __volatile__ ("fence rw,rw" : : : "memory");
++}
++
++#define a_ll a_ll
++static inline int a_ll(volatile int *p)
++{
++      int v;
++      __asm__ __volatile__ ("lr.w %0, %1" : "=&r"(v), "+A"(*p));
++      return v;
++}
++
++#define a_sc a_sc
++static inline int a_sc(volatile int *p, int v)
++{
++      int r;
++      __asm__ __volatile__ ("sc.w %0, %2, %1" : "=&r"(r), "+A"(*p) : "r"(v) : "memory");
++return !r;
++}
++
++#define a_cas a_cas
++static inline int a_cas(volatile int *p, int t, int s)
++{
++      int old, tmp;
++      __asm__("1:  lr.w    %0, %2      \n"
++              "    bne     %0, %3, 1f  \n"
++              "    sc.w    %1, %4, %2  \n"
++              "    bnez    %1, 1b      \n"
++              "1:                      \n"
++              : "=&r"(old), "+r"(tmp), "+A"(*p)
++              : "r"(t), "r"(s));
++      return old;
++}
++
++#define a_ll_p a_ll_p
++static inline void *a_ll_p(volatile void *p)
++{
++      void *v;
++      __asm__ __volatile__ ("lr.d %0, %1" : "=&r"(v), "+A"(*(long *)p));
++      return v;
++}
++
++#define a_sc_p a_sc_p
++static inline int a_sc_p(volatile int *p, void *v)
++{
++      int r;
++      __asm__ __volatile__ ("sc.d %0, %2, %1" : "=&r"(r), "+A"(*(long *)p) : "r"(v) : "memory");
++      return !r;
++}
++
++#define a_cas_p a_cas_p
++static inline void *a_cas_p(volatile void *p, void *t, void *s)
++{
++      void *old;
++      int tmp;
++      __asm__("1:  lr.d    %0, %2      \n"
++              "    bne     %0, %3, 1f  \n"
++              "    sc.d    %1, %4, %2  \n"
++              "    bnez    %1, 1b      \n"
++              "1:                      \n"
++              : "=&r"(old), "+r"(tmp), "+A"(*(long *)p)
++              : "r"(t), "r"(s));
++      return old;
++}
+diff --git a/arch/riscv64/bits/alltypes.h.in b/arch/riscv64/bits/alltypes.h.in
+new file mode 100644
+index 0000000..ae9ba41
+--- /dev/null
++++ b/arch/riscv64/bits/alltypes.h.in
+@@ -0,0 +1,29 @@
++#define _Addr long
++#define _Int64 long
++#define _Reg long
++
++TYPEDEF __builtin_va_list va_list;
++TYPEDEF __builtin_va_list __isoc_va_list;
++
++#ifndef __cplusplus
++TYPEDEF int wchar_t;
++#endif
++
++TYPEDEF int blksize_t;
++TYPEDEF unsigned int nlink_t;
++
++TYPEDEF float float_t;
++TYPEDEF double double_t;
++
++TYPEDEF struct { long long __ll; long double __ld; } max_align_t;
++
++TYPEDEF long time_t;
++TYPEDEF long suseconds_t;
++
++TYPEDEF struct { union { int __i[14]; volatile int __vi[14]; unsigned long __s[7]; } __u; } pthread_attr_t;
++TYPEDEF struct { union { int __i[10]; volatile int __vi[10]; volatile void *volatile __p[5]; } __u; } pthread_mutex_t;
++TYPEDEF struct { union { int __i[10]; volatile int __vi[10]; volatile void *volatile __p[5]; } __u; } mtx_t;
++TYPEDEF struct { union { int __i[12]; volatile int __vi[12]; void *__p[6]; } __u; } pthread_cond_t;
++TYPEDEF struct { union { int __i[12]; volatile int __vi[12]; void *__p[6]; } __u; } cnd_t;
++TYPEDEF struct { union { int __i[14]; volatile int __vi[14]; void *__p[7]; } __u; } pthread_rwlock_t;
++TYPEDEF struct { union { int __i[8]; volatile int __vi[8]; void *__p[4]; } __u; } pthread_barrier_t;
+diff --git a/arch/riscv64/bits/endian.h b/arch/riscv64/bits/endian.h
+new file mode 100644
+index 0000000..7df0e02
+--- /dev/null
++++ b/arch/riscv64/bits/endian.h
+@@ -0,0 +1,5 @@
++#if __RISCVEB__
++#define __BYTE_ORDER __BIG_ENDIAN
++#else
++#define __BYTE_ORDER __LITTLE_ENDIAN
++#endif
+diff --git a/arch/riscv64/bits/fcntl.h b/arch/riscv64/bits/fcntl.h
+new file mode 100644
+index 0000000..9278797
+--- /dev/null
++++ b/arch/riscv64/bits/fcntl.h
+@@ -0,0 +1,38 @@
++#define O_CREAT        0100
++#define O_EXCL         0200
++#define O_NOCTTY       0400
++#define O_TRUNC       01000
++#define O_APPEND      02000
++#define O_NONBLOCK    04000
++#define O_DSYNC      010000
++#define O_SYNC     04010000
++#define O_RSYNC    04010000
++#define O_DIRECTORY  040000
++#define O_NOFOLLOW  0100000
++#define O_CLOEXEC  02000000
++
++#define O_ASYNC      020000
++#define O_DIRECT    0200000
++#define O_LARGEFILE 0400000
++#define O_NOATIME  01000000
++#define O_PATH    010000000
++#define O_TMPFILE 020040000
++#define O_NDELAY O_NONBLOCK
++
++#define F_DUPFD  0
++#define F_GETFD  1
++#define F_SETFD  2
++#define F_GETFL  3
++#define F_SETFL  4
++#define F_GETLK  5
++#define F_SETLK  6
++#define F_SETLKW 7
++#define F_SETOWN 8
++#define F_GETOWN 9
++#define F_SETSIG 10
++#define F_GETSIG 11
++
++#define F_SETOWN_EX 15
++#define F_GETOWN_EX 16
++
++#define F_GETOWNER_UIDS 17
+diff --git a/arch/riscv64/bits/fenv.h b/arch/riscv64/bits/fenv.h
+new file mode 100644
+index 0000000..806ec40
+--- /dev/null
++++ b/arch/riscv64/bits/fenv.h
+@@ -0,0 +1,17 @@
++#define FE_INVALID      16
++#define FE_DIVBYZERO    8
++#define FE_OVERFLOW     4
++#define FE_UNDERFLOW    2
++#define FE_INEXACT      1
++
++#define FE_ALL_EXCEPT   31
++
++#define FE_TONEAREST    0
++#define FE_DOWNWARD     2
++#define FE_UPWARD       3
++#define FE_TOWARDZERO   1
++
++typedef unsigned int fexcept_t;
++typedef unsigned int fenv_t;
++
++#define FE_DFL_ENV      ((const fenv_t *) -1)
+diff --git a/arch/riscv64/bits/float.h b/arch/riscv64/bits/float.h
+new file mode 100644
+index 0000000..719c790
+--- /dev/null
++++ b/arch/riscv64/bits/float.h
+@@ -0,0 +1,16 @@
++#define FLT_EVAL_METHOD 0
++
++#define LDBL_TRUE_MIN 6.47517511943802511092443895822764655e-4966L
++#define LDBL_MIN 3.36210314311209350626267781732175260e-4932L
++#define LDBL_MAX 1.18973149535723176508575932662800702e+4932L
++#define LDBL_EPSILON 1.92592994438723585305597794258492732e-34L
++
++#define LDBL_MANT_DIG 113
++#define LDBL_MIN_EXP (-16381)
++#define LDBL_MAX_EXP 16384
++
++#define LDBL_DIG 33
++#define LDBL_MIN_10_EXP (-4931)
++#define LDBL_MAX_10_EXP 4932
++
++#define DECIMAL_DIG 36
+diff --git a/arch/riscv64/bits/ipc.h b/arch/riscv64/bits/ipc.h
+new file mode 100644
+index 0000000..6f3328a
+--- /dev/null
++++ b/arch/riscv64/bits/ipc.h
+@@ -0,0 +1,14 @@
++struct ipc_perm {
++      key_t __ipc_perm_key;
++      uid_t uid;
++      gid_t gid;
++      uid_t cuid;
++      gid_t cgid;
++      mode_t mode;
++      unsigned short __ipc_perm_seq;
++
++      unsigned long __pad1;
++      unsigned long __pad2;
++};
++
++#define IPC_64 0
+diff --git a/arch/riscv64/bits/limits.h b/arch/riscv64/bits/limits.h
+new file mode 100644
+index 0000000..0226588
+--- /dev/null
++++ b/arch/riscv64/bits/limits.h
+@@ -0,0 +1,7 @@
++#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
++ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
++#define LONG_BIT 64
++#endif
++
++#define LONG_MAX  0x7fffffffffffffffL
++#define LLONG_MAX  0x7fffffffffffffffLL
+diff --git a/arch/riscv64/bits/mman.h b/arch/riscv64/bits/mman.h
+new file mode 100644
+index 0000000..3695057
+--- /dev/null
++++ b/arch/riscv64/bits/mman.h
+@@ -0,0 +1 @@
++#define MAP_32BIT       0x40
+diff --git a/arch/riscv64/bits/msg.h b/arch/riscv64/bits/msg.h
+new file mode 100644
+index 0000000..641e170
+--- /dev/null
++++ b/arch/riscv64/bits/msg.h
+@@ -0,0 +1,13 @@
++struct msqid_ds {
++      struct ipc_perm msg_perm;
++      time_t msg_stime;
++      time_t msg_rtime;
++      time_t msg_ctime;
++      unsigned long msg_cbytes;
++      msgqnum_t msg_qnum;
++      msglen_t msg_qbytes;
++      pid_t msg_lspid;
++      pid_t msg_lrpid;
++      unsigned long __pad1;
++      unsigned long __pad2;
++};
+diff --git a/arch/riscv64/bits/posix.h b/arch/riscv64/bits/posix.h
+new file mode 100644
+index 0000000..8068ce9
+--- /dev/null
++++ b/arch/riscv64/bits/posix.h
+@@ -0,0 +1,2 @@
++#define _POSIX_V6_LP64_OFF64 1
++#define _POSIX_V7_LP64_OFF64 1
+diff --git a/arch/riscv64/bits/reg.h b/arch/riscv64/bits/reg.h
+new file mode 100644
+index 0000000..c800788
+--- /dev/null
++++ b/arch/riscv64/bits/reg.h
+@@ -0,0 +1,8 @@
++#undef __WORDSIZE
++#define __WORDSIZE 64
++#define REG_PC 0
++#define REG_RA 1
++#define REG_SP 2
++#define REG_TP 4
++#define REG_S0 8
++#define REG_A0 10
+diff --git a/arch/riscv64/bits/sem.h b/arch/riscv64/bits/sem.h
+new file mode 100644
+index 0000000..5f93c12
+--- /dev/null
++++ b/arch/riscv64/bits/sem.h
+@@ -0,0 +1,9 @@
++struct semid_ds {
++      struct ipc_perm sem_perm;
++      time_t sem_otime;
++      time_t sem_ctime;
++      unsigned short sem_nsems;
++      char __sem_nsems_pad[sizeof(time_t)-sizeof(short)];
++      time_t __unused3;
++      time_t __unused4;
++};
+diff --git a/arch/riscv64/bits/setjmp.h b/arch/riscv64/bits/setjmp.h
+new file mode 100644
+index 0000000..b6cdc8e
+--- /dev/null
++++ b/arch/riscv64/bits/setjmp.h
+@@ -0,0 +1 @@
++typedef unsigned long __jmp_buf[28];
+diff --git a/arch/riscv64/bits/shm.h b/arch/riscv64/bits/shm.h
+new file mode 100644
+index 0000000..f4b8712
+--- /dev/null
++++ b/arch/riscv64/bits/shm.h
+@@ -0,0 +1,26 @@
++#define SHMLBA 4096
++
++struct shmid_ds
++{
++      struct ipc_perm shm_perm;
++      size_t shm_segsz;
++      time_t shm_atime;
++      time_t shm_dtime;
++      time_t shm_ctime;
++      pid_t shm_cpid;
++      pid_t shm_lpid;
++      unsigned long shm_nattch;
++      unsigned long __pad1;
++      unsigned long __pad2;
++};
++
++struct shminfo {
++      unsigned long shmmax, shmmin, shmmni, shmseg, shmall, __unused[4];
++};
++
++struct shm_info {
++      int __used_ids;
++      unsigned long shm_tot, shm_rss, shm_swp;
++      unsigned long __swap_attempts, __swap_successes;
++};
++
+diff --git a/arch/riscv64/bits/signal.h b/arch/riscv64/bits/signal.h
+new file mode 100644
+index 0000000..8b992cc
+--- /dev/null
++++ b/arch/riscv64/bits/signal.h
+@@ -0,0 +1,113 @@
++#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
++ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
++
++#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
++# define MINSIGSTKSZ 2048
++# define SIGSTKSZ 8192
++#endif
++
++/* gregs[0] holds the program counter. */
++
++#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
++typedef unsigned long greg_t;
++typedef unsigned long gregset_t[32];
++
++struct __riscv_f_ext_state {
++      unsigned int f[32];
++      unsigned int fcsr;
++};
++
++struct __riscv_d_ext_state {
++      unsigned long long f[32];
++      unsigned int fcsr;
++};
++
++struct __riscv_q_ext_state {
++      unsigned long long f[64] __attribute__((aligned(16)));
++      unsigned int fcsr;
++      unsigned int reserved[3];
++};
++
++union __riscv_fp_state {
++      struct __riscv_f_ext_state f;
++      struct __riscv_d_ext_state d;
++      struct __riscv_q_ext_state q;
++};
++
++typedef union __riscv_fp_state fpregset_t;
++
++typedef struct sigcontext {
++      gregset_t gregs;
++      fpregset_t fpregs;
++} mcontext_t;
++
++#else
++typedef struct {
++      unsigned long gregs[32];
++      unsigned long long fpregs[66];
++} mcontext_t;
++#endif
++
++struct sigaltstack {
++      void *ss_sp;
++      int ss_flags;
++      size_t ss_size;
++};
++
++typedef struct __ucontext
++{
++      unsigned long uc_flags;
++      struct __ucontext *uc_link;
++      stack_t uc_stack;
++      sigset_t uc_sigmask;
++      char __unused[1024 / 8 - sizeof(sigset_t)];
++      mcontext_t uc_mcontext;
++} ucontext_t;
++
++#define SA_NOCLDSTOP 1
++#define SA_NOCLDWAIT 2
++#define SA_SIGINFO   4
++#define SA_ONSTACK   0x08000000
++#define SA_RESTART   0x10000000
++#define SA_NODEFER   0x40000000
++#define SA_RESETHAND 0x80000000
++#define SA_RESTORER  0x04000000
++
++#endif
++
++#define SIGHUP     1
++#define SIGINT     2
++#define SIGQUIT    3
++#define SIGILL     4
++#define SIGTRAP    5
++#define SIGABRT    6
++#define SIGIOT     SIGABRT
++#define SIGBUS     7
++#define SIGFPE     8
++#define SIGKILL    9
++#define SIGUSR1   10
++#define SIGSEGV   11
++#define SIGUSR2   12
++#define SIGPIPE   13
++#define SIGALRM   14
++#define SIGTERM   15
++#define SIGSTKFLT 16
++#define SIGCHLD   17
++#define SIGCONT   18
++#define SIGSTOP   19
++#define SIGTSTP   20
++#define SIGTTIN   21
++#define SIGTTOU   22
++#define SIGURG    23
++#define SIGXCPU   24
++#define SIGXFSZ   25
++#define SIGVTALRM 26
++#define SIGPROF   27
++#define SIGWINCH  28
++#define SIGIO     29
++#define SIGPOLL   SIGIO
++#define SIGPWR    30
++#define SIGSYS    31
++#define SIGUNUSED SIGSYS
++
++#define _NSIG     65
+diff --git a/arch/riscv64/bits/socket.h b/arch/riscv64/bits/socket.h
+new file mode 100644
+index 0000000..c11677e
+--- /dev/null
++++ b/arch/riscv64/bits/socket.h
+@@ -0,0 +1,33 @@
++#include <endian.h>
++
++struct msghdr {
++      void *msg_name;
++      socklen_t msg_namelen;
++      struct iovec *msg_iov;
++#if __BYTE_ORDER == __BIG_ENDIAN
++      int __pad1, msg_iovlen;
++#else
++      int msg_iovlen, __pad1;
++#endif
++      void *msg_control;
++#if __BYTE_ORDER == __BIG_ENDIAN
++      int __pad2;
++      socklen_t msg_controllen;
++#else
++      socklen_t msg_controllen;
++      int __pad2;
++#endif
++      int msg_flags;
++};
++
++struct cmsghdr {
++#if __BYTE_ORDER == __BIG_ENDIAN
++      int __pad1;
++      socklen_t cmsg_len;
++#else
++      socklen_t cmsg_len;
++      int __pad1;
++#endif
++      int cmsg_level;
++      int cmsg_type;
++};
+diff --git a/arch/riscv64/bits/stat.h b/arch/riscv64/bits/stat.h
+new file mode 100644
+index 0000000..b7f4221
+--- /dev/null
++++ b/arch/riscv64/bits/stat.h
+@@ -0,0 +1,18 @@
++struct stat {
++      dev_t st_dev;
++      ino_t st_ino;
++      mode_t st_mode;
++      nlink_t st_nlink;
++      uid_t st_uid;
++      gid_t st_gid;
++      dev_t st_rdev;
++      unsigned long __pad;
++      off_t st_size;
++      blksize_t st_blksize;
++      int __pad2;
++      blkcnt_t st_blocks;
++      struct timespec st_atim;
++      struct timespec st_mtim;
++      struct timespec st_ctim;
++      unsigned __unused[2];
++};
+diff --git a/arch/riscv64/bits/stdint.h b/arch/riscv64/bits/stdint.h
+new file mode 100644
+index 0000000..1bb147f
+--- /dev/null
++++ b/arch/riscv64/bits/stdint.h
+@@ -0,0 +1,20 @@
++typedef int32_t int_fast16_t;
++typedef int32_t int_fast32_t;
++typedef uint32_t uint_fast16_t;
++typedef uint32_t uint_fast32_t;
++
++#define INT_FAST16_MIN  INT32_MIN
++#define INT_FAST32_MIN  INT32_MIN
++
++#define INT_FAST16_MAX  INT32_MAX
++#define INT_FAST32_MAX  INT32_MAX
++
++#define UINT_FAST16_MAX UINT32_MAX
++#define UINT_FAST32_MAX UINT32_MAX
++
++#define INTPTR_MIN      INT64_MIN
++#define INTPTR_MAX      INT64_MAX
++#define UINTPTR_MAX     UINT64_MAX
++#define PTRDIFF_MIN     INT64_MIN
++#define PTRDIFF_MAX     INT64_MAX
++#define SIZE_MAX        UINT64_MAX
+diff --git a/arch/riscv64/bits/syscall.h.in b/arch/riscv64/bits/syscall.h.in
+new file mode 100644
+index 0000000..3c81c10
+--- /dev/null
++++ b/arch/riscv64/bits/syscall.h.in
+@@ -0,0 +1,278 @@
++#define __NR_io_setup 0
++#define __NR_io_destroy 1
++#define __NR_io_submit 2
++#define __NR_io_cancel 3
++#define __NR_io_getevents 4
++#define __NR_setxattr 5
++#define __NR_lsetxattr 6
++#define __NR_fsetxattr 7
++#define __NR_getxattr 8
++#define __NR_lgetxattr 9
++#define __NR_fgetxattr 10
++#define __NR_listxattr 11
++#define __NR_llistxattr 12
++#define __NR_flistxattr 13
++#define __NR_removexattr 14
++#define __NR_lremovexattr 15
++#define __NR_fremovexattr 16
++#define __NR_getcwd 17
++#define __NR_lookup_dcookie 18
++#define __NR_eventfd2 19
++#define __NR_epoll_create1 20
++#define __NR_epoll_ctl 21
++#define __NR_epoll_pwait 22
++#define __NR_dup 23
++#define __NR_dup3 24
++#define __NR_fcntl 25
++#define __NR_inotify_init1 26
++#define __NR_inotify_add_watch 27
++#define __NR_inotify_rm_watch 28
++#define __NR_ioctl 29
++#define __NR_ioprio_set 30
++#define __NR_ioprio_get 31
++#define __NR_flock 32
++#define __NR_mknodat 33
++#define __NR_mkdirat 34
++#define __NR_unlinkat 35
++#define __NR_symlinkat 36
++#define __NR_linkat 37
++#define __NR_renameat 38
++#define __NR_umount2 39
++#define __NR_mount 40
++#define __NR_pivot_root 41
++#define __NR_nfsservctl 42
++#define __NR_statfs 43
++#define __NR_fstatfs 44
++#define __NR_truncate 45
++#define __NR_ftruncate 46
++#define __NR_fallocate 47
++#define __NR_faccessat 48
++#define __NR_chdir 49
++#define __NR_fchdir 50
++#define __NR_chroot 51
++#define __NR_fchmod 52
++#define __NR_fchmodat 53
++#define __NR_fchownat 54
++#define __NR_fchown 55
++#define __NR_openat 56
++#define __NR_close 57
++#define __NR_vhangup 58
++#define __NR_pipe2 59
++#define __NR_quotactl 60
++#define __NR_getdents64 61
++#define __NR_lseek 62
++#define __NR_read 63
++#define __NR_write 64
++#define __NR_readv 65
++#define __NR_writev 66
++#define __NR_pread64 67
++#define __NR_pwrite64 68
++#define __NR_preadv 69
++#define __NR_pwritev 70
++#define __NR_sendfile 71
++#define __NR_pselect6 72
++#define __NR_ppoll 73
++#define __NR_signalfd4 74
++#define __NR_vmsplice 75
++#define __NR_splice 76
++#define __NR_tee 77
++#define __NR_readlinkat 78
++#define __NR_fstatat 79
++#define __NR_fstat 80
++#define __NR_sync 81
++#define __NR_fsync 82
++#define __NR_fdatasync 83
++#define __NR_sync_file_range 84
++#define __NR_timerfd_create 85
++#define __NR_timerfd_settime 86
++#define __NR_timerfd_gettime 87
++#define __NR_utimensat 88
++#define __NR_acct 89
++#define __NR_capget 90
++#define __NR_capset 91
++#define __NR_personality 92
++#define __NR_exit 93
++#define __NR_exit_group 94
++#define __NR_waitid 95
++#define __NR_set_tid_address 96
++#define __NR_unshare 97
++#define __NR_futex 98
++#define __NR_set_robust_list 99
++#define __NR_get_robust_list 100
++#define __NR_nanosleep 101
++#define __NR_getitimer 102
++#define __NR_setitimer 103
++#define __NR_kexec_load 104
++#define __NR_init_module 105
++#define __NR_delete_module 106
++#define __NR_timer_create 107
++#define __NR_timer_gettime 108
++#define __NR_timer_getoverrun 109
++#define __NR_timer_settime 110
++#define __NR_timer_delete 111
++#define __NR_clock_settime 112
++#define __NR_clock_gettime 113
++#define __NR_clock_getres 114
++#define __NR_clock_nanosleep 115
++#define __NR_syslog 116
++#define __NR_ptrace 117
++#define __NR_sched_setparam 118
++#define __NR_sched_setscheduler 119
++#define __NR_sched_getscheduler 120
++#define __NR_sched_getparam 121
++#define __NR_sched_setaffinity 122
++#define __NR_sched_getaffinity 123
++#define __NR_sched_yield 124
++#define __NR_sched_get_priority_max 125
++#define __NR_sched_get_priority_min 126
++#define __NR_sched_rr_get_interval 127
++#define __NR_restart_syscall 128
++#define __NR_kill 129
++#define __NR_tkill 130
++#define __NR_tgkill 131
++#define __NR_sigaltstack 132
++#define __NR_rt_sigsuspend 133
++#define __NR_rt_sigaction 134
++#define __NR_rt_sigprocmask 135
++#define __NR_rt_sigpending 136
++#define __NR_rt_sigtimedwait 137
++#define __NR_rt_sigqueueinfo 138
++#define __NR_rt_sigreturn 139
++#define __NR_setpriority 140
++#define __NR_getpriority 141
++#define __NR_reboot 142
++#define __NR_setregid 143
++#define __NR_setgid 144
++#define __NR_setreuid 145
++#define __NR_setuid 146
++#define __NR_setresuid 147
++#define __NR_getresuid 148
++#define __NR_setresgid 149
++#define __NR_getresgid 150
++#define __NR_setfsuid 151
++#define __NR_setfsgid 152
++#define __NR_times 153
++#define __NR_setpgid 154
++#define __NR_getpgid 155
++#define __NR_getsid 156
++#define __NR_setsid 157
++#define __NR_getgroups 158
++#define __NR_setgroups 159
++#define __NR_uname 160
++#define __NR_sethostname 161
++#define __NR_setdomainname 162
++#define __NR_getrlimit 163
++#define __NR_setrlimit 164
++#define __NR_getrusage 165
++#define __NR_umask 166
++#define __NR_prctl 167
++#define __NR_getcpu 168
++#define __NR_gettimeofday 169
++#define __NR_settimeofday 170
++#define __NR_adjtimex 171
++#define __NR_getpid 172
++#define __NR_getppid 173
++#define __NR_getuid 174
++#define __NR_geteuid 175
++#define __NR_getgid 176
++#define __NR_getegid 177
++#define __NR_gettid 178
++#define __NR_sysinfo 179
++#define __NR_mq_open 180
++#define __NR_mq_unlink 181
++#define __NR_mq_timedsend 182
++#define __NR_mq_timedreceive 183
++#define __NR_mq_notify 184
++#define __NR_mq_getsetattr 185
++#define __NR_msgget 186
++#define __NR_msgctl 187
++#define __NR_msgrcv 188
++#define __NR_msgsnd 189
++#define __NR_semget 190
++#define __NR_semctl 191
++#define __NR_semtimedop 192
++#define __NR_semop 193
++#define __NR_shmget 194
++#define __NR_shmctl 195
++#define __NR_shmat 196
++#define __NR_shmdt 197
++#define __NR_socket 198
++#define __NR_socketpair 199
++#define __NR_bind 200
++#define __NR_listen 201
++#define __NR_accept 202
++#define __NR_connect 203
++#define __NR_getsockname 204
++#define __NR_getpeername 205
++#define __NR_sendto 206
++#define __NR_recvfrom 207
++#define __NR_setsockopt 208
++#define __NR_getsockopt 209
++#define __NR_shutdown 210
++#define __NR_sendmsg 211
++#define __NR_recvmsg 212
++#define __NR_readahead 213
++#define __NR_brk 214
++#define __NR_munmap 215
++#define __NR_mremap 216
++#define __NR_add_key 217
++#define __NR_request_key 218
++#define __NR_keyctl 219
++#define __NR_clone 220
++#define __NR_execve 221
++#define __NR_mmap 222
++#define __NR_fadvise64 223
++#define __NR_swapon 224
++#define __NR_swapoff 225
++#define __NR_mprotect 226
++#define __NR_msync 227
++#define __NR_mlock 228
++#define __NR_munlock 229
++#define __NR_mlockall 230
++#define __NR_munlockall 231
++#define __NR_mincore 232
++#define __NR_madvise 233
++#define __NR_remap_file_pages 234
++#define __NR_mbind 235
++#define __NR_get_mempolicy 236
++#define __NR_set_mempolicy 237
++#define __NR_migrate_pages 238
++#define __NR_move_pages 239
++#define __NR_rt_tgsigqueueinfo 240
++#define __NR_perf_event_open 241
++#define __NR_accept4 242
++#define __NR_recvmmsg 243
++#define __NR_arch_specific_syscall 244
++#define __NR_wait4 260
++#define __NR_prlimit64 261
++#define __NR_fanotify_init 262
++#define __NR_fanotify_mark 263
++#define __NR_name_to_handle_at 264
++#define __NR_open_by_handle_at 265
++#define __NR_clock_adjtime 266
++#define __NR_syncfs 267
++#define __NR_setns 268
++#define __NR_sendmmsg 269
++#define __NR_process_vm_readv 270
++#define __NR_process_vm_writev 271
++#define __NR_kcmp 272
++#define __NR_finit_module 273
++#define __NR_sched_setattr 274
++#define __NR_sched_getattr 275
++#define __NR_renameat2 276
++#define __NR_seccomp 277
++#define __NR_getrandom 278
++#define __NR_memfd_create 279
++#define __NR_bpf 280
++#define __NR_execveat 281
++#define __NR_userfaultfd 282
++#define __NR_membarrier 283
++#define __NR_mlock2 284
++#define __NR_copy_file_range 285
++#define __NR_preadv2 286
++#define __NR_pwritev2 287
++#define __NR_pkey_mprotect 288
++#define __NR_pkey_alloc 289
++#define __NR_pkey_free 290
++#define __NR_sysriscv __NR_arch_specific_syscall
++
+diff --git a/arch/riscv64/bits/user.h b/arch/riscv64/bits/user.h
+new file mode 100644
+index 0000000..bd0f0fc
+--- /dev/null
++++ b/arch/riscv64/bits/user.h
+@@ -0,0 +1,43 @@
++struct user_regs_struct {
++      unsigned long pc;
++      unsigned long ra;
++      unsigned long sp;
++      unsigned long gp;
++      unsigned long tp;
++      unsigned long t0;
++      unsigned long t1;
++      unsigned long t2;
++      unsigned long s0;
++      unsigned long s1;
++      unsigned long a0;
++      unsigned long a1;
++      unsigned long a2;
++      unsigned long a3;
++      unsigned long a4;
++      unsigned long a5;
++      unsigned long a6;
++      unsigned long a7;
++      unsigned long s2;
++      unsigned long s3;
++      unsigned long s4;
++      unsigned long s5;
++      unsigned long s6;
++      unsigned long s7;
++      unsigned long s8;
++      unsigned long s9;
++      unsigned long s10;
++      unsigned long s11;
++      unsigned long t3;
++      unsigned long t4;
++      unsigned long t5;
++      unsigned long t6;
++};
++
++struct user_fpregs_struct {
++      double f[32];
++      unsigned int fcsr;
++};
++
++#define ELF_NGREG 32
++typedef unsigned long elf_greg_t, elf_gregset_t[ELF_NGREG];
++typedef struct user_fpregs_struct elf_fpregset_t;
+diff --git a/arch/riscv64/crt_arch.h b/arch/riscv64/crt_arch.h
+new file mode 100644
+index 0000000..d0e32a6
+--- /dev/null
++++ b/arch/riscv64/crt_arch.h
+@@ -0,0 +1,18 @@
++__asm__(
++".text\n"
++".global " START "\n"
++".type " START ",%function\n"
++START ":\n"
++".weak __global_pointer$\n"
++".hidden __global_pointer$\n"
++".option push\n"
++".option norelax\n\t"
++"lla gp, __global_pointer$\n"
++".option pop\n\t"
++"mv a0, sp\n"
++".weak _DYNAMIC\n"
++".hidden _DYNAMIC\n\t"
++"lla a1, _DYNAMIC\n\t"
++"andi sp, sp, -16\n\t"
++"jal " START "_c"
++);
+diff --git a/arch/riscv64/pthread_arch.h b/arch/riscv64/pthread_arch.h
+new file mode 100644
+index 0000000..feffaa4
+--- /dev/null
++++ b/arch/riscv64/pthread_arch.h
+@@ -0,0 +1,12 @@
++static inline struct pthread *__pthread_self()
++{
++      char *tp;
++      __asm__ __volatile__("mv %0, tp" : "=r"(tp));
++      return (void *)(tp - sizeof(struct pthread));
++}
++
++#define TLS_ABOVE_TP
++#define GAP_ABOVE_TP 0
++#define TP_ADJ(p) ((char *)p + sizeof(struct pthread))
++
++#define MC_PC gregs[0]
+diff --git a/arch/riscv64/reloc.h b/arch/riscv64/reloc.h
+new file mode 100644
+index 0000000..8bd90dd
+--- /dev/null
++++ b/arch/riscv64/reloc.h
+@@ -0,0 +1,27 @@
++#if defined __riscv_float_abi_soft
++#define RISCV_FP_SUFFIX "-sf"
++#elif defined __riscv_float_abi_single
++#define RISCV_FP_SUFFIX "-sp"
++#elif defined __riscv_float_abi_double
++#define RISCV_FP_SUFFIX ""
++#endif
++
++#define RISCV_LDSO_HELPER(x) "riscv" #x
++#define RISCV_LDSO(x) RISCV_LDSO_HELPER(x)
++
++#define LDSO_ARCH RISCV_LDSO(__riscv_xlen) RISCV_FP_SUFFIX
++
++#define NO_LEGACY_INITFINI
++
++#define TPOFF_K 0
++
++#define REL_SYMBOLIC    R_RISCV_64
++#define REL_PLT         R_RISCV_JUMP_SLOT
++#define REL_RELATIVE    R_RISCV_RELATIVE
++#define REL_COPY        R_RISCV_COPY
++#define REL_DTPMOD      R_RISCV_TLS_DTPMOD64
++#define REL_DTPOFF      R_RISCV_TLS_DTPREL64
++#define REL_TPOFF       R_RISCV_TLS_TPREL64
++
++#define CRTJMP(pc,sp) __asm__ __volatile__( \
++      "mv sp, %1 ; jr %0" : : "r"(pc), "r"(sp) : "memory" )
+diff --git a/arch/riscv64/syscall_arch.h b/arch/riscv64/syscall_arch.h
+new file mode 100644
+index 0000000..7b6e3fd
+--- /dev/null
++++ b/arch/riscv64/syscall_arch.h
+@@ -0,0 +1,76 @@
++#define __SYSCALL_LL_E(x) (x)
++#define __SYSCALL_LL_O(x) (x)
++
++#define __asm_syscall(...) \
++      __asm__ __volatile__ ("scall\n\t" \
++      : "+r"(a0) : __VA_ARGS__ : "memory"); \
++      return a0; \
++
++static inline long __syscall0(long n)
++{
++      register long a7 __asm__("a7") = n;
++      register long a0 __asm__("a0");
++      __asm_syscall("r"(a7))
++}
++
++static inline long __syscall1(long n, long a)
++{
++      register long a7 __asm__("a7") = n;
++      register long a0 __asm__("a0") = a;
++      __asm_syscall("r"(a7), "0"(a0))
++}
++
++static inline long __syscall2(long n, long a, long b)
++{
++      register long a7 __asm__("a7") = n;
++      register long a0 __asm__("a0") = a;
++      register long a1 __asm__("a1") = b;
++      __asm_syscall("r"(a7), "0"(a0), "r"(a1))
++}
++
++static inline long __syscall3(long n, long a, long b, long c)
++{
++      register long a7 __asm__("a7") = n;
++      register long a0 __asm__("a0") = a;
++      register long a1 __asm__("a1") = b;
++      register long a2 __asm__("a2") = c;
++      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2))
++}
++
++static inline long __syscall4(long n, long a, long b, long c, long d)
++{
++      register long a7 __asm__("a7") = n;
++      register long a0 __asm__("a0") = a;
++      register long a1 __asm__("a1") = b;
++      register long a2 __asm__("a2") = c;
++      register long a3 __asm__("a3") = d;
++      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3))
++}
++
++static inline long __syscall5(long n, long a, long b, long c, long d, long e)
++{
++      register long a7 __asm__("a7") = n;
++      register long a0 __asm__("a0") = a;
++      register long a1 __asm__("a1") = b;
++      register long a2 __asm__("a2") = c;
++      register long a3 __asm__("a3") = d;
++      register long a4 __asm__("a4") = e;
++      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3), "r"(a4))
++}
++
++static inline long __syscall6(long n, long a, long b, long c, long d, long e, long f)
++{
++      register long a7 __asm__("a7") = n;
++      register long a0 __asm__("a0") = a;
++      register long a1 __asm__("a1") = b;
++      register long a2 __asm__("a2") = c;
++      register long a3 __asm__("a3") = d;
++      register long a4 __asm__("a4") = e;
++      register long a5 __asm__("a5") = f;
++      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3), "r"(a4), "r"(a5))
++}
++
++#define VDSO_USEFUL
++/* We don't have a clock_gettime function.
++#define VDSO_CGT_SYM "__vdso_clock_gettime"
++#define VDSO_CGT_VER "LINUX_2.6" */
+diff --git a/configure b/configure
+index 6310e0b..ef39686 100755
+--- a/configure
++++ b/configure
+@@ -322,6 +322,7 @@ microblaze*) ARCH=microblaze ;;
+ or1k*) ARCH=or1k ;;
+ powerpc64*|ppc64*) ARCH=powerpc64 ;;
+ powerpc*|ppc*) ARCH=powerpc ;;
++riscv64*) ARCH=riscv64 ;;
+ sh[1-9bel-]*|sh|superh*) ARCH=sh ;;
+ s390x*) ARCH=s390x ;;
+ unknown) fail "$0: unable to detect target arch; try $0 --target=..." ;;
+@@ -640,6 +641,11 @@ trycppif __LITTLE_ENDIAN__ "$t" && SUBARCH=${SUBARCH}le
+ trycppif _SOFT_FLOAT "$t" && fail "$0: error: soft-float not supported on powerpc64"
+ fi
++if test "$ARCH" = "riscv64" ; then
++trycppif "RISCVEB || _RISCVEB || __RISCVEB || __RISCVEB__" "$t" && SUBARCH=${SUBARCH}eb
++trycppif __riscv_soft_float "$t" && SUBARCH=${SUBARCH}-sf
++fi
++
+ if test "$ARCH" = "sh" ; then
+ tryflag CFLAGS_AUTO -Wa,--isa=any
+ trycppif __BIG_ENDIAN__ "$t" && SUBARCH=${SUBARCH}eb
+diff --git a/crt/riscv64/crti.s b/crt/riscv64/crti.s
+new file mode 100644
+index 0000000..8b54a65
+--- /dev/null
++++ b/crt/riscv64/crti.s
+@@ -0,0 +1,11 @@
++.section .init
++.global _init
++.type _init,%function
++_init:
++        ret
++
++.section .fini
++.global _fini
++.type _fini %function
++_fini:
++        ret
+diff --git a/crt/riscv64/crtn.s b/crt/riscv64/crtn.s
+new file mode 100644
+index 0000000..e69de29
+diff --git a/include/elf.h b/include/elf.h
+index aad522e..41e6e0c 100644
+--- a/include/elf.h
++++ b/include/elf.h
+@@ -3226,6 +3226,62 @@ enum
+ #define R_BPF_NONE            0
+ #define R_BPF_MAP_FD          1
++#define R_RISCV_NONE            0
++#define R_RISCV_32              1
++#define R_RISCV_64              2
++#define R_RISCV_RELATIVE        3
++#define R_RISCV_COPY            4
++#define R_RISCV_JUMP_SLOT       5
++#define R_RISCV_TLS_DTPMOD32    6
++#define R_RISCV_TLS_DTPMOD64    7
++#define R_RISCV_TLS_DTPREL32    8
++#define R_RISCV_TLS_DTPREL64    9
++#define R_RISCV_TLS_TPREL32     10
++#define R_RISCV_TLS_TPREL64     11
++
++#define R_RISCV_BRANCH          16
++#define R_RISCV_JAL             17
++#define R_RISCV_CALL            18
++#define R_RISCV_CALL_PLT        19
++#define R_RISCV_GOT_HI20        20
++#define R_RISCV_TLS_GOT_HI20    21
++#define R_RISCV_TLS_GD_HI20     22
++#define R_RISCV_PCREL_HI20      23
++#define R_RISCV_PCREL_LO12_I    24
++#define R_RISCV_PCREL_LO12_S    25
++#define R_RISCV_HI20            26
++#define R_RISCV_LO12_I          27
++#define R_RISCV_LO12_S          28
++#define R_RISCV_TPREL_HI20      29
++#define R_RISCV_TPREL_LO12_I    30
++#define R_RISCV_TPREL_LO12_S    31
++#define R_RISCV_TPREL_ADD       32
++#define R_RISCV_ADD8            33
++#define R_RISCV_ADD16           34
++#define R_RISCV_ADD32           35
++#define R_RISCV_ADD64           36
++#define R_RISCV_SUB8            37
++#define R_RISCV_SUB16           38
++#define R_RISCV_SUB32           39
++#define R_RISCV_SUB64           40
++#define R_RISCV_GNU_VTINHERIT   41
++#define R_RISCV_GNU_VTENTRY     42
++#define R_RISCV_ALIGN           43
++#define R_RISCV_RVC_BRANCH      44
++#define R_RISCV_RVC_JUMP        45
++#define R_RISCV_RVC_LUI         46
++#define R_RISCV_GPREL_I         47
++#define R_RISCV_GPREL_S         48
++#define R_RISCV_TPREL_I         49
++#define R_RISCV_TPREL_S         50
++#define R_RISCV_RELAX           51
++#define R_RISCV_SUB6            52
++#define R_RISCV_SET6            53
++#define R_RISCV_SET8            54
++#define R_RISCV_SET16           55
++#define R_RISCV_SET32           56
++#define R_RISCV_32_PCREL        57
++
+ #ifdef __cplusplus
+ }
+ #endif
+diff --git a/src/fenv/riscv64/fenv-sf.c b/src/fenv/riscv64/fenv-sf.c
+new file mode 100644
+index 0000000..9ff7b79
+--- /dev/null
++++ b/src/fenv/riscv64/fenv-sf.c
+@@ -0,0 +1,3 @@
++#ifdef __riscv_soft_float
++#include "../fenv.c"
++#endif
+diff --git a/src/fenv/riscv64/fenv.S b/src/fenv/riscv64/fenv.S
+new file mode 100644
+index 0000000..a55aa4a
+--- /dev/null
++++ b/src/fenv/riscv64/fenv.S
+@@ -0,0 +1,53 @@
++#ifndef __riscv_soft_float
++
++.global feclearexcept
++.type feclearexcept, %function
++feclearexcept:
++        csrc fflags, a0
++        li a0, 0
++        ret
++
++.global feraiseexcept
++.type feraiseexcept, %function
++feraiseexcept:
++        csrs fflags, a0
++        li a0, 0
++        ret
++
++.global fetestexcept
++.type fetestexcept, %function
++fetestexcept:
++        frflags t0
++        and a0, t0, a0
++        ret
++
++.global fegetround
++.type fegetround, %function
++fegetround:
++        frrm a0
++        ret
++
++.global __fesetround
++.type __fesetround, %function
++__fesetround:
++        fsrm t0, a0
++        li a0, 0
++        ret
++
++.global fegetenv
++.type fegetenv, %function
++fegetenv:
++        frcsr t0
++        sw t0, 0(a0)
++        li a0, 0
++        ret
++
++.global fesetenv
++.type fesetenv, %function
++fesetenv:
++        lw t1, 0(a0)
++        fscsr t0, t1
++        li a0, 0
++        ret
++
++#endif
+diff --git a/src/internal/riscv64/syscall.s b/src/internal/riscv64/syscall.s
+new file mode 100644
+index 0000000..a7d125a
+--- /dev/null
++++ b/src/internal/riscv64/syscall.s
+@@ -0,0 +1,15 @@
++.global __syscall
++.hidden __syscall
++.type   __syscall,%function
++__syscall:
++        mv t0, a0
++        mv a0, a1
++        mv a1, a2
++        mv a2, a3
++        mv a3, a4
++        mv a4, a5
++        mv a5, a6
++        mv a6, a7
++        mv a7, t0
++        scall
++        ret
+diff --git a/src/ldso/riscv64/dlsym.s b/src/ldso/riscv64/dlsym.s
+new file mode 100644
+index 0000000..ff9109d
+--- /dev/null
++++ b/src/ldso/riscv64/dlsym.s
+@@ -0,0 +1,6 @@
++.global dlsym
++.hidden __dlsym
++.type dlsym, %function
++dlsym:
++        mv a2, ra
++        j __dlsym
+diff --git a/src/math/riscv64/copysign.s b/src/math/riscv64/copysign.s
+new file mode 100644
+index 0000000..81afa8b
+--- /dev/null
++++ b/src/math/riscv64/copysign.s
+@@ -0,0 +1,5 @@
++.global copysign
++.type   copysign, %function
++copysign:
++        fsgnj.d fa0, fa0, fa1
++        ret
+diff --git a/src/math/riscv64/copysignf.s b/src/math/riscv64/copysignf.s
+new file mode 100644
+index 0000000..fe36f90
+--- /dev/null
++++ b/src/math/riscv64/copysignf.s
+@@ -0,0 +1,5 @@
++.global copysignf
++.type   copysignf, %function
++copysignf:
++        fsgnj.s fa0, fa0, fa1
++        ret
+diff --git a/src/math/riscv64/fabs.s b/src/math/riscv64/fabs.s
+new file mode 100644
+index 0000000..27def33
+--- /dev/null
++++ b/src/math/riscv64/fabs.s
+@@ -0,0 +1,5 @@
++.global fabs
++.type   fabs, %function
++fabs:
++        fabs.d fa0, fa0
++        ret
+diff --git a/src/math/riscv64/fabsf.s b/src/math/riscv64/fabsf.s
+new file mode 100644
+index 0000000..8e0b9d6
+--- /dev/null
++++ b/src/math/riscv64/fabsf.s
+@@ -0,0 +1,5 @@
++.global fabsf
++.type   fabsf, %function
++fabsf:
++        fabs.s fa0, fa0
++        ret
+diff --git a/src/math/riscv64/fma.s b/src/math/riscv64/fma.s
+new file mode 100644
+index 0000000..17e1d13
+--- /dev/null
++++ b/src/math/riscv64/fma.s
+@@ -0,0 +1,5 @@
++.global fma
++.type   fma, %function
++fma:
++        fmadd.d fa0, fa0, fa1, fa2
++        ret
+diff --git a/src/math/riscv64/fmaf.s b/src/math/riscv64/fmaf.s
+new file mode 100644
+index 0000000..cfe1710
+--- /dev/null
++++ b/src/math/riscv64/fmaf.s
+@@ -0,0 +1,5 @@
++.global fmaf
++.type   fmaf, %function
++fmaf:
++        fmadd.s fa0, fa0, fa1, fa2
++        ret
+diff --git a/src/math/riscv64/fmax.s b/src/math/riscv64/fmax.s
+new file mode 100644
+index 0000000..40655d3
+--- /dev/null
++++ b/src/math/riscv64/fmax.s
+@@ -0,0 +1,5 @@
++.global fmax
++.type   fmax, %function
++fmax:
++        fmax.d fa0, fa0, fa1
++        ret
+diff --git a/src/math/riscv64/fmaxf.s b/src/math/riscv64/fmaxf.s
+new file mode 100644
+index 0000000..490b6e9
+--- /dev/null
++++ b/src/math/riscv64/fmaxf.s
+@@ -0,0 +1,5 @@
++.global fmaxf
++.type   fmaxf, %function
++fmaxf:
++        fmax.s fa0, fa0, fa1
++        ret
+diff --git a/src/math/riscv64/fmin.s b/src/math/riscv64/fmin.s
+new file mode 100644
+index 0000000..97f72e0
+--- /dev/null
++++ b/src/math/riscv64/fmin.s
+@@ -0,0 +1,5 @@
++.global fmin
++.type   fmin, %function
++fmin:
++        fmin.d fa0, fa0, fa1
++        ret
+diff --git a/src/math/riscv64/fminf.s b/src/math/riscv64/fminf.s
+new file mode 100644
+index 0000000..4f8e55e
+--- /dev/null
++++ b/src/math/riscv64/fminf.s
+@@ -0,0 +1,5 @@
++.global fminf
++.type   fminf, %function
++fminf:
++        fmin.s fa0, fa0, fa1
++        ret
+diff --git a/src/math/riscv64/sqrt.s b/src/math/riscv64/sqrt.s
+new file mode 100644
+index 0000000..a4c8b3e
+--- /dev/null
++++ b/src/math/riscv64/sqrt.s
+@@ -0,0 +1,5 @@
++.global sqrt
++.type   sqrt, %function
++sqrt:
++        fsqrt.d fa0, fa0
++        ret
+diff --git a/src/math/riscv64/sqrtf.s b/src/math/riscv64/sqrtf.s
+new file mode 100644
+index 0000000..ff7abcf
+--- /dev/null
++++ b/src/math/riscv64/sqrtf.s
+@@ -0,0 +1,5 @@
++.global sqrtf
++.type   sqrtf, %function
++sqrtf:
++        fsqrt.s fa0, fa0
++        ret
+diff --git a/src/setjmp/riscv64/longjmp.S b/src/setjmp/riscv64/longjmp.S
+new file mode 100644
+index 0000000..d87a1af
+--- /dev/null
++++ b/src/setjmp/riscv64/longjmp.S
+@@ -0,0 +1,44 @@
++.global __longjmp
++.global _longjmp
++.global longjmp
++.type __longjmp, %function
++.type _longjmp,  %function
++.type longjmp,   %function
++__longjmp:
++_longjmp:
++longjmp:
++        ld s0,    0(a0)
++        ld s1,    8(a0)
++        ld s2,    16(a0)
++        ld s3,    24(a0)
++        ld s4,    32(a0)
++        ld s5,    40(a0)
++        ld s6,    48(a0)
++        ld s7,    56(a0)
++        ld s8,    64(a0)
++        ld s9,    72(a0)
++        ld s10,   80(a0)
++        ld s11,   88(a0)
++        ld sp,    96(a0)
++        ld ra,    104(a0)
++
++#ifndef __riscv_soft_float
++        fld fs0,  112(a0)
++        fld fs1,  120(a0)
++        fld fs2,  128(a0)
++        fld fs3,  136(a0)
++        fld fs3,  144(a0)
++        fld fs4,  152(a0)
++        fld fs5,  160(a0)
++        fld fs6,  168(a0)
++        fld fs7,  176(a0)
++        fld fs8,  184(a0)
++        fld fs9,  192(a0)
++        fld fs10, 200(a0)
++        fld fs11, 208(a0)
++#endif
++
++        mv a0, a1
++        bnez a1, 1f
++        li a0, 1
++1:      ret
+diff --git a/src/setjmp/riscv64/setjmp.S b/src/setjmp/riscv64/setjmp.S
+new file mode 100644
+index 0000000..abc05aa
+--- /dev/null
++++ b/src/setjmp/riscv64/setjmp.S
+@@ -0,0 +1,42 @@
++.global __setjmp
++.global _setjmp
++.global setjmp
++.type __setjmp, %function
++.type _setjmp,  %function
++.type setjmp,   %function
++__setjmp:
++_setjmp:
++setjmp:
++        sd s0,    0(a0)
++        sd s1,    8(a0)
++        sd s2,    16(a0)
++        sd s3,    24(a0)
++        sd s4,    32(a0)
++        sd s5,    40(a0)
++        sd s6,    48(a0)
++        sd s7,    56(a0)
++        sd s8,    64(a0)
++        sd s9,    72(a0)
++        sd s10,   80(a0)
++        sd s11,   88(a0)
++        sd sp,    96(a0)
++        sd ra,    104(a0)
++
++#ifndef __riscv_soft_float
++        fsd fs0,  112(a0)
++        fsd fs1,  120(a0)
++        fsd fs2,  128(a0)
++        fsd fs3,  136(a0)
++        fsd fs3,  144(a0)
++        fsd fs4,  152(a0)
++        fsd fs5,  160(a0)
++        fsd fs6,  168(a0)
++        fsd fs7,  176(a0)
++        fsd fs8,  184(a0)
++        fsd fs9,  192(a0)
++        fsd fs10, 200(a0)
++        fsd fs11, 208(a0)
++#endif
++
++        li a0, 0
++        ret
+diff --git a/src/signal/riscv64/restore.s b/src/signal/riscv64/restore.s
+new file mode 100644
+index 0000000..732736d
+--- /dev/null
++++ b/src/signal/riscv64/restore.s
+@@ -0,0 +1,8 @@
++.global __restore
++.type __restore, %function
++__restore:
++.global __restore_rt
++.type __restore_rt, %function
++__restore_rt:
++      li a7, 139 # SYS_rt_sigreturn
++      scall
+diff --git a/src/signal/riscv64/sigsetjmp.s b/src/signal/riscv64/sigsetjmp.s
+new file mode 100644
+index 0000000..9ed9500
+--- /dev/null
++++ b/src/signal/riscv64/sigsetjmp.s
+@@ -0,0 +1,21 @@
++.global sigsetjmp
++.global __sigsetjmp
++.type sigsetjmp, %function
++.type __sigsetjmp, %function
++sigsetjmp:
++__sigsetjmp:
++        beqz a1, setjmp
++
++        sd ra, 216(a0)
++        sd s0, 224(a0)
++        mv s0, a0
++
++        jal setjmp
++
++        mv a1, a0
++        mv a0, s0
++        ld s0, 224(a0)
++        ld ra, 216(a0)
++
++.hidden __sigsetjmp_tail
++        j __sigsetjmp_tail
+diff --git a/src/thread/riscv64/__set_thread_area.s b/src/thread/riscv64/__set_thread_area.s
+new file mode 100644
+index 0000000..828154d
+--- /dev/null
++++ b/src/thread/riscv64/__set_thread_area.s
+@@ -0,0 +1,6 @@
++.global __set_thread_area
++.type   __set_thread_area, %function
++__set_thread_area:
++      mv tp, a0
++      li a0, 0
++      ret
+diff --git a/src/thread/riscv64/__unmapself.s b/src/thread/riscv64/__unmapself.s
+new file mode 100644
+index 0000000..98e7881
+--- /dev/null
++++ b/src/thread/riscv64/__unmapself.s
+@@ -0,0 +1,7 @@
++.global __unmapself
++.type __unmapself, %function
++__unmapself:
++       li a7, 215 # SYS_munmap
++       scall
++       li a7, 93  # SYS_exit
++       scall
+diff --git a/src/thread/riscv64/clone.s b/src/thread/riscv64/clone.s
+new file mode 100644
+index 0000000..b2d4f02
+--- /dev/null
++++ b/src/thread/riscv64/clone.s
+@@ -0,0 +1,34 @@
++# __clone(func, stack, flags, arg, ptid, tls, ctid)
++#           a0,    a1,    a2,  a3,   a4,  a5,   a6
++
++# syscall(SYS_clone, flags, stack, ptid, tls, ctid)
++#                a7     a0,    a1,   a2,  a3,   a4
++
++.global __clone
++.type  __clone, %function
++__clone:
++        # Save func and arg to stack
++        addi a1, a1, -16
++        sd a0, 0(a1)
++        sd a3, 8(a1)
++
++        # Call SYS_clone
++        mv a0, a2
++        mv a2, a4
++        mv a3, a5
++        mv a4, a6
++        li a7, 220 # SYS_clone
++        scall
++
++        beqz a0, 1f
++        # Parent
++        ret
++
++        # Child
++1:      ld a1, 0(sp)
++        ld a0, 8(sp)
++        jalr a1
++
++        # Exit
++        li a7, 93 # SYS_exit
++        scall
+diff --git a/src/thread/riscv64/syscall_cp.s b/src/thread/riscv64/syscall_cp.s
+new file mode 100644
+index 0000000..c745b32
+--- /dev/null
++++ b/src/thread/riscv64/syscall_cp.s
+@@ -0,0 +1,29 @@
++.global __cp_begin
++.hidden __cp_begin
++.global __cp_end
++.hidden __cp_end
++.global __cp_cancel
++.hidden __cp_cancel
++.hidden __cancel
++.global __syscall_cp_asm
++.hidden __syscall_cp_asm
++.type __syscall_cp_asm, %function
++__syscall_cp_asm:
++__cp_begin:
++        ld t0, 0(a0)
++        bnez t0, __cp_cancel
++
++        mv t0, a1
++        mv a0, a2
++        mv a1, a3
++        mv a2, a4
++        mv a3, a5
++        mv a4, a6
++        mv a5, a7
++        ld a6, 0(sp)
++        mv a7, t0
++        scall
++__cp_cancel:
++        ret
++__cp_end:
++        j __cancel
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/805-riscv64-Fix-syscall_cp.patch b/toolchain/musl/patches/805-riscv64-Fix-syscall_cp.patch
new file mode 100644 (file)
index 0000000..143dde1
--- /dev/null
@@ -0,0 +1,38 @@
+From b356d67f2956a69578b35c49adc8c77e18eb20cb Mon Sep 17 00:00:00 2001
+From: Drew DeVault <[email protected]>
+Date: Thu, 21 Mar 2019 12:23:20 -0400
+Subject: [PATCH 05/15] riscv64: Fix syscall_cp
+
+Thanks to Rich Felker for pointing out this error on the musl list. In
+addition to fixing the labels, this loads the cancel flag with lw
+instead of ld.
+---
+ src/thread/riscv64/syscall_cp.s | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+diff --git a/src/thread/riscv64/syscall_cp.s b/src/thread/riscv64/syscall_cp.s
+index c745b32..65cf722 100644
+--- a/src/thread/riscv64/syscall_cp.s
++++ b/src/thread/riscv64/syscall_cp.s
+@@ -10,7 +10,7 @@
+ .type __syscall_cp_asm, %function
+ __syscall_cp_asm:
+ __cp_begin:
+-        ld t0, 0(a0)
++        lw t0, 0(a0)
+         bnez t0, __cp_cancel
+         mv t0, a1
+@@ -23,7 +23,7 @@ __cp_begin:
+         ld a6, 0(sp)
+         mv a7, t0
+         scall
+-__cp_cancel:
+-        ret
+ __cp_end:
++        ret
++__cp_cancel:
+         j __cancel
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/806-riscv64-add-cache-flush-syscall.patch b/toolchain/musl/patches/806-riscv64-add-cache-flush-syscall.patch
new file mode 100644 (file)
index 0000000..2a76809
--- /dev/null
@@ -0,0 +1,85 @@
+From 3935e958288251f7ff3aea7ce107d205bf86146f Mon Sep 17 00:00:00 2001
+From: Drew DeVault <[email protected]>
+Date: Thu, 21 Mar 2019 12:24:48 -0400
+Subject: [PATCH 06/15] riscv64: add cache flush syscall
+
+---
+ arch/riscv64/bits/syscall.h.in |  1 +
+ arch/riscv64/syscall_arch.h    |  3 +++
+ src/linux/cache.c              | 37 +++++++++++++++++++++++++++++++++++++
+ 3 files changed, 41 insertions(+)
+
+diff --git a/arch/riscv64/bits/syscall.h.in b/arch/riscv64/bits/syscall.h.in
+index 3c81c10..11393c2 100644
+--- a/arch/riscv64/bits/syscall.h.in
++++ b/arch/riscv64/bits/syscall.h.in
+@@ -275,4 +275,5 @@
+ #define __NR_pkey_alloc 289
+ #define __NR_pkey_free 290
+ #define __NR_sysriscv __NR_arch_specific_syscall
++#define __NR_riscv_flush_icache (__NR_sysriscv + 15)
+diff --git a/arch/riscv64/syscall_arch.h b/arch/riscv64/syscall_arch.h
+index 7b6e3fd..0e59581 100644
+--- a/arch/riscv64/syscall_arch.h
++++ b/arch/riscv64/syscall_arch.h
+@@ -74,3 +74,6 @@ static inline long __syscall6(long n, long a, long b, long c, long d, long e, lo
+ /* We don't have a clock_gettime function.
+ #define VDSO_CGT_SYM "__vdso_clock_gettime"
+ #define VDSO_CGT_VER "LINUX_2.6" */
++
++#define VDSO_FLUSH_ICACHE_SYM "__vdso_flush_icache"
++#define VDSO_FLUSH_ICACHE_VER "LINUX_4.5"
+diff --git a/src/linux/cache.c b/src/linux/cache.c
+index 84a138a..0c5af2e 100644
+--- a/src/linux/cache.c
++++ b/src/linux/cache.c
+@@ -1,4 +1,6 @@
++#include <errno.h>
+ #include "syscall.h"
++#include "atomic.h"
+ #ifdef SYS_cacheflush
+ int _flush_cache(void *addr, int len, int op)
+@@ -15,3 +17,38 @@ int __cachectl(void *addr, int len, int op)
+ }
+ weak_alias(__cachectl, cachectl);
+ #endif
++
++#ifdef SYS_riscv_flush_icache
++
++#ifdef VDSO_FLUSH_ICACHE_SYM
++
++static void *volatile vdso_func;
++
++static int flush_icache_init(void *start, void *end, unsigned long int flags)
++{
++      void *p = __vdsosym(VDSO_FLUSH_ICACHE_VER, VDSO_FLUSH_ICACHE_SYM);
++      int (*f)(void *, void *, unsigned long int) =
++              (int (*)(void *, void *, unsigned long int))p;
++      a_cas_p(&vdso_func, (void *)flush_icache_init, p);
++      return f ? f(start, end, flags) : -ENOSYS;
++}
++
++static void *volatile vdso_func = (void *)flush_icache_init;
++
++#endif
++
++int __riscv_flush_icache(void *start, void *end, unsigned long int flags) 
++{
++#ifdef VDSO_FLUSH_ICACHE_SYM
++      int (*f)(void *, void *, unsigned long int) =
++              (int (*)(void *, void *, unsigned long int))vdso_func;
++      if (f) {
++              int r = f(start, end, flags);
++              if (!r) return r;
++              if (r != -ENOSYS) return __syscall_ret(r);
++      }
++#endif
++      return syscall(SYS_riscv_flush_icache, start, end, flags);
++}
++weak_alias(__riscv_flush_icache, riscv_flush_icache);
++#endif
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/807-riscv64-don-t-define-SYS_renameat.patch b/toolchain/musl/patches/807-riscv64-don-t-define-SYS_renameat.patch
new file mode 100644 (file)
index 0000000..7cb251c
--- /dev/null
@@ -0,0 +1,24 @@
+From c8454d6e652ae752b63e4a1bd65f2cd7dfcdc1d4 Mon Sep 17 00:00:00 2001
+From: Michael Forney <[email protected]>
+Date: Thu, 21 Mar 2019 12:26:32 -0400
+Subject: [PATCH 07/15] riscv64: don't define SYS_renameat
+
+---
+ arch/riscv64/bits/syscall.h.in | 1 -
+ 1 file changed, 1 deletion(-)
+
+diff --git a/arch/riscv64/bits/syscall.h.in b/arch/riscv64/bits/syscall.h.in
+index 11393c2..2372ed3 100644
+--- a/arch/riscv64/bits/syscall.h.in
++++ b/arch/riscv64/bits/syscall.h.in
+@@ -36,7 +36,6 @@
+ #define __NR_unlinkat 35
+ #define __NR_symlinkat 36
+ #define __NR_linkat 37
+-#define __NR_renameat 38
+ #define __NR_umount2 39
+ #define __NR_mount 40
+ #define __NR_pivot_root 41
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/808-riscv64-Fix-fcntl-constants.patch b/toolchain/musl/patches/808-riscv64-Fix-fcntl-constants.patch
new file mode 100644 (file)
index 0000000..0559e6a
--- /dev/null
@@ -0,0 +1,38 @@
+From d012ac9a30fc5d71da4bb3e2d5e951f0c9ecfaf2 Mon Sep 17 00:00:00 2001
+From: Michael Forney <[email protected]>
+Date: Thu, 21 Mar 2019 12:27:01 -0400
+Subject: [PATCH 08/15] riscv64: Fix fcntl constants
+
+---
+ arch/riscv64/bits/fcntl.h | 10 +++++-----
+ 1 file changed, 5 insertions(+), 5 deletions(-)
+
+diff --git a/arch/riscv64/bits/fcntl.h b/arch/riscv64/bits/fcntl.h
+index 9278797..ecb4d18 100644
+--- a/arch/riscv64/bits/fcntl.h
++++ b/arch/riscv64/bits/fcntl.h
+@@ -7,16 +7,16 @@
+ #define O_DSYNC      010000
+ #define O_SYNC     04010000
+ #define O_RSYNC    04010000
+-#define O_DIRECTORY  040000
+-#define O_NOFOLLOW  0100000
++#define O_DIRECTORY 0200000
++#define O_NOFOLLOW  0400000
+ #define O_CLOEXEC  02000000
+ #define O_ASYNC      020000
+-#define O_DIRECT    0200000
+-#define O_LARGEFILE 0400000
++#define O_DIRECT     040000
++#define O_LARGEFILE 0100000
+ #define O_NOATIME  01000000
+ #define O_PATH    010000000
+-#define O_TMPFILE 020040000
++#define O_TMPFILE 020200000
+ #define O_NDELAY O_NONBLOCK
+ #define F_DUPFD  0
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/809-riscv64-Fix-soft-float-check.patch b/toolchain/musl/patches/809-riscv64-Fix-soft-float-check.patch
new file mode 100644 (file)
index 0000000..423877f
--- /dev/null
@@ -0,0 +1,74 @@
+From 89b67af6bec2dbc329d6b28f15c1788bb5c91772 Mon Sep 17 00:00:00 2001
+From: Michael Forney <[email protected]>
+Date: Thu, 21 Mar 2019 12:29:09 -0400
+Subject: [PATCH 09/15] riscv64: Fix soft float check
+
+---
+ configure                    | 2 +-
+ src/fenv/riscv64/fenv-sf.c   | 2 +-
+ src/fenv/riscv64/fenv.S      | 2 +-
+ src/setjmp/riscv64/longjmp.S | 2 +-
+ src/setjmp/riscv64/setjmp.S  | 2 +-
+ 5 files changed, 5 insertions(+), 5 deletions(-)
+
+diff --git a/configure b/configure
+index ef39686..34b0a9b 100755
+--- a/configure
++++ b/configure
+@@ -643,7 +643,7 @@ fi
+ if test "$ARCH" = "riscv64" ; then
+ trycppif "RISCVEB || _RISCVEB || __RISCVEB || __RISCVEB__" "$t" && SUBARCH=${SUBARCH}eb
+-trycppif __riscv_soft_float "$t" && SUBARCH=${SUBARCH}-sf
++trycppif __riscv_float_abi_soft "$t" && SUBARCH=${SUBARCH}-sf
+ fi
+ if test "$ARCH" = "sh" ; then
+diff --git a/src/fenv/riscv64/fenv-sf.c b/src/fenv/riscv64/fenv-sf.c
+index 9ff7b79..ecd3cb5 100644
+--- a/src/fenv/riscv64/fenv-sf.c
++++ b/src/fenv/riscv64/fenv-sf.c
+@@ -1,3 +1,3 @@
+-#ifdef __riscv_soft_float
++#ifndef __riscv_flen
+ #include "../fenv.c"
+ #endif
+diff --git a/src/fenv/riscv64/fenv.S b/src/fenv/riscv64/fenv.S
+index a55aa4a..97f74dd 100644
+--- a/src/fenv/riscv64/fenv.S
++++ b/src/fenv/riscv64/fenv.S
+@@ -1,4 +1,4 @@
+-#ifndef __riscv_soft_float
++#ifdef __riscv_flen
+ .global feclearexcept
+ .type feclearexcept, %function
+diff --git a/src/setjmp/riscv64/longjmp.S b/src/setjmp/riscv64/longjmp.S
+index d87a1af..46cc596 100644
+--- a/src/setjmp/riscv64/longjmp.S
++++ b/src/setjmp/riscv64/longjmp.S
+@@ -22,7 +22,7 @@ longjmp:
+         ld sp,    96(a0)
+         ld ra,    104(a0)
+-#ifndef __riscv_soft_float
++#ifndef __riscv_float_abi_soft
+         fld fs0,  112(a0)
+         fld fs1,  120(a0)
+         fld fs2,  128(a0)
+diff --git a/src/setjmp/riscv64/setjmp.S b/src/setjmp/riscv64/setjmp.S
+index abc05aa..0b58a67 100644
+--- a/src/setjmp/riscv64/setjmp.S
++++ b/src/setjmp/riscv64/setjmp.S
+@@ -22,7 +22,7 @@ setjmp:
+         sd sp,    96(a0)
+         sd ra,    104(a0)
+-#ifndef __riscv_soft_float
++#ifndef __riscv_float_abi_soft
+         fsd fs0,  112(a0)
+         fsd fs1,  120(a0)
+         fsd fs2,  128(a0)
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/810-riscv64-Support-soft-float.patch b/toolchain/musl/patches/810-riscv64-Support-soft-float.patch
new file mode 100644 (file)
index 0000000..77cc71d
--- /dev/null
@@ -0,0 +1,443 @@
+From 731a0ebbe743a5265738913fa34ff8ed6766ee42 Mon Sep 17 00:00:00 2001
+From: Michael Forney <[email protected]>
+Date: Thu, 21 Mar 2019 12:30:06 -0400
+Subject: [PATCH 10/15] riscv64: Support soft float
+
+---
+ src/math/riscv64/copysign.c  | 15 +++++++++++++++
+ src/math/riscv64/copysign.s  |  5 -----
+ src/math/riscv64/copysignf.c | 15 +++++++++++++++
+ src/math/riscv64/copysignf.s |  5 -----
+ src/math/riscv64/fabs.c      | 15 +++++++++++++++
+ src/math/riscv64/fabs.s      |  5 -----
+ src/math/riscv64/fabsf.c     | 15 +++++++++++++++
+ src/math/riscv64/fabsf.s     |  5 -----
+ src/math/riscv64/fma.c       | 15 +++++++++++++++
+ src/math/riscv64/fma.s       |  5 -----
+ src/math/riscv64/fmaf.c      | 15 +++++++++++++++
+ src/math/riscv64/fmaf.s      |  5 -----
+ src/math/riscv64/fmax.c      | 15 +++++++++++++++
+ src/math/riscv64/fmax.s      |  5 -----
+ src/math/riscv64/fmaxf.c     | 15 +++++++++++++++
+ src/math/riscv64/fmaxf.s     |  5 -----
+ src/math/riscv64/fmin.c      | 15 +++++++++++++++
+ src/math/riscv64/fmin.s      |  5 -----
+ src/math/riscv64/fminf.c     | 15 +++++++++++++++
+ src/math/riscv64/fminf.s     |  5 -----
+ src/math/riscv64/sqrt.c      | 15 +++++++++++++++
+ src/math/riscv64/sqrt.s      |  5 -----
+ src/math/riscv64/sqrtf.c     | 15 +++++++++++++++
+ src/math/riscv64/sqrtf.s     |  5 -----
+ 24 files changed, 180 insertions(+), 60 deletions(-)
+ create mode 100644 src/math/riscv64/copysign.c
+ delete mode 100644 src/math/riscv64/copysign.s
+ create mode 100644 src/math/riscv64/copysignf.c
+ delete mode 100644 src/math/riscv64/copysignf.s
+ create mode 100644 src/math/riscv64/fabs.c
+ delete mode 100644 src/math/riscv64/fabs.s
+ create mode 100644 src/math/riscv64/fabsf.c
+ delete mode 100644 src/math/riscv64/fabsf.s
+ create mode 100644 src/math/riscv64/fma.c
+ delete mode 100644 src/math/riscv64/fma.s
+ create mode 100644 src/math/riscv64/fmaf.c
+ delete mode 100644 src/math/riscv64/fmaf.s
+ create mode 100644 src/math/riscv64/fmax.c
+ delete mode 100644 src/math/riscv64/fmax.s
+ create mode 100644 src/math/riscv64/fmaxf.c
+ delete mode 100644 src/math/riscv64/fmaxf.s
+ create mode 100644 src/math/riscv64/fmin.c
+ delete mode 100644 src/math/riscv64/fmin.s
+ create mode 100644 src/math/riscv64/fminf.c
+ delete mode 100644 src/math/riscv64/fminf.s
+ create mode 100644 src/math/riscv64/sqrt.c
+ delete mode 100644 src/math/riscv64/sqrt.s
+ create mode 100644 src/math/riscv64/sqrtf.c
+ delete mode 100644 src/math/riscv64/sqrtf.s
+
+diff --git a/src/math/riscv64/copysign.c b/src/math/riscv64/copysign.c
+new file mode 100644
+index 0000000..c785417
+--- /dev/null
++++ b/src/math/riscv64/copysign.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 64
++
++double copysign(double x, double y)
++{
++      __asm__ ("fsgnj.d %0, %1, %2" : "=f"(x) : "f"(x), "f"(y));
++      return x;
++}
++
++#else
++
++#include "../copysign.c"
++
++#endif
+diff --git a/src/math/riscv64/copysign.s b/src/math/riscv64/copysign.s
+deleted file mode 100644
+index 81afa8b..0000000
+--- a/src/math/riscv64/copysign.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global copysign
+-.type   copysign, %function
+-copysign:
+-        fsgnj.d fa0, fa0, fa1
+-        ret
+diff --git a/src/math/riscv64/copysignf.c b/src/math/riscv64/copysignf.c
+new file mode 100644
+index 0000000..a125611
+--- /dev/null
++++ b/src/math/riscv64/copysignf.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 32
++
++float copysignf(float x, float y)
++{
++      __asm__ ("fsgnj.s %0, %1, %2" : "=f"(x) : "f"(x), "f"(y));
++      return x;
++}
++
++#else
++
++#include "../copysignf.c"
++
++#endif
+diff --git a/src/math/riscv64/copysignf.s b/src/math/riscv64/copysignf.s
+deleted file mode 100644
+index fe36f90..0000000
+--- a/src/math/riscv64/copysignf.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global copysignf
+-.type   copysignf, %function
+-copysignf:
+-        fsgnj.s fa0, fa0, fa1
+-        ret
+diff --git a/src/math/riscv64/fabs.c b/src/math/riscv64/fabs.c
+new file mode 100644
+index 0000000..5290b6f
+--- /dev/null
++++ b/src/math/riscv64/fabs.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 64
++
++double fabs(double x)
++{
++      __asm__ ("fabs.d %0, %1" : "=f"(x) : "f"(x));
++      return x;
++}
++
++#else
++
++#include "../fabs.c"
++
++#endif
+diff --git a/src/math/riscv64/fabs.s b/src/math/riscv64/fabs.s
+deleted file mode 100644
+index 27def33..0000000
+--- a/src/math/riscv64/fabs.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global fabs
+-.type   fabs, %function
+-fabs:
+-        fabs.d fa0, fa0
+-        ret
+diff --git a/src/math/riscv64/fabsf.c b/src/math/riscv64/fabsf.c
+new file mode 100644
+index 0000000..f5032e3
+--- /dev/null
++++ b/src/math/riscv64/fabsf.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 32
++
++float fabsf(float x)
++{
++      __asm__ ("fabs.s %0, %1" : "=f"(x) : "f"(x));
++      return x;
++}
++
++#else
++
++#include "../fabsf.c"
++
++#endif
+diff --git a/src/math/riscv64/fabsf.s b/src/math/riscv64/fabsf.s
+deleted file mode 100644
+index 8e0b9d6..0000000
+--- a/src/math/riscv64/fabsf.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global fabsf
+-.type   fabsf, %function
+-fabsf:
+-        fabs.s fa0, fa0
+-        ret
+diff --git a/src/math/riscv64/fma.c b/src/math/riscv64/fma.c
+new file mode 100644
+index 0000000..99b0571
+--- /dev/null
++++ b/src/math/riscv64/fma.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 64
++
++double fma(double x, double y, double z)
++{
++      __asm__ ("fmadd.d %0, %1, %2, %3" : "=f"(x) : "f"(x), "f"(y), "f"(z));
++      return x;
++}
++
++#else
++
++#include "../fma.c"
++
++#endif
+diff --git a/src/math/riscv64/fma.s b/src/math/riscv64/fma.s
+deleted file mode 100644
+index 17e1d13..0000000
+--- a/src/math/riscv64/fma.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global fma
+-.type   fma, %function
+-fma:
+-        fmadd.d fa0, fa0, fa1, fa2
+-        ret
+diff --git a/src/math/riscv64/fmaf.c b/src/math/riscv64/fmaf.c
+new file mode 100644
+index 0000000..f9dc47e
+--- /dev/null
++++ b/src/math/riscv64/fmaf.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 32
++
++float fmaf(float x, float y, float z)
++{
++      __asm__ ("fmadd.s %0, %1, %2, %3" : "=f"(x) : "f"(x), "f"(y), "f"(z));
++      return x;
++}
++
++#else
++
++#include "../fmaf.c"
++
++#endif
+diff --git a/src/math/riscv64/fmaf.s b/src/math/riscv64/fmaf.s
+deleted file mode 100644
+index cfe1710..0000000
+--- a/src/math/riscv64/fmaf.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global fmaf
+-.type   fmaf, %function
+-fmaf:
+-        fmadd.s fa0, fa0, fa1, fa2
+-        ret
+diff --git a/src/math/riscv64/fmax.c b/src/math/riscv64/fmax.c
+new file mode 100644
+index 0000000..023709c
+--- /dev/null
++++ b/src/math/riscv64/fmax.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 64
++
++double fmax(double x, double y)
++{
++      __asm__ ("fmax.d %0, %1, %2" : "=f"(x) : "f"(x), "f"(y));
++      return x;
++}
++
++#else
++
++#include "../fmax.c"
++
++#endif
+diff --git a/src/math/riscv64/fmax.s b/src/math/riscv64/fmax.s
+deleted file mode 100644
+index 40655d3..0000000
+--- a/src/math/riscv64/fmax.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global fmax
+-.type   fmax, %function
+-fmax:
+-        fmax.d fa0, fa0, fa1
+-        ret
+diff --git a/src/math/riscv64/fmaxf.c b/src/math/riscv64/fmaxf.c
+new file mode 100644
+index 0000000..863d2bd
+--- /dev/null
++++ b/src/math/riscv64/fmaxf.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 32
++
++float fmaxf(float x, float y)
++{
++      __asm__ ("fmax.s %0, %1, %2" : "=f"(x) : "f"(x), "f"(y));
++      return x;
++}
++
++#else
++
++#include "../fmaxf.c"
++
++#endif
+diff --git a/src/math/riscv64/fmaxf.s b/src/math/riscv64/fmaxf.s
+deleted file mode 100644
+index 490b6e9..0000000
+--- a/src/math/riscv64/fmaxf.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global fmaxf
+-.type   fmaxf, %function
+-fmaxf:
+-        fmax.s fa0, fa0, fa1
+-        ret
+diff --git a/src/math/riscv64/fmin.c b/src/math/riscv64/fmin.c
+new file mode 100644
+index 0000000..a4e3b06
+--- /dev/null
++++ b/src/math/riscv64/fmin.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 64
++
++double fmin(double x, double y)
++{
++      __asm__ ("fmin.d %0, %1, %2" : "=f"(x) : "f"(x), "f"(y));
++      return x;
++}
++
++#else
++
++#include "../fmin.c"
++
++#endif
+diff --git a/src/math/riscv64/fmin.s b/src/math/riscv64/fmin.s
+deleted file mode 100644
+index 97f72e0..0000000
+--- a/src/math/riscv64/fmin.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global fmin
+-.type   fmin, %function
+-fmin:
+-        fmin.d fa0, fa0, fa1
+-        ret
+diff --git a/src/math/riscv64/fminf.c b/src/math/riscv64/fminf.c
+new file mode 100644
+index 0000000..32156e8
+--- /dev/null
++++ b/src/math/riscv64/fminf.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 32
++
++float fminf(float x, float y)
++{
++      __asm__ ("fmin.s %0, %1, %2" : "=f"(x) : "f"(x), "f"(y));
++      return x;
++}
++
++#else
++
++#include "../fminf.c"
++
++#endif
+diff --git a/src/math/riscv64/fminf.s b/src/math/riscv64/fminf.s
+deleted file mode 100644
+index 4f8e55e..0000000
+--- a/src/math/riscv64/fminf.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global fminf
+-.type   fminf, %function
+-fminf:
+-        fmin.s fa0, fa0, fa1
+-        ret
+diff --git a/src/math/riscv64/sqrt.c b/src/math/riscv64/sqrt.c
+new file mode 100644
+index 0000000..75c34f7
+--- /dev/null
++++ b/src/math/riscv64/sqrt.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 64
++
++double sqrt(double x)
++{
++      __asm__ ("sqrt.d %0, %1" : "=f"(x) : "f"(x));
++      return x;
++}
++
++#else
++
++#include "../sqrt.c"
++
++#endif
+diff --git a/src/math/riscv64/sqrt.s b/src/math/riscv64/sqrt.s
+deleted file mode 100644
+index a4c8b3e..0000000
+--- a/src/math/riscv64/sqrt.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global sqrt
+-.type   sqrt, %function
+-sqrt:
+-        fsqrt.d fa0, fa0
+-        ret
+diff --git a/src/math/riscv64/sqrtf.c b/src/math/riscv64/sqrtf.c
+new file mode 100644
+index 0000000..610c2cf
+--- /dev/null
++++ b/src/math/riscv64/sqrtf.c
+@@ -0,0 +1,15 @@
++#include <math.h>
++
++#if __riscv_flen >= 32
++
++float sqrtf(float x)
++{
++      __asm__ ("fsqrt.s %0, %1" : "=f"(x) : "f"(x));
++      return x;
++}
++
++#else
++
++#include "../sqrtf.c"
++
++#endif
+diff --git a/src/math/riscv64/sqrtf.s b/src/math/riscv64/sqrtf.s
+deleted file mode 100644
+index ff7abcf..0000000
+--- a/src/math/riscv64/sqrtf.s
++++ /dev/null
+@@ -1,5 +0,0 @@
+-.global sqrtf
+-.type   sqrtf, %function
+-sqrtf:
+-        fsqrt.s fa0, fa0
+-        ret
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/811-riscv64-Fix-inline-asm-for-sqrt.patch b/toolchain/musl/patches/811-riscv64-Fix-inline-asm-for-sqrt.patch
new file mode 100644 (file)
index 0000000..ca822a6
--- /dev/null
@@ -0,0 +1,29 @@
+From 50c66218e74c3f2a05dc825ed51ba8a3f889d47c Mon Sep 17 00:00:00 2001
+From: Michael Forney <[email protected]>
+Date: Thu, 21 Mar 2019 12:30:40 -0400
+Subject: [PATCH 11/15] riscv64: Fix inline asm for sqrt
+
+This was accidentally broken when converting the .s files to C and
+inline asm (988d64a480bdae3a3ac7158e018198af8495304f).
+
+Patch by Fabrice Bellard.
+---
+ src/math/riscv64/sqrt.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/src/math/riscv64/sqrt.c b/src/math/riscv64/sqrt.c
+index 75c34f7..867a504 100644
+--- a/src/math/riscv64/sqrt.c
++++ b/src/math/riscv64/sqrt.c
+@@ -4,7 +4,7 @@
+ double sqrt(double x)
+ {
+-      __asm__ ("sqrt.d %0, %1" : "=f"(x) : "f"(x));
++      __asm__ ("fsqrt.d %0, %1" : "=f"(x) : "f"(x));
+       return x;
+ }
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/812-riscv64-jmp_buf-reorganization.patch b/toolchain/musl/patches/812-riscv64-jmp_buf-reorganization.patch
new file mode 100644 (file)
index 0000000..9e2f3d6
--- /dev/null
@@ -0,0 +1,111 @@
+From ef67ce6f41f9a092a1d66a91edd80d56d273bfa7 Mon Sep 17 00:00:00 2001
+From: Stefan O'Rear <[email protected]>
+Date: Thu, 21 Mar 2019 14:18:11 -0400
+Subject: [PATCH 12/15] riscv64: jmp_buf reorganization
+
+1. fs3 is no longer saved and restored twice. This saves 8 bytes in all
+modes.
+
+2. The size of __jmp_buf (not jmp_buf) has been corrected to match the
+size of the non-signal registers saved and restored.
+
+The total size of jmp_buf now matches glibc; the fields are still in a
+different order.
+
+3. Additional information for sigsetjmp is now stored in words 0 and 2
+after __jmp_buf, matching the address usage in aarch64.
+---
+ arch/riscv64/bits/setjmp.h     |  2 +-
+ src/setjmp/riscv64/longjmp.S   | 17 ++++++++---------
+ src/setjmp/riscv64/setjmp.S    | 17 ++++++++---------
+ src/signal/riscv64/sigsetjmp.s |  4 ++--
+ 4 files changed, 19 insertions(+), 21 deletions(-)
+
+diff --git a/arch/riscv64/bits/setjmp.h b/arch/riscv64/bits/setjmp.h
+index b6cdc8e..ad7e401 100644
+--- a/arch/riscv64/bits/setjmp.h
++++ b/arch/riscv64/bits/setjmp.h
+@@ -1 +1 @@
+-typedef unsigned long __jmp_buf[28];
++typedef unsigned long __jmp_buf[26];
+diff --git a/src/setjmp/riscv64/longjmp.S b/src/setjmp/riscv64/longjmp.S
+index 46cc596..abc297e 100644
+--- a/src/setjmp/riscv64/longjmp.S
++++ b/src/setjmp/riscv64/longjmp.S
+@@ -27,15 +27,14 @@ longjmp:
+         fld fs1,  120(a0)
+         fld fs2,  128(a0)
+         fld fs3,  136(a0)
+-        fld fs3,  144(a0)
+-        fld fs4,  152(a0)
+-        fld fs5,  160(a0)
+-        fld fs6,  168(a0)
+-        fld fs7,  176(a0)
+-        fld fs8,  184(a0)
+-        fld fs9,  192(a0)
+-        fld fs10, 200(a0)
+-        fld fs11, 208(a0)
++        fld fs4,  144(a0)
++        fld fs5,  152(a0)
++        fld fs6,  160(a0)
++        fld fs7,  168(a0)
++        fld fs8,  176(a0)
++        fld fs9,  184(a0)
++        fld fs10, 192(a0)
++        fld fs11, 200(a0)
+ #endif
+         mv a0, a1
+diff --git a/src/setjmp/riscv64/setjmp.S b/src/setjmp/riscv64/setjmp.S
+index 0b58a67..04ba181 100644
+--- a/src/setjmp/riscv64/setjmp.S
++++ b/src/setjmp/riscv64/setjmp.S
+@@ -27,15 +27,14 @@ setjmp:
+         fsd fs1,  120(a0)
+         fsd fs2,  128(a0)
+         fsd fs3,  136(a0)
+-        fsd fs3,  144(a0)
+-        fsd fs4,  152(a0)
+-        fsd fs5,  160(a0)
+-        fsd fs6,  168(a0)
+-        fsd fs7,  176(a0)
+-        fsd fs8,  184(a0)
+-        fsd fs9,  192(a0)
+-        fsd fs10, 200(a0)
+-        fsd fs11, 208(a0)
++        fsd fs4,  144(a0)
++        fsd fs5,  152(a0)
++        fsd fs6,  160(a0)
++        fsd fs7,  168(a0)
++        fsd fs8,  176(a0)
++        fsd fs9,  184(a0)
++        fsd fs10, 192(a0)
++        fsd fs11, 200(a0)
+ #endif
+         li a0, 0
+diff --git a/src/signal/riscv64/sigsetjmp.s b/src/signal/riscv64/sigsetjmp.s
+index 9ed9500..ae0e79c 100644
+--- a/src/signal/riscv64/sigsetjmp.s
++++ b/src/signal/riscv64/sigsetjmp.s
+@@ -6,7 +6,7 @@ sigsetjmp:
+ __sigsetjmp:
+         beqz a1, setjmp
+-        sd ra, 216(a0)
++        sd ra, 208(a0)
+         sd s0, 224(a0)
+         mv s0, a0
+@@ -15,7 +15,7 @@ __sigsetjmp:
+         mv a1, a0
+         mv a0, s0
+         ld s0, 224(a0)
+-        ld ra, 216(a0)
++        ld ra, 208(a0)
+ .hidden __sigsetjmp_tail
+         j __sigsetjmp_tail
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/813-riscv64-Scrub-usage-of-j-jal.patch b/toolchain/musl/patches/813-riscv64-Scrub-usage-of-j-jal.patch
new file mode 100644 (file)
index 0000000..14f6c13
--- /dev/null
@@ -0,0 +1,69 @@
+From 66935ee514c82b7b43fbaec199c22db1a93c135d Mon Sep 17 00:00:00 2001
+From: Stefan O'Rear <[email protected]>
+Date: Thu, 21 Mar 2019 14:19:21 -0400
+Subject: [PATCH 13/15] riscv64: Scrub usage of j/jal
+
+j and jal with GNU binutils generate instructions and relocations only
+usable for a range of +- 1 MiB.  RISC-V musl ld.so is currently half of
+that, but this could be a problem for static linking.
+
+Replace with tail and call, pseudoinstructions that have +- 2 GiB range;
+with relaxation enabled the same opcodes will be generated for small
+binaries.
+---
+ src/ldso/riscv64/dlsym.s        | 2 +-
+ src/signal/riscv64/sigsetjmp.s  | 8 +++++---
+ src/thread/riscv64/syscall_cp.s | 2 +-
+ 3 files changed, 7 insertions(+), 5 deletions(-)
+
+diff --git a/src/ldso/riscv64/dlsym.s b/src/ldso/riscv64/dlsym.s
+index ff9109d..322d55b 100644
+--- a/src/ldso/riscv64/dlsym.s
++++ b/src/ldso/riscv64/dlsym.s
+@@ -3,4 +3,4 @@
+ .type dlsym, %function
+ dlsym:
+         mv a2, ra
+-        j __dlsym
++        tail __dlsym
+diff --git a/src/signal/riscv64/sigsetjmp.s b/src/signal/riscv64/sigsetjmp.s
+index ae0e79c..1acd485 100644
+--- a/src/signal/riscv64/sigsetjmp.s
++++ b/src/signal/riscv64/sigsetjmp.s
+@@ -4,13 +4,15 @@
+ .type __sigsetjmp, %function
+ sigsetjmp:
+ __sigsetjmp:
+-        beqz a1, setjmp
++        bnez a1, 1f
++        tail setjmp
++1:
+         sd ra, 208(a0)
+         sd s0, 224(a0)
+         mv s0, a0
+-        jal setjmp
++        call setjmp
+         mv a1, a0
+         mv a0, s0
+@@ -18,4 +20,4 @@ __sigsetjmp:
+         ld ra, 208(a0)
+ .hidden __sigsetjmp_tail
+-        j __sigsetjmp_tail
++        tail __sigsetjmp_tail
+diff --git a/src/thread/riscv64/syscall_cp.s b/src/thread/riscv64/syscall_cp.s
+index 65cf722..081efe2 100644
+--- a/src/thread/riscv64/syscall_cp.s
++++ b/src/thread/riscv64/syscall_cp.s
+@@ -26,4 +26,4 @@ __cp_begin:
+ __cp_end:
+         ret
+ __cp_cancel:
+-        j __cancel
++        tail __cancel
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/814-riscv64-simplify-longjmp-return-value-assignment.patch b/toolchain/musl/patches/814-riscv64-simplify-longjmp-return-value-assignment.patch
new file mode 100644 (file)
index 0000000..bc9eb6e
--- /dev/null
@@ -0,0 +1,27 @@
+From 327f05b6a1917f2f4619ddd14c3c7ab98644752f Mon Sep 17 00:00:00 2001
+From: Stefan O'Rear <[email protected]>
+Date: Thu, 21 Mar 2019 14:20:07 -0400
+Subject: [PATCH 14/15] riscv64: simplify longjmp return value assignment
+
+---
+ src/setjmp/riscv64/longjmp.S | 7 +++----
+ 1 file changed, 3 insertions(+), 4 deletions(-)
+
+diff --git a/src/setjmp/riscv64/longjmp.S b/src/setjmp/riscv64/longjmp.S
+index abc297e..1092c5a 100644
+--- a/src/setjmp/riscv64/longjmp.S
++++ b/src/setjmp/riscv64/longjmp.S
+@@ -37,7 +37,6 @@ longjmp:
+         fld fs11, 200(a0)
+ #endif
+-        mv a0, a1
+-        bnez a1, 1f
+-        li a0, 1
+-1:      ret
++        seqz a0, a1
++        add a0, a0, a1
++        ret
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/815-riscv64-s-scall-ecall-g.patch b/toolchain/musl/patches/815-riscv64-s-scall-ecall-g.patch
new file mode 100644 (file)
index 0000000..3ff78fc
--- /dev/null
@@ -0,0 +1,98 @@
+From 8fcd25578fa08d4eeae68a21cb36f2c5f39c29d5 Mon Sep 17 00:00:00 2001
+From: Stefan O'Rear <[email protected]>
+Date: Thu, 21 Mar 2019 14:22:07 -0400
+Subject: [PATCH 15/15] riscv64: s/scall/ecall/g
+
+The instruction was renamed in RISC-V 2.0 (2014) and binutils'
+acceptance of the old name is not a documented or guaranteed behavior.
+---
+ arch/riscv64/syscall_arch.h      | 2 +-
+ src/internal/riscv64/syscall.s   | 2 +-
+ src/signal/riscv64/restore.s     | 2 +-
+ src/thread/riscv64/__unmapself.s | 4 ++--
+ src/thread/riscv64/clone.s       | 4 ++--
+ src/thread/riscv64/syscall_cp.s  | 2 +-
+ 6 files changed, 8 insertions(+), 8 deletions(-)
+
+diff --git a/arch/riscv64/syscall_arch.h b/arch/riscv64/syscall_arch.h
+index 0e59581..a5b0f64 100644
+--- a/arch/riscv64/syscall_arch.h
++++ b/arch/riscv64/syscall_arch.h
+@@ -2,7 +2,7 @@
+ #define __SYSCALL_LL_O(x) (x)
+ #define __asm_syscall(...) \
+-      __asm__ __volatile__ ("scall\n\t" \
++      __asm__ __volatile__ ("ecall\n\t" \
+       : "+r"(a0) : __VA_ARGS__ : "memory"); \
+       return a0; \
+diff --git a/src/internal/riscv64/syscall.s b/src/internal/riscv64/syscall.s
+index a7d125a..27905f4 100644
+--- a/src/internal/riscv64/syscall.s
++++ b/src/internal/riscv64/syscall.s
+@@ -11,5 +11,5 @@ __syscall:
+         mv a5, a6
+         mv a6, a7
+         mv a7, t0
+-        scall
++        ecall
+         ret
+diff --git a/src/signal/riscv64/restore.s b/src/signal/riscv64/restore.s
+index 732736d..40012c7 100644
+--- a/src/signal/riscv64/restore.s
++++ b/src/signal/riscv64/restore.s
+@@ -5,4 +5,4 @@ __restore:
+ .type __restore_rt, %function
+ __restore_rt:
+       li a7, 139 # SYS_rt_sigreturn
+-      scall
++      ecall
+diff --git a/src/thread/riscv64/__unmapself.s b/src/thread/riscv64/__unmapself.s
+index 98e7881..805d3a1 100644
+--- a/src/thread/riscv64/__unmapself.s
++++ b/src/thread/riscv64/__unmapself.s
+@@ -2,6 +2,6 @@
+ .type __unmapself, %function
+ __unmapself:
+        li a7, 215 # SYS_munmap
+-       scall
++       ecall
+        li a7, 93  # SYS_exit
+-       scall
++       ecall
+diff --git a/src/thread/riscv64/clone.s b/src/thread/riscv64/clone.s
+index b2d4f02..52ee8cd 100644
+--- a/src/thread/riscv64/clone.s
++++ b/src/thread/riscv64/clone.s
+@@ -18,7 +18,7 @@ __clone:
+         mv a3, a5
+         mv a4, a6
+         li a7, 220 # SYS_clone
+-        scall
++        ecall
+         beqz a0, 1f
+         # Parent
+@@ -31,4 +31,4 @@ __clone:
+         # Exit
+         li a7, 93 # SYS_exit
+-        scall
++        ecall
+diff --git a/src/thread/riscv64/syscall_cp.s b/src/thread/riscv64/syscall_cp.s
+index 081efe2..b54ea20 100644
+--- a/src/thread/riscv64/syscall_cp.s
++++ b/src/thread/riscv64/syscall_cp.s
+@@ -22,7 +22,7 @@ __cp_begin:
+         mv a5, a7
+         ld a6, 0(sp)
+         mv a7, t0
+-        scall
++        ecall
+ __cp_end:
+         ret
+ __cp_cancel:
+-- 
+2.1.4
+
diff --git a/toolchain/musl/patches/902-RISC-V-add-riscv32-and-riscv64.patch b/toolchain/musl/patches/902-RISC-V-add-riscv32-and-riscv64.patch
deleted file mode 100644 (file)
index 0191e04..0000000
+++ /dev/null
@@ -1,3333 +0,0 @@
-From 6a4f4a9c774608add4b02f95322518bd2f5f51ee Mon Sep 17 00:00:00 2001
-From: Aric Belsito <[email protected]>
-Date: Tue, 5 Jan 2016 16:12:18 -0800
-Subject: [PATCH] RISC-V: add riscv32 and riscv64 architecture support
-
-Author: Alex Suykov <[email protected]>
-Author: Aric Belsito <[email protected]>
-Author: Michael Clark <[email protected]>
----
- arch/riscv32/atomic_arch.h             |  35 ++++
- arch/riscv32/bits/alltypes.h.in        |  26 +++
- arch/riscv32/bits/endian.h             |   5 +
- arch/riscv32/bits/fcntl.h              |  38 ++++
- arch/riscv32/bits/fenv.h               |  18 ++
- arch/riscv32/bits/float.h              |  16 ++
- arch/riscv32/bits/ipc.h                |  14 ++
- arch/riscv32/bits/limits.h             |   7 +
- arch/riscv32/bits/msg.h                |  13 ++
- arch/riscv32/bits/posix.h              |   2 +
- arch/riscv32/bits/reg.h                |   8 +
- arch/riscv32/bits/sem.h                |   9 +
- arch/riscv32/bits/setjmp.h             |   1 +
- arch/riscv32/bits/shm.h                |  26 +++
- arch/riscv32/bits/signal.h             | 113 ++++++++++
- arch/riscv32/bits/socket.h             |  33 +++
- arch/riscv32/bits/stat.h               |  18 ++
- arch/riscv32/bits/stdint.h             |  20 ++
- arch/riscv32/bits/syscall.h.in         | 278 +++++++++++++++++++++++++
- arch/riscv32/bits/user.h               |  43 ++++
- arch/riscv32/crt_arch.h                |  18 ++
- arch/riscv32/pthread_arch.h            |  12 ++
- arch/riscv32/reloc.h                   |  27 +++
- arch/riscv32/syscall_arch.h            |  78 +++++++
- arch/riscv64/atomic_arch.h             |  66 ++++++
- arch/riscv64/bits/alltypes.h.in        |  29 +++
- arch/riscv64/bits/endian.h             |   5 +
- arch/riscv64/bits/fcntl.h              |  38 ++++
- arch/riscv64/bits/fenv.h               |  17 ++
- arch/riscv64/bits/float.h              |  16 ++
- arch/riscv64/bits/ipc.h                |  14 ++
- arch/riscv64/bits/limits.h             |   7 +
- arch/riscv64/bits/mman.h               |   1 +
- arch/riscv64/bits/msg.h                |  13 ++
- arch/riscv64/bits/posix.h              |   2 +
- arch/riscv64/bits/reg.h                |   8 +
- arch/riscv64/bits/sem.h                |   9 +
- arch/riscv64/bits/setjmp.h             |   1 +
- arch/riscv64/bits/shm.h                |  26 +++
- arch/riscv64/bits/signal.h             | 113 ++++++++++
- arch/riscv64/bits/socket.h             |  33 +++
- arch/riscv64/bits/stat.h               |  18 ++
- arch/riscv64/bits/stdint.h             |  20 ++
- arch/riscv64/bits/syscall.h.in         | 278 +++++++++++++++++++++++++
- arch/riscv64/bits/user.h               |  43 ++++
- arch/riscv64/crt_arch.h                |  18 ++
- arch/riscv64/pthread_arch.h            |  12 ++
- arch/riscv64/reloc.h                   |  27 +++
- arch/riscv64/syscall_arch.h            |  76 +++++++
- configure                              |   7 +
- crt/riscv32/crti.s                     |  11 +
- crt/riscv32/crtn.s                     |   0
- crt/riscv64/crti.s                     |  11 +
- crt/riscv64/crtn.s                     |   0
- include/elf.h                          |  56 +++++
- src/fenv/riscv32/fenv-sf.c             |   3 +
- src/fenv/riscv32/fenv.S                |  53 +++++
- src/fenv/riscv64/fenv-sf.c             |   3 +
- src/fenv/riscv64/fenv.S                |  53 +++++
- src/internal/riscv32/syscall.s         |  15 ++
- src/internal/riscv64/syscall.s         |  15 ++
- src/ldso/riscv32/dlsym.s               |   6 +
- src/ldso/riscv64/dlsym.s               |   6 +
- src/math/riscv32/copysign.s            |   5 +
- src/math/riscv32/copysignf.s           |   5 +
- src/math/riscv32/fabs.s                |   5 +
- src/math/riscv32/fabsf.s               |   5 +
- src/math/riscv32/fma.s                 |   5 +
- src/math/riscv32/fmaf.s                |   5 +
- src/math/riscv32/fmax.s                |   5 +
- src/math/riscv32/fmaxf.s               |   5 +
- src/math/riscv32/fmin.s                |   5 +
- src/math/riscv32/fminf.s               |   5 +
- src/math/riscv32/sqrt.s                |   5 +
- src/math/riscv32/sqrtf.s               |   5 +
- src/math/riscv64/copysign.s            |   5 +
- src/math/riscv64/copysignf.s           |   5 +
- src/math/riscv64/fabs.s                |   5 +
- src/math/riscv64/fabsf.s               |   5 +
- src/math/riscv64/fma.s                 |   5 +
- src/math/riscv64/fmaf.s                |   5 +
- src/math/riscv64/fmax.s                |   5 +
- src/math/riscv64/fmaxf.s               |   5 +
- src/math/riscv64/fmin.s                |   5 +
- src/math/riscv64/fminf.s               |   5 +
- src/math/riscv64/sqrt.s                |   5 +
- src/math/riscv64/sqrtf.s               |   5 +
- src/setjmp/riscv32/longjmp.S           |  44 ++++
- src/setjmp/riscv32/setjmp.S            |  42 ++++
- src/setjmp/riscv64/longjmp.S           |  44 ++++
- src/setjmp/riscv64/setjmp.S            |  42 ++++
- src/signal/riscv32/restore.s           |   8 +
- src/signal/riscv32/sigsetjmp.s         |  21 ++
- src/signal/riscv64/restore.s           |   8 +
- src/signal/riscv64/sigsetjmp.s         |  21 ++
- src/thread/riscv32/__set_thread_area.s |   6 +
- src/thread/riscv32/__unmapself.s       |   7 +
- src/thread/riscv32/clone.s             |  34 +++
- src/thread/riscv32/syscall_cp.s        |  29 +++
- src/thread/riscv64/__set_thread_area.s |   6 +
- src/thread/riscv64/__unmapself.s       |   7 +
- src/thread/riscv64/clone.s             |  34 +++
- src/thread/riscv64/syscall_cp.s        |  29 +++
- 103 files changed, 2489 insertions(+)
- create mode 100644 arch/riscv32/atomic_arch.h
- create mode 100644 arch/riscv32/bits/alltypes.h.in
- create mode 100644 arch/riscv32/bits/endian.h
- create mode 100644 arch/riscv32/bits/fcntl.h
- create mode 100644 arch/riscv32/bits/fenv.h
- create mode 100644 arch/riscv32/bits/float.h
- create mode 100644 arch/riscv32/bits/ipc.h
- create mode 100644 arch/riscv32/bits/limits.h
- create mode 100644 arch/riscv32/bits/msg.h
- create mode 100644 arch/riscv32/bits/posix.h
- create mode 100644 arch/riscv32/bits/reg.h
- create mode 100644 arch/riscv32/bits/sem.h
- create mode 100644 arch/riscv32/bits/setjmp.h
- create mode 100644 arch/riscv32/bits/shm.h
- create mode 100644 arch/riscv32/bits/signal.h
- create mode 100644 arch/riscv32/bits/socket.h
- create mode 100644 arch/riscv32/bits/stat.h
- create mode 100644 arch/riscv32/bits/stdint.h
- create mode 100644 arch/riscv32/bits/syscall.h.in
- create mode 100644 arch/riscv32/bits/user.h
- create mode 100644 arch/riscv32/crt_arch.h
- create mode 100644 arch/riscv32/pthread_arch.h
- create mode 100644 arch/riscv32/reloc.h
- create mode 100644 arch/riscv32/syscall_arch.h
- create mode 100644 arch/riscv64/atomic_arch.h
- create mode 100644 arch/riscv64/bits/alltypes.h.in
- create mode 100644 arch/riscv64/bits/endian.h
- create mode 100644 arch/riscv64/bits/fcntl.h
- create mode 100644 arch/riscv64/bits/fenv.h
- create mode 100644 arch/riscv64/bits/float.h
- create mode 100644 arch/riscv64/bits/ipc.h
- create mode 100644 arch/riscv64/bits/limits.h
- create mode 100644 arch/riscv64/bits/mman.h
- create mode 100644 arch/riscv64/bits/msg.h
- create mode 100644 arch/riscv64/bits/posix.h
- create mode 100644 arch/riscv64/bits/reg.h
- create mode 100644 arch/riscv64/bits/sem.h
- create mode 100644 arch/riscv64/bits/setjmp.h
- create mode 100644 arch/riscv64/bits/shm.h
- create mode 100644 arch/riscv64/bits/signal.h
- create mode 100644 arch/riscv64/bits/socket.h
- create mode 100644 arch/riscv64/bits/stat.h
- create mode 100644 arch/riscv64/bits/stdint.h
- create mode 100644 arch/riscv64/bits/syscall.h.in
- create mode 100644 arch/riscv64/bits/user.h
- create mode 100644 arch/riscv64/crt_arch.h
- create mode 100644 arch/riscv64/pthread_arch.h
- create mode 100644 arch/riscv64/reloc.h
- create mode 100644 arch/riscv64/syscall_arch.h
- create mode 100644 crt/riscv32/crti.s
- create mode 100644 crt/riscv32/crtn.s
- create mode 100644 crt/riscv64/crti.s
- create mode 100644 crt/riscv64/crtn.s
- create mode 100644 src/fenv/riscv32/fenv-sf.c
- create mode 100644 src/fenv/riscv32/fenv.S
- create mode 100644 src/fenv/riscv64/fenv-sf.c
- create mode 100644 src/fenv/riscv64/fenv.S
- create mode 100644 src/internal/riscv32/syscall.s
- create mode 100644 src/internal/riscv64/syscall.s
- create mode 100644 src/ldso/riscv32/dlsym.s
- create mode 100644 src/ldso/riscv64/dlsym.s
- create mode 100644 src/math/riscv32/copysign.s
- create mode 100644 src/math/riscv32/copysignf.s
- create mode 100644 src/math/riscv32/fabs.s
- create mode 100644 src/math/riscv32/fabsf.s
- create mode 100644 src/math/riscv32/fma.s
- create mode 100644 src/math/riscv32/fmaf.s
- create mode 100644 src/math/riscv32/fmax.s
- create mode 100644 src/math/riscv32/fmaxf.s
- create mode 100644 src/math/riscv32/fmin.s
- create mode 100644 src/math/riscv32/fminf.s
- create mode 100644 src/math/riscv32/sqrt.s
- create mode 100644 src/math/riscv32/sqrtf.s
- create mode 100644 src/math/riscv64/copysign.s
- create mode 100644 src/math/riscv64/copysignf.s
- create mode 100644 src/math/riscv64/fabs.s
- create mode 100644 src/math/riscv64/fabsf.s
- create mode 100644 src/math/riscv64/fma.s
- create mode 100644 src/math/riscv64/fmaf.s
- create mode 100644 src/math/riscv64/fmax.s
- create mode 100644 src/math/riscv64/fmaxf.s
- create mode 100644 src/math/riscv64/fmin.s
- create mode 100644 src/math/riscv64/fminf.s
- create mode 100644 src/math/riscv64/sqrt.s
- create mode 100644 src/math/riscv64/sqrtf.s
- create mode 100644 src/setjmp/riscv32/longjmp.S
- create mode 100644 src/setjmp/riscv32/setjmp.S
- create mode 100644 src/setjmp/riscv64/longjmp.S
- create mode 100644 src/setjmp/riscv64/setjmp.S
- create mode 100644 src/signal/riscv32/restore.s
- create mode 100644 src/signal/riscv32/sigsetjmp.s
- create mode 100644 src/signal/riscv64/restore.s
- create mode 100644 src/signal/riscv64/sigsetjmp.s
- create mode 100644 src/thread/riscv32/__set_thread_area.s
- create mode 100644 src/thread/riscv32/__unmapself.s
- create mode 100644 src/thread/riscv32/clone.s
- create mode 100644 src/thread/riscv32/syscall_cp.s
- create mode 100644 src/thread/riscv64/__set_thread_area.s
- create mode 100644 src/thread/riscv64/__unmapself.s
- create mode 100644 src/thread/riscv64/clone.s
- create mode 100644 src/thread/riscv64/syscall_cp.s
-
-diff --git a/arch/riscv32/atomic_arch.h b/arch/riscv32/atomic_arch.h
-new file mode 100644
-index 00000000..93c89cc2
---- /dev/null
-+++ b/arch/riscv32/atomic_arch.h
-@@ -0,0 +1,35 @@
-+#define a_barrier a_barrier
-+static inline void a_barrier()
-+{
-+      __asm__ __volatile__ ("fence rw,rw" : : : "memory");
-+}
-+
-+#define a_ll a_ll
-+static inline int a_ll(volatile int *p)
-+{
-+      int v;
-+      __asm__ __volatile__ ("lr.w %0, (%1)" : "=&r"(v) : "r"(p));
-+      return v;
-+}
-+
-+#define a_sc a_sc
-+static inline int a_sc(volatile int *p, int v)
-+{
-+      int r;
-+      __asm__ __volatile__ ("sc.w %0, %2, (%1)" : "=&r"(r) : "r"(p), "r"(v) : "memory");
-+      return !r;
-+}
-+
-+#define a_cas a_cas
-+static inline int a_cas(volatile int *p, int t, int s)
-+{
-+      int old, tmp;
-+      __asm__("1:  lr.w    %0, %2      \n"
-+              "    bne     %0, %3, 1f  \n"
-+              "    sc.w    %1, %4, %2  \n"
-+              "    bnez    %1, 1b      \n"
-+              "1:                      \n"
-+              : "=&r"(old), "+r"(tmp), "+A"(*p)
-+              : "r"(t), "r"(s));
-+      return old;
-+}
-diff --git a/arch/riscv32/bits/alltypes.h.in b/arch/riscv32/bits/alltypes.h.in
-new file mode 100644
-index 00000000..66ca18ad
---- /dev/null
-+++ b/arch/riscv32/bits/alltypes.h.in
-@@ -0,0 +1,26 @@
-+#define _Addr int
-+#define _Int64 long long
-+#define _Reg int
-+
-+TYPEDEF __builtin_va_list va_list;
-+TYPEDEF __builtin_va_list __isoc_va_list;
-+
-+#ifndef __cplusplus
-+TYPEDEF int wchar_t;
-+#endif
-+
-+TYPEDEF float float_t;
-+TYPEDEF double double_t;
-+
-+TYPEDEF struct { long long __ll; long double __ld; } max_align_t;
-+
-+TYPEDEF long time_t;
-+TYPEDEF long suseconds_t;
-+
-+TYPEDEF struct { union { int __i[9]; volatile int __vi[9]; unsigned __s[9]; } __u; } pthread_attr_t;
-+TYPEDEF struct { union { int __i[6]; volatile int __vi[6]; volatile void *volatile __p[6]; } __u; } pthread_mutex_t;
-+TYPEDEF struct { union { int __i[6]; volatile int __vi[6]; volatile void *volatile __p[6]; } __u; } mtx_t;
-+TYPEDEF struct { union { int __i[12]; volatile int __vi[12]; void *__p[12]; } __u; } pthread_cond_t;
-+TYPEDEF struct { union { int __i[12]; volatile int __vi[12]; void *__p[12]; } __u; } cnd_t;
-+TYPEDEF struct { union { int __i[8]; volatile int __vi[8]; void *__p[8]; } __u; } pthread_rwlock_t;
-+TYPEDEF struct { union { int __i[5]; volatile int __vi[5]; void *__p[5]; } __u; } pthread_barrier_t;
-diff --git a/arch/riscv32/bits/endian.h b/arch/riscv32/bits/endian.h
-new file mode 100644
-index 00000000..7df0e02a
---- /dev/null
-+++ b/arch/riscv32/bits/endian.h
-@@ -0,0 +1,5 @@
-+#if __RISCVEB__
-+#define __BYTE_ORDER __BIG_ENDIAN
-+#else
-+#define __BYTE_ORDER __LITTLE_ENDIAN
-+#endif
-diff --git a/arch/riscv32/bits/fcntl.h b/arch/riscv32/bits/fcntl.h
-new file mode 100644
-index 00000000..92787976
---- /dev/null
-+++ b/arch/riscv32/bits/fcntl.h
-@@ -0,0 +1,38 @@
-+#define O_CREAT        0100
-+#define O_EXCL         0200
-+#define O_NOCTTY       0400
-+#define O_TRUNC       01000
-+#define O_APPEND      02000
-+#define O_NONBLOCK    04000
-+#define O_DSYNC      010000
-+#define O_SYNC     04010000
-+#define O_RSYNC    04010000
-+#define O_DIRECTORY  040000
-+#define O_NOFOLLOW  0100000
-+#define O_CLOEXEC  02000000
-+
-+#define O_ASYNC      020000
-+#define O_DIRECT    0200000
-+#define O_LARGEFILE 0400000
-+#define O_NOATIME  01000000
-+#define O_PATH    010000000
-+#define O_TMPFILE 020040000
-+#define O_NDELAY O_NONBLOCK
-+
-+#define F_DUPFD  0
-+#define F_GETFD  1
-+#define F_SETFD  2
-+#define F_GETFL  3
-+#define F_SETFL  4
-+#define F_GETLK  5
-+#define F_SETLK  6
-+#define F_SETLKW 7
-+#define F_SETOWN 8
-+#define F_GETOWN 9
-+#define F_SETSIG 10
-+#define F_GETSIG 11
-+
-+#define F_SETOWN_EX 15
-+#define F_GETOWN_EX 16
-+
-+#define F_GETOWNER_UIDS 17
-diff --git a/arch/riscv32/bits/fenv.h b/arch/riscv32/bits/fenv.h
-new file mode 100644
-index 00000000..6ac43e4e
---- /dev/null
-+++ b/arch/riscv32/bits/fenv.h
-@@ -0,0 +1,18 @@
-+#define FE_INVALID      16
-+#define FE_DIVBYZERO    8
-+#define FE_OVERFLOW     4
-+#define FE_UNDERFLOW    2
-+#define FE_INEXACT      1
-+
-+#define FE_ALL_EXCEPT   31
-+
-+#define FE_TONEAREST    0
-+#define FE_DOWNWARD     2
-+#define FE_UPWARD       3
-+#define FE_TOWARDZERO   1
-+
-+typedef unsigned int fexcept_t;
-+
-+typedef unsigned int fenv_t;
-+
-+#define FE_DFL_ENV      ((const fenv_t *) -1)
-diff --git a/arch/riscv32/bits/float.h b/arch/riscv32/bits/float.h
-new file mode 100644
-index 00000000..719c7908
---- /dev/null
-+++ b/arch/riscv32/bits/float.h
-@@ -0,0 +1,16 @@
-+#define FLT_EVAL_METHOD 0
-+
-+#define LDBL_TRUE_MIN 6.47517511943802511092443895822764655e-4966L
-+#define LDBL_MIN 3.36210314311209350626267781732175260e-4932L
-+#define LDBL_MAX 1.18973149535723176508575932662800702e+4932L
-+#define LDBL_EPSILON 1.92592994438723585305597794258492732e-34L
-+
-+#define LDBL_MANT_DIG 113
-+#define LDBL_MIN_EXP (-16381)
-+#define LDBL_MAX_EXP 16384
-+
-+#define LDBL_DIG 33
-+#define LDBL_MIN_10_EXP (-4931)
-+#define LDBL_MAX_10_EXP 4932
-+
-+#define DECIMAL_DIG 36
-diff --git a/arch/riscv32/bits/ipc.h b/arch/riscv32/bits/ipc.h
-new file mode 100644
-index 00000000..6f3328a8
---- /dev/null
-+++ b/arch/riscv32/bits/ipc.h
-@@ -0,0 +1,14 @@
-+struct ipc_perm {
-+      key_t __ipc_perm_key;
-+      uid_t uid;
-+      gid_t gid;
-+      uid_t cuid;
-+      gid_t cgid;
-+      mode_t mode;
-+      unsigned short __ipc_perm_seq;
-+
-+      unsigned long __pad1;
-+      unsigned long __pad2;
-+};
-+
-+#define IPC_64 0
-diff --git a/arch/riscv32/bits/limits.h b/arch/riscv32/bits/limits.h
-new file mode 100644
-index 00000000..fbc6d238
---- /dev/null
-+++ b/arch/riscv32/bits/limits.h
-@@ -0,0 +1,7 @@
-+#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
-+ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-+#define LONG_BIT 32
-+#endif
-+
-+#define LONG_MAX  0x7fffffffL
-+#define LLONG_MAX  0x7fffffffffffffffLL
-diff --git a/arch/riscv32/bits/msg.h b/arch/riscv32/bits/msg.h
-new file mode 100644
-index 00000000..641e1703
---- /dev/null
-+++ b/arch/riscv32/bits/msg.h
-@@ -0,0 +1,13 @@
-+struct msqid_ds {
-+      struct ipc_perm msg_perm;
-+      time_t msg_stime;
-+      time_t msg_rtime;
-+      time_t msg_ctime;
-+      unsigned long msg_cbytes;
-+      msgqnum_t msg_qnum;
-+      msglen_t msg_qbytes;
-+      pid_t msg_lspid;
-+      pid_t msg_lrpid;
-+      unsigned long __pad1;
-+      unsigned long __pad2;
-+};
-diff --git a/arch/riscv32/bits/posix.h b/arch/riscv32/bits/posix.h
-new file mode 100644
-index 00000000..7563df5d
---- /dev/null
-+++ b/arch/riscv32/bits/posix.h
-@@ -0,0 +1,2 @@
-+# define _POSIX_V6_ILP32_OFFBIG 1
-+# define _POSIX_V7_ILP32_OFFBIG 1
-diff --git a/arch/riscv32/bits/reg.h b/arch/riscv32/bits/reg.h
-new file mode 100644
-index 00000000..e0bf40d5
---- /dev/null
-+++ b/arch/riscv32/bits/reg.h
-@@ -0,0 +1,8 @@
-+#undef __WORDSIZE
-+#define __WORDSIZE 32
-+#define REG_PC 0
-+#define REG_RA 1
-+#define REG_SP 2
-+#define REG_TP 4
-+#define REG_S0 8
-+#define REG_A0 10
-diff --git a/arch/riscv32/bits/sem.h b/arch/riscv32/bits/sem.h
-new file mode 100644
-index 00000000..5f93c12d
---- /dev/null
-+++ b/arch/riscv32/bits/sem.h
-@@ -0,0 +1,9 @@
-+struct semid_ds {
-+      struct ipc_perm sem_perm;
-+      time_t sem_otime;
-+      time_t sem_ctime;
-+      unsigned short sem_nsems;
-+      char __sem_nsems_pad[sizeof(time_t)-sizeof(short)];
-+      time_t __unused3;
-+      time_t __unused4;
-+};
-diff --git a/arch/riscv32/bits/setjmp.h b/arch/riscv32/bits/setjmp.h
-new file mode 100644
-index 00000000..ef6a017a
---- /dev/null
-+++ b/arch/riscv32/bits/setjmp.h
-@@ -0,0 +1 @@
-+typedef unsigned long __jmp_buf[40];
-diff --git a/arch/riscv32/bits/shm.h b/arch/riscv32/bits/shm.h
-new file mode 100644
-index 00000000..f4b87126
---- /dev/null
-+++ b/arch/riscv32/bits/shm.h
-@@ -0,0 +1,26 @@
-+#define SHMLBA 4096
-+
-+struct shmid_ds
-+{
-+      struct ipc_perm shm_perm;
-+      size_t shm_segsz;
-+      time_t shm_atime;
-+      time_t shm_dtime;
-+      time_t shm_ctime;
-+      pid_t shm_cpid;
-+      pid_t shm_lpid;
-+      unsigned long shm_nattch;
-+      unsigned long __pad1;
-+      unsigned long __pad2;
-+};
-+
-+struct shminfo {
-+      unsigned long shmmax, shmmin, shmmni, shmseg, shmall, __unused[4];
-+};
-+
-+struct shm_info {
-+      int __used_ids;
-+      unsigned long shm_tot, shm_rss, shm_swp;
-+      unsigned long __swap_attempts, __swap_successes;
-+};
-+
-diff --git a/arch/riscv32/bits/signal.h b/arch/riscv32/bits/signal.h
-new file mode 100644
-index 00000000..8b992cc8
---- /dev/null
-+++ b/arch/riscv32/bits/signal.h
-@@ -0,0 +1,113 @@
-+#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
-+ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-+
-+#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-+# define MINSIGSTKSZ 2048
-+# define SIGSTKSZ 8192
-+#endif
-+
-+/* gregs[0] holds the program counter. */
-+
-+#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-+typedef unsigned long greg_t;
-+typedef unsigned long gregset_t[32];
-+
-+struct __riscv_f_ext_state {
-+      unsigned int f[32];
-+      unsigned int fcsr;
-+};
-+
-+struct __riscv_d_ext_state {
-+      unsigned long long f[32];
-+      unsigned int fcsr;
-+};
-+
-+struct __riscv_q_ext_state {
-+      unsigned long long f[64] __attribute__((aligned(16)));
-+      unsigned int fcsr;
-+      unsigned int reserved[3];
-+};
-+
-+union __riscv_fp_state {
-+      struct __riscv_f_ext_state f;
-+      struct __riscv_d_ext_state d;
-+      struct __riscv_q_ext_state q;
-+};
-+
-+typedef union __riscv_fp_state fpregset_t;
-+
-+typedef struct sigcontext {
-+      gregset_t gregs;
-+      fpregset_t fpregs;
-+} mcontext_t;
-+
-+#else
-+typedef struct {
-+      unsigned long gregs[32];
-+      unsigned long long fpregs[66];
-+} mcontext_t;
-+#endif
-+
-+struct sigaltstack {
-+      void *ss_sp;
-+      int ss_flags;
-+      size_t ss_size;
-+};
-+
-+typedef struct __ucontext
-+{
-+      unsigned long uc_flags;
-+      struct __ucontext *uc_link;
-+      stack_t uc_stack;
-+      sigset_t uc_sigmask;
-+      char __unused[1024 / 8 - sizeof(sigset_t)];
-+      mcontext_t uc_mcontext;
-+} ucontext_t;
-+
-+#define SA_NOCLDSTOP 1
-+#define SA_NOCLDWAIT 2
-+#define SA_SIGINFO   4
-+#define SA_ONSTACK   0x08000000
-+#define SA_RESTART   0x10000000
-+#define SA_NODEFER   0x40000000
-+#define SA_RESETHAND 0x80000000
-+#define SA_RESTORER  0x04000000
-+
-+#endif
-+
-+#define SIGHUP     1
-+#define SIGINT     2
-+#define SIGQUIT    3
-+#define SIGILL     4
-+#define SIGTRAP    5
-+#define SIGABRT    6
-+#define SIGIOT     SIGABRT
-+#define SIGBUS     7
-+#define SIGFPE     8
-+#define SIGKILL    9
-+#define SIGUSR1   10
-+#define SIGSEGV   11
-+#define SIGUSR2   12
-+#define SIGPIPE   13
-+#define SIGALRM   14
-+#define SIGTERM   15
-+#define SIGSTKFLT 16
-+#define SIGCHLD   17
-+#define SIGCONT   18
-+#define SIGSTOP   19
-+#define SIGTSTP   20
-+#define SIGTTIN   21
-+#define SIGTTOU   22
-+#define SIGURG    23
-+#define SIGXCPU   24
-+#define SIGXFSZ   25
-+#define SIGVTALRM 26
-+#define SIGPROF   27
-+#define SIGWINCH  28
-+#define SIGIO     29
-+#define SIGPOLL   SIGIO
-+#define SIGPWR    30
-+#define SIGSYS    31
-+#define SIGUNUSED SIGSYS
-+
-+#define _NSIG     65
-diff --git a/arch/riscv32/bits/socket.h b/arch/riscv32/bits/socket.h
-new file mode 100644
-index 00000000..c11677e9
---- /dev/null
-+++ b/arch/riscv32/bits/socket.h
-@@ -0,0 +1,33 @@
-+#include <endian.h>
-+
-+struct msghdr {
-+      void *msg_name;
-+      socklen_t msg_namelen;
-+      struct iovec *msg_iov;
-+#if __BYTE_ORDER == __BIG_ENDIAN
-+      int __pad1, msg_iovlen;
-+#else
-+      int msg_iovlen, __pad1;
-+#endif
-+      void *msg_control;
-+#if __BYTE_ORDER == __BIG_ENDIAN
-+      int __pad2;
-+      socklen_t msg_controllen;
-+#else
-+      socklen_t msg_controllen;
-+      int __pad2;
-+#endif
-+      int msg_flags;
-+};
-+
-+struct cmsghdr {
-+#if __BYTE_ORDER == __BIG_ENDIAN
-+      int __pad1;
-+      socklen_t cmsg_len;
-+#else
-+      socklen_t cmsg_len;
-+      int __pad1;
-+#endif
-+      int cmsg_level;
-+      int cmsg_type;
-+};
-diff --git a/arch/riscv32/bits/stat.h b/arch/riscv32/bits/stat.h
-new file mode 100644
-index 00000000..b7f4221b
---- /dev/null
-+++ b/arch/riscv32/bits/stat.h
-@@ -0,0 +1,18 @@
-+struct stat {
-+      dev_t st_dev;
-+      ino_t st_ino;
-+      mode_t st_mode;
-+      nlink_t st_nlink;
-+      uid_t st_uid;
-+      gid_t st_gid;
-+      dev_t st_rdev;
-+      unsigned long __pad;
-+      off_t st_size;
-+      blksize_t st_blksize;
-+      int __pad2;
-+      blkcnt_t st_blocks;
-+      struct timespec st_atim;
-+      struct timespec st_mtim;
-+      struct timespec st_ctim;
-+      unsigned __unused[2];
-+};
-diff --git a/arch/riscv32/bits/stdint.h b/arch/riscv32/bits/stdint.h
-new file mode 100644
-index 00000000..d1b27121
---- /dev/null
-+++ b/arch/riscv32/bits/stdint.h
-@@ -0,0 +1,20 @@
-+typedef int32_t int_fast16_t;
-+typedef int32_t int_fast32_t;
-+typedef uint32_t uint_fast16_t;
-+typedef uint32_t uint_fast32_t;
-+
-+#define INT_FAST16_MIN  INT32_MIN
-+#define INT_FAST32_MIN  INT32_MIN
-+
-+#define INT_FAST16_MAX  INT32_MAX
-+#define INT_FAST32_MAX  INT32_MAX
-+
-+#define UINT_FAST16_MAX UINT32_MAX
-+#define UINT_FAST32_MAX UINT32_MAX
-+
-+#define INTPTR_MIN      INT32_MIN
-+#define INTPTR_MAX      INT32_MAX
-+#define UINTPTR_MAX     UINT32_MAX
-+#define PTRDIFF_MIN     INT32_MIN
-+#define PTRDIFF_MAX     INT32_MAX
-+#define SIZE_MAX        UINT32_MAX
-diff --git a/arch/riscv32/bits/syscall.h.in b/arch/riscv32/bits/syscall.h.in
-new file mode 100644
-index 00000000..3c81c107
---- /dev/null
-+++ b/arch/riscv32/bits/syscall.h.in
-@@ -0,0 +1,278 @@
-+#define __NR_io_setup 0
-+#define __NR_io_destroy 1
-+#define __NR_io_submit 2
-+#define __NR_io_cancel 3
-+#define __NR_io_getevents 4
-+#define __NR_setxattr 5
-+#define __NR_lsetxattr 6
-+#define __NR_fsetxattr 7
-+#define __NR_getxattr 8
-+#define __NR_lgetxattr 9
-+#define __NR_fgetxattr 10
-+#define __NR_listxattr 11
-+#define __NR_llistxattr 12
-+#define __NR_flistxattr 13
-+#define __NR_removexattr 14
-+#define __NR_lremovexattr 15
-+#define __NR_fremovexattr 16
-+#define __NR_getcwd 17
-+#define __NR_lookup_dcookie 18
-+#define __NR_eventfd2 19
-+#define __NR_epoll_create1 20
-+#define __NR_epoll_ctl 21
-+#define __NR_epoll_pwait 22
-+#define __NR_dup 23
-+#define __NR_dup3 24
-+#define __NR_fcntl 25
-+#define __NR_inotify_init1 26
-+#define __NR_inotify_add_watch 27
-+#define __NR_inotify_rm_watch 28
-+#define __NR_ioctl 29
-+#define __NR_ioprio_set 30
-+#define __NR_ioprio_get 31
-+#define __NR_flock 32
-+#define __NR_mknodat 33
-+#define __NR_mkdirat 34
-+#define __NR_unlinkat 35
-+#define __NR_symlinkat 36
-+#define __NR_linkat 37
-+#define __NR_renameat 38
-+#define __NR_umount2 39
-+#define __NR_mount 40
-+#define __NR_pivot_root 41
-+#define __NR_nfsservctl 42
-+#define __NR_statfs 43
-+#define __NR_fstatfs 44
-+#define __NR_truncate 45
-+#define __NR_ftruncate 46
-+#define __NR_fallocate 47
-+#define __NR_faccessat 48
-+#define __NR_chdir 49
-+#define __NR_fchdir 50
-+#define __NR_chroot 51
-+#define __NR_fchmod 52
-+#define __NR_fchmodat 53
-+#define __NR_fchownat 54
-+#define __NR_fchown 55
-+#define __NR_openat 56
-+#define __NR_close 57
-+#define __NR_vhangup 58
-+#define __NR_pipe2 59
-+#define __NR_quotactl 60
-+#define __NR_getdents64 61
-+#define __NR_lseek 62
-+#define __NR_read 63
-+#define __NR_write 64
-+#define __NR_readv 65
-+#define __NR_writev 66
-+#define __NR_pread64 67
-+#define __NR_pwrite64 68
-+#define __NR_preadv 69
-+#define __NR_pwritev 70
-+#define __NR_sendfile 71
-+#define __NR_pselect6 72
-+#define __NR_ppoll 73
-+#define __NR_signalfd4 74
-+#define __NR_vmsplice 75
-+#define __NR_splice 76
-+#define __NR_tee 77
-+#define __NR_readlinkat 78
-+#define __NR_fstatat 79
-+#define __NR_fstat 80
-+#define __NR_sync 81
-+#define __NR_fsync 82
-+#define __NR_fdatasync 83
-+#define __NR_sync_file_range 84
-+#define __NR_timerfd_create 85
-+#define __NR_timerfd_settime 86
-+#define __NR_timerfd_gettime 87
-+#define __NR_utimensat 88
-+#define __NR_acct 89
-+#define __NR_capget 90
-+#define __NR_capset 91
-+#define __NR_personality 92
-+#define __NR_exit 93
-+#define __NR_exit_group 94
-+#define __NR_waitid 95
-+#define __NR_set_tid_address 96
-+#define __NR_unshare 97
-+#define __NR_futex 98
-+#define __NR_set_robust_list 99
-+#define __NR_get_robust_list 100
-+#define __NR_nanosleep 101
-+#define __NR_getitimer 102
-+#define __NR_setitimer 103
-+#define __NR_kexec_load 104
-+#define __NR_init_module 105
-+#define __NR_delete_module 106
-+#define __NR_timer_create 107
-+#define __NR_timer_gettime 108
-+#define __NR_timer_getoverrun 109
-+#define __NR_timer_settime 110
-+#define __NR_timer_delete 111
-+#define __NR_clock_settime 112
-+#define __NR_clock_gettime 113
-+#define __NR_clock_getres 114
-+#define __NR_clock_nanosleep 115
-+#define __NR_syslog 116
-+#define __NR_ptrace 117
-+#define __NR_sched_setparam 118
-+#define __NR_sched_setscheduler 119
-+#define __NR_sched_getscheduler 120
-+#define __NR_sched_getparam 121
-+#define __NR_sched_setaffinity 122
-+#define __NR_sched_getaffinity 123
-+#define __NR_sched_yield 124
-+#define __NR_sched_get_priority_max 125
-+#define __NR_sched_get_priority_min 126
-+#define __NR_sched_rr_get_interval 127
-+#define __NR_restart_syscall 128
-+#define __NR_kill 129
-+#define __NR_tkill 130
-+#define __NR_tgkill 131
-+#define __NR_sigaltstack 132
-+#define __NR_rt_sigsuspend 133
-+#define __NR_rt_sigaction 134
-+#define __NR_rt_sigprocmask 135
-+#define __NR_rt_sigpending 136
-+#define __NR_rt_sigtimedwait 137
-+#define __NR_rt_sigqueueinfo 138
-+#define __NR_rt_sigreturn 139
-+#define __NR_setpriority 140
-+#define __NR_getpriority 141
-+#define __NR_reboot 142
-+#define __NR_setregid 143
-+#define __NR_setgid 144
-+#define __NR_setreuid 145
-+#define __NR_setuid 146
-+#define __NR_setresuid 147
-+#define __NR_getresuid 148
-+#define __NR_setresgid 149
-+#define __NR_getresgid 150
-+#define __NR_setfsuid 151
-+#define __NR_setfsgid 152
-+#define __NR_times 153
-+#define __NR_setpgid 154
-+#define __NR_getpgid 155
-+#define __NR_getsid 156
-+#define __NR_setsid 157
-+#define __NR_getgroups 158
-+#define __NR_setgroups 159
-+#define __NR_uname 160
-+#define __NR_sethostname 161
-+#define __NR_setdomainname 162
-+#define __NR_getrlimit 163
-+#define __NR_setrlimit 164
-+#define __NR_getrusage 165
-+#define __NR_umask 166
-+#define __NR_prctl 167
-+#define __NR_getcpu 168
-+#define __NR_gettimeofday 169
-+#define __NR_settimeofday 170
-+#define __NR_adjtimex 171
-+#define __NR_getpid 172
-+#define __NR_getppid 173
-+#define __NR_getuid 174
-+#define __NR_geteuid 175
-+#define __NR_getgid 176
-+#define __NR_getegid 177
-+#define __NR_gettid 178
-+#define __NR_sysinfo 179
-+#define __NR_mq_open 180
-+#define __NR_mq_unlink 181
-+#define __NR_mq_timedsend 182
-+#define __NR_mq_timedreceive 183
-+#define __NR_mq_notify 184
-+#define __NR_mq_getsetattr 185
-+#define __NR_msgget 186
-+#define __NR_msgctl 187
-+#define __NR_msgrcv 188
-+#define __NR_msgsnd 189
-+#define __NR_semget 190
-+#define __NR_semctl 191
-+#define __NR_semtimedop 192
-+#define __NR_semop 193
-+#define __NR_shmget 194
-+#define __NR_shmctl 195
-+#define __NR_shmat 196
-+#define __NR_shmdt 197
-+#define __NR_socket 198
-+#define __NR_socketpair 199
-+#define __NR_bind 200
-+#define __NR_listen 201
-+#define __NR_accept 202
-+#define __NR_connect 203
-+#define __NR_getsockname 204
-+#define __NR_getpeername 205
-+#define __NR_sendto 206
-+#define __NR_recvfrom 207
-+#define __NR_setsockopt 208
-+#define __NR_getsockopt 209
-+#define __NR_shutdown 210
-+#define __NR_sendmsg 211
-+#define __NR_recvmsg 212
-+#define __NR_readahead 213
-+#define __NR_brk 214
-+#define __NR_munmap 215
-+#define __NR_mremap 216
-+#define __NR_add_key 217
-+#define __NR_request_key 218
-+#define __NR_keyctl 219
-+#define __NR_clone 220
-+#define __NR_execve 221
-+#define __NR_mmap 222
-+#define __NR_fadvise64 223
-+#define __NR_swapon 224
-+#define __NR_swapoff 225
-+#define __NR_mprotect 226
-+#define __NR_msync 227
-+#define __NR_mlock 228
-+#define __NR_munlock 229
-+#define __NR_mlockall 230
-+#define __NR_munlockall 231
-+#define __NR_mincore 232
-+#define __NR_madvise 233
-+#define __NR_remap_file_pages 234
-+#define __NR_mbind 235
-+#define __NR_get_mempolicy 236
-+#define __NR_set_mempolicy 237
-+#define __NR_migrate_pages 238
-+#define __NR_move_pages 239
-+#define __NR_rt_tgsigqueueinfo 240
-+#define __NR_perf_event_open 241
-+#define __NR_accept4 242
-+#define __NR_recvmmsg 243
-+#define __NR_arch_specific_syscall 244
-+#define __NR_wait4 260
-+#define __NR_prlimit64 261
-+#define __NR_fanotify_init 262
-+#define __NR_fanotify_mark 263
-+#define __NR_name_to_handle_at 264
-+#define __NR_open_by_handle_at 265
-+#define __NR_clock_adjtime 266
-+#define __NR_syncfs 267
-+#define __NR_setns 268
-+#define __NR_sendmmsg 269
-+#define __NR_process_vm_readv 270
-+#define __NR_process_vm_writev 271
-+#define __NR_kcmp 272
-+#define __NR_finit_module 273
-+#define __NR_sched_setattr 274
-+#define __NR_sched_getattr 275
-+#define __NR_renameat2 276
-+#define __NR_seccomp 277
-+#define __NR_getrandom 278
-+#define __NR_memfd_create 279
-+#define __NR_bpf 280
-+#define __NR_execveat 281
-+#define __NR_userfaultfd 282
-+#define __NR_membarrier 283
-+#define __NR_mlock2 284
-+#define __NR_copy_file_range 285
-+#define __NR_preadv2 286
-+#define __NR_pwritev2 287
-+#define __NR_pkey_mprotect 288
-+#define __NR_pkey_alloc 289
-+#define __NR_pkey_free 290
-+#define __NR_sysriscv __NR_arch_specific_syscall
-+
-diff --git a/arch/riscv32/bits/user.h b/arch/riscv32/bits/user.h
-new file mode 100644
-index 00000000..bd0f0fc7
---- /dev/null
-+++ b/arch/riscv32/bits/user.h
-@@ -0,0 +1,43 @@
-+struct user_regs_struct {
-+      unsigned long pc;
-+      unsigned long ra;
-+      unsigned long sp;
-+      unsigned long gp;
-+      unsigned long tp;
-+      unsigned long t0;
-+      unsigned long t1;
-+      unsigned long t2;
-+      unsigned long s0;
-+      unsigned long s1;
-+      unsigned long a0;
-+      unsigned long a1;
-+      unsigned long a2;
-+      unsigned long a3;
-+      unsigned long a4;
-+      unsigned long a5;
-+      unsigned long a6;
-+      unsigned long a7;
-+      unsigned long s2;
-+      unsigned long s3;
-+      unsigned long s4;
-+      unsigned long s5;
-+      unsigned long s6;
-+      unsigned long s7;
-+      unsigned long s8;
-+      unsigned long s9;
-+      unsigned long s10;
-+      unsigned long s11;
-+      unsigned long t3;
-+      unsigned long t4;
-+      unsigned long t5;
-+      unsigned long t6;
-+};
-+
-+struct user_fpregs_struct {
-+      double f[32];
-+      unsigned int fcsr;
-+};
-+
-+#define ELF_NGREG 32
-+typedef unsigned long elf_greg_t, elf_gregset_t[ELF_NGREG];
-+typedef struct user_fpregs_struct elf_fpregset_t;
-diff --git a/arch/riscv32/crt_arch.h b/arch/riscv32/crt_arch.h
-new file mode 100644
-index 00000000..65187e19
---- /dev/null
-+++ b/arch/riscv32/crt_arch.h
-@@ -0,0 +1,18 @@
-+__asm__(
-+".text\n"
-+".global " START "\n"
-+".type " START ",%function\n"
-+START ":\n"
-+".weak __global_pointer$\n"
-+".hidden __global_pointer$\n\t"
-+".option push\n"
-+".option norelax\n\t"
-+"lla gp, __global_pointer$\n"
-+".option pop\n\t"
-+"mv a0, sp\n"
-+".weak _DYNAMIC\n"
-+".hidden _DYNAMIC\n\t"
-+"lla a1, _DYNAMIC\n\t"
-+"andi sp, sp, -16\n\t"
-+"jal " START "_c"
-+);
-diff --git a/arch/riscv32/pthread_arch.h b/arch/riscv32/pthread_arch.h
-new file mode 100644
-index 00000000..feffaa47
---- /dev/null
-+++ b/arch/riscv32/pthread_arch.h
-@@ -0,0 +1,12 @@
-+static inline struct pthread *__pthread_self()
-+{
-+      char *tp;
-+      __asm__ __volatile__("mv %0, tp" : "=r"(tp));
-+      return (void *)(tp - sizeof(struct pthread));
-+}
-+
-+#define TLS_ABOVE_TP
-+#define GAP_ABOVE_TP 0
-+#define TP_ADJ(p) ((char *)p + sizeof(struct pthread))
-+
-+#define MC_PC gregs[0]
-diff --git a/arch/riscv32/reloc.h b/arch/riscv32/reloc.h
-new file mode 100644
-index 00000000..d057bbee
---- /dev/null
-+++ b/arch/riscv32/reloc.h
-@@ -0,0 +1,27 @@
-+#if defined __riscv_float_abi_soft
-+#define RISCV_FP_SUFFIX "-sf"
-+#elif defined __riscv_float_abi_single
-+#define RISCV_FP_SUFFIX "-sp"
-+#elif defined __riscv_float_abi_double
-+#define RISCV_FP_SUFFIX ""
-+#endif
-+
-+#define RISCV_LDSO_HELPER(x) "riscv" #x
-+#define RISCV_LDSO(x) RISCV_LDSO_HELPER(x)
-+
-+#define LDSO_ARCH RISCV_LDSO(__riscv_xlen) RISCV_FP_SUFFIX
-+
-+#define NO_LEGACY_INITFINI
-+
-+#define TPOFF_K 0
-+
-+#define REL_SYMBOLIC    R_RISCV_32
-+#define REL_PLT         R_RISCV_JUMP_SLOT
-+#define REL_RELATIVE    R_RISCV_RELATIVE
-+#define REL_COPY        R_RISCV_COPY
-+#define REL_DTPMOD      R_RISCV_TLS_DTPMOD32
-+#define REL_DTPOFF      R_RISCV_TLS_DTPREL32
-+#define REL_TPOFF       R_RISCV_TLS_TPREL32
-+
-+#define CRTJMP(pc,sp) __asm__ __volatile__( \
-+      "mv sp, %1 ; jr %0" : : "r"(pc), "r"(sp) : "memory" )
-diff --git a/arch/riscv32/syscall_arch.h b/arch/riscv32/syscall_arch.h
-new file mode 100644
-index 00000000..bc60d1f6
---- /dev/null
-+++ b/arch/riscv32/syscall_arch.h
-@@ -0,0 +1,78 @@
-+#define __SYSCALL_LL_E(x) \
-+((union { long long ll; long l[2]; }){ .ll = x }).l[0], \
-+((union { long long ll; long l[2]; }){ .ll = x }).l[1]
-+#define __SYSCALL_LL_O(x) 0, __SYSCALL_LL_E((x))
-+
-+#define __asm_syscall(...) \
-+      __asm__ __volatile__ ("scall\n\t" \
-+      : "+r"(a0) : __VA_ARGS__ : "memory"); \
-+      return a0; \
-+
-+static inline long __syscall0(long n)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0");
-+      __asm_syscall("r"(a7))
-+}
-+
-+static inline long __syscall1(long n, long a)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      __asm_syscall("r"(a7), "0"(a0))
-+}
-+
-+static inline long __syscall2(long n, long a, long b)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1))
-+}
-+
-+static inline long __syscall3(long n, long a, long b, long c)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      register long a2 __asm__("a2") = c;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2))
-+}
-+
-+static inline long __syscall4(long n, long a, long b, long c, long d)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      register long a2 __asm__("a2") = c;
-+      register long a3 __asm__("a3") = d;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3))
-+}
-+
-+static inline long __syscall5(long n, long a, long b, long c, long d, long e)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      register long a2 __asm__("a2") = c;
-+      register long a3 __asm__("a3") = d;
-+      register long a4 __asm__("a4") = e;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3), "r"(a4))
-+}
-+
-+static inline long __syscall6(long n, long a, long b, long c, long d, long e, long f)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      register long a2 __asm__("a2") = c;
-+      register long a3 __asm__("a3") = d;
-+      register long a4 __asm__("a4") = e;
-+      register long a5 __asm__("a5") = f;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3), "r"(a4), "r"(a5))
-+}
-+
-+#define VDSO_USEFUL
-+/* We don't have a clock_gettime function.
-+#define VDSO_CGT_SYM "__vdso_clock_gettime"
-+#define VDSO_CGT_VER "LINUX_2.6" */
-diff --git a/arch/riscv64/atomic_arch.h b/arch/riscv64/atomic_arch.h
-new file mode 100644
-index 00000000..018c7fd2
---- /dev/null
-+++ b/arch/riscv64/atomic_arch.h
-@@ -0,0 +1,66 @@
-+#define a_barrier a_barrier
-+static inline void a_barrier()
-+{
-+      __asm__ __volatile__ ("fence rw,rw" : : : "memory");
-+}
-+
-+#define a_ll a_ll
-+static inline int a_ll(volatile int *p)
-+{
-+      int v;
-+      __asm__ __volatile__ ("lr.w %0, %1" : "=&r"(v), "+A"(*p));
-+      return v;
-+}
-+
-+#define a_sc a_sc
-+static inline int a_sc(volatile int *p, int v)
-+{
-+      int r;
-+      __asm__ __volatile__ ("sc.w %0, %2, %1" : "=&r"(r), "+A"(*p) : "r"(v) : "memory");
-+return !r;
-+}
-+
-+#define a_cas a_cas
-+static inline int a_cas(volatile int *p, int t, int s)
-+{
-+      int old, tmp;
-+      __asm__("1:  lr.w    %0, %2      \n"
-+              "    bne     %0, %3, 1f  \n"
-+              "    sc.w    %1, %4, %2  \n"
-+              "    bnez    %1, 1b      \n"
-+              "1:                      \n"
-+              : "=&r"(old), "+r"(tmp), "+A"(*p)
-+              : "r"(t), "r"(s));
-+      return old;
-+}
-+
-+#define a_ll_p a_ll_p
-+static inline void *a_ll_p(volatile void *p)
-+{
-+      void *v;
-+      __asm__ __volatile__ ("lr.d %0, %1" : "=&r"(v), "+A"(*(long *)p));
-+      return v;
-+}
-+
-+#define a_sc_p a_sc_p
-+static inline int a_sc_p(volatile int *p, void *v)
-+{
-+      int r;
-+      __asm__ __volatile__ ("sc.d %0, %2, %1" : "=&r"(r), "+A"(*(long *)p) : "r"(v) : "memory");
-+      return !r;
-+}
-+
-+#define a_cas_p a_cas_p
-+static inline void *a_cas_p(volatile void *p, void *t, void *s)
-+{
-+      void *old;
-+      int tmp;
-+      __asm__("1:  lr.d    %0, %2      \n"
-+              "    bne     %0, %3, 1f  \n"
-+              "    sc.d    %1, %4, %2  \n"
-+              "    bnez    %1, 1b      \n"
-+              "1:                      \n"
-+              : "=&r"(old), "+r"(tmp), "+A"(*(long *)p)
-+              : "r"(t), "r"(s));
-+      return old;
-+}
-diff --git a/arch/riscv64/bits/alltypes.h.in b/arch/riscv64/bits/alltypes.h.in
-new file mode 100644
-index 00000000..ae9ba41d
---- /dev/null
-+++ b/arch/riscv64/bits/alltypes.h.in
-@@ -0,0 +1,29 @@
-+#define _Addr long
-+#define _Int64 long
-+#define _Reg long
-+
-+TYPEDEF __builtin_va_list va_list;
-+TYPEDEF __builtin_va_list __isoc_va_list;
-+
-+#ifndef __cplusplus
-+TYPEDEF int wchar_t;
-+#endif
-+
-+TYPEDEF int blksize_t;
-+TYPEDEF unsigned int nlink_t;
-+
-+TYPEDEF float float_t;
-+TYPEDEF double double_t;
-+
-+TYPEDEF struct { long long __ll; long double __ld; } max_align_t;
-+
-+TYPEDEF long time_t;
-+TYPEDEF long suseconds_t;
-+
-+TYPEDEF struct { union { int __i[14]; volatile int __vi[14]; unsigned long __s[7]; } __u; } pthread_attr_t;
-+TYPEDEF struct { union { int __i[10]; volatile int __vi[10]; volatile void *volatile __p[5]; } __u; } pthread_mutex_t;
-+TYPEDEF struct { union { int __i[10]; volatile int __vi[10]; volatile void *volatile __p[5]; } __u; } mtx_t;
-+TYPEDEF struct { union { int __i[12]; volatile int __vi[12]; void *__p[6]; } __u; } pthread_cond_t;
-+TYPEDEF struct { union { int __i[12]; volatile int __vi[12]; void *__p[6]; } __u; } cnd_t;
-+TYPEDEF struct { union { int __i[14]; volatile int __vi[14]; void *__p[7]; } __u; } pthread_rwlock_t;
-+TYPEDEF struct { union { int __i[8]; volatile int __vi[8]; void *__p[4]; } __u; } pthread_barrier_t;
-diff --git a/arch/riscv64/bits/endian.h b/arch/riscv64/bits/endian.h
-new file mode 100644
-index 00000000..7df0e02a
---- /dev/null
-+++ b/arch/riscv64/bits/endian.h
-@@ -0,0 +1,5 @@
-+#if __RISCVEB__
-+#define __BYTE_ORDER __BIG_ENDIAN
-+#else
-+#define __BYTE_ORDER __LITTLE_ENDIAN
-+#endif
-diff --git a/arch/riscv64/bits/fcntl.h b/arch/riscv64/bits/fcntl.h
-new file mode 100644
-index 00000000..92787976
---- /dev/null
-+++ b/arch/riscv64/bits/fcntl.h
-@@ -0,0 +1,38 @@
-+#define O_CREAT        0100
-+#define O_EXCL         0200
-+#define O_NOCTTY       0400
-+#define O_TRUNC       01000
-+#define O_APPEND      02000
-+#define O_NONBLOCK    04000
-+#define O_DSYNC      010000
-+#define O_SYNC     04010000
-+#define O_RSYNC    04010000
-+#define O_DIRECTORY  040000
-+#define O_NOFOLLOW  0100000
-+#define O_CLOEXEC  02000000
-+
-+#define O_ASYNC      020000
-+#define O_DIRECT    0200000
-+#define O_LARGEFILE 0400000
-+#define O_NOATIME  01000000
-+#define O_PATH    010000000
-+#define O_TMPFILE 020040000
-+#define O_NDELAY O_NONBLOCK
-+
-+#define F_DUPFD  0
-+#define F_GETFD  1
-+#define F_SETFD  2
-+#define F_GETFL  3
-+#define F_SETFL  4
-+#define F_GETLK  5
-+#define F_SETLK  6
-+#define F_SETLKW 7
-+#define F_SETOWN 8
-+#define F_GETOWN 9
-+#define F_SETSIG 10
-+#define F_GETSIG 11
-+
-+#define F_SETOWN_EX 15
-+#define F_GETOWN_EX 16
-+
-+#define F_GETOWNER_UIDS 17
-diff --git a/arch/riscv64/bits/fenv.h b/arch/riscv64/bits/fenv.h
-new file mode 100644
-index 00000000..806ec40f
---- /dev/null
-+++ b/arch/riscv64/bits/fenv.h
-@@ -0,0 +1,17 @@
-+#define FE_INVALID      16
-+#define FE_DIVBYZERO    8
-+#define FE_OVERFLOW     4
-+#define FE_UNDERFLOW    2
-+#define FE_INEXACT      1
-+
-+#define FE_ALL_EXCEPT   31
-+
-+#define FE_TONEAREST    0
-+#define FE_DOWNWARD     2
-+#define FE_UPWARD       3
-+#define FE_TOWARDZERO   1
-+
-+typedef unsigned int fexcept_t;
-+typedef unsigned int fenv_t;
-+
-+#define FE_DFL_ENV      ((const fenv_t *) -1)
-diff --git a/arch/riscv64/bits/float.h b/arch/riscv64/bits/float.h
-new file mode 100644
-index 00000000..719c7908
---- /dev/null
-+++ b/arch/riscv64/bits/float.h
-@@ -0,0 +1,16 @@
-+#define FLT_EVAL_METHOD 0
-+
-+#define LDBL_TRUE_MIN 6.47517511943802511092443895822764655e-4966L
-+#define LDBL_MIN 3.36210314311209350626267781732175260e-4932L
-+#define LDBL_MAX 1.18973149535723176508575932662800702e+4932L
-+#define LDBL_EPSILON 1.92592994438723585305597794258492732e-34L
-+
-+#define LDBL_MANT_DIG 113
-+#define LDBL_MIN_EXP (-16381)
-+#define LDBL_MAX_EXP 16384
-+
-+#define LDBL_DIG 33
-+#define LDBL_MIN_10_EXP (-4931)
-+#define LDBL_MAX_10_EXP 4932
-+
-+#define DECIMAL_DIG 36
-diff --git a/arch/riscv64/bits/ipc.h b/arch/riscv64/bits/ipc.h
-new file mode 100644
-index 00000000..6f3328a8
---- /dev/null
-+++ b/arch/riscv64/bits/ipc.h
-@@ -0,0 +1,14 @@
-+struct ipc_perm {
-+      key_t __ipc_perm_key;
-+      uid_t uid;
-+      gid_t gid;
-+      uid_t cuid;
-+      gid_t cgid;
-+      mode_t mode;
-+      unsigned short __ipc_perm_seq;
-+
-+      unsigned long __pad1;
-+      unsigned long __pad2;
-+};
-+
-+#define IPC_64 0
-diff --git a/arch/riscv64/bits/limits.h b/arch/riscv64/bits/limits.h
-new file mode 100644
-index 00000000..0226588c
---- /dev/null
-+++ b/arch/riscv64/bits/limits.h
-@@ -0,0 +1,7 @@
-+#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
-+ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-+#define LONG_BIT 64
-+#endif
-+
-+#define LONG_MAX  0x7fffffffffffffffL
-+#define LLONG_MAX  0x7fffffffffffffffLL
-diff --git a/arch/riscv64/bits/mman.h b/arch/riscv64/bits/mman.h
-new file mode 100644
-index 00000000..36950573
---- /dev/null
-+++ b/arch/riscv64/bits/mman.h
-@@ -0,0 +1 @@
-+#define MAP_32BIT       0x40
-diff --git a/arch/riscv64/bits/msg.h b/arch/riscv64/bits/msg.h
-new file mode 100644
-index 00000000..641e1703
---- /dev/null
-+++ b/arch/riscv64/bits/msg.h
-@@ -0,0 +1,13 @@
-+struct msqid_ds {
-+      struct ipc_perm msg_perm;
-+      time_t msg_stime;
-+      time_t msg_rtime;
-+      time_t msg_ctime;
-+      unsigned long msg_cbytes;
-+      msgqnum_t msg_qnum;
-+      msglen_t msg_qbytes;
-+      pid_t msg_lspid;
-+      pid_t msg_lrpid;
-+      unsigned long __pad1;
-+      unsigned long __pad2;
-+};
-diff --git a/arch/riscv64/bits/posix.h b/arch/riscv64/bits/posix.h
-new file mode 100644
-index 00000000..8068ce98
---- /dev/null
-+++ b/arch/riscv64/bits/posix.h
-@@ -0,0 +1,2 @@
-+#define _POSIX_V6_LP64_OFF64 1
-+#define _POSIX_V7_LP64_OFF64 1
-diff --git a/arch/riscv64/bits/reg.h b/arch/riscv64/bits/reg.h
-new file mode 100644
-index 00000000..c800788c
---- /dev/null
-+++ b/arch/riscv64/bits/reg.h
-@@ -0,0 +1,8 @@
-+#undef __WORDSIZE
-+#define __WORDSIZE 64
-+#define REG_PC 0
-+#define REG_RA 1
-+#define REG_SP 2
-+#define REG_TP 4
-+#define REG_S0 8
-+#define REG_A0 10
-diff --git a/arch/riscv64/bits/sem.h b/arch/riscv64/bits/sem.h
-new file mode 100644
-index 00000000..5f93c12d
---- /dev/null
-+++ b/arch/riscv64/bits/sem.h
-@@ -0,0 +1,9 @@
-+struct semid_ds {
-+      struct ipc_perm sem_perm;
-+      time_t sem_otime;
-+      time_t sem_ctime;
-+      unsigned short sem_nsems;
-+      char __sem_nsems_pad[sizeof(time_t)-sizeof(short)];
-+      time_t __unused3;
-+      time_t __unused4;
-+};
-diff --git a/arch/riscv64/bits/setjmp.h b/arch/riscv64/bits/setjmp.h
-new file mode 100644
-index 00000000..b6cdc8e8
---- /dev/null
-+++ b/arch/riscv64/bits/setjmp.h
-@@ -0,0 +1 @@
-+typedef unsigned long __jmp_buf[28];
-diff --git a/arch/riscv64/bits/shm.h b/arch/riscv64/bits/shm.h
-new file mode 100644
-index 00000000..f4b87126
---- /dev/null
-+++ b/arch/riscv64/bits/shm.h
-@@ -0,0 +1,26 @@
-+#define SHMLBA 4096
-+
-+struct shmid_ds
-+{
-+      struct ipc_perm shm_perm;
-+      size_t shm_segsz;
-+      time_t shm_atime;
-+      time_t shm_dtime;
-+      time_t shm_ctime;
-+      pid_t shm_cpid;
-+      pid_t shm_lpid;
-+      unsigned long shm_nattch;
-+      unsigned long __pad1;
-+      unsigned long __pad2;
-+};
-+
-+struct shminfo {
-+      unsigned long shmmax, shmmin, shmmni, shmseg, shmall, __unused[4];
-+};
-+
-+struct shm_info {
-+      int __used_ids;
-+      unsigned long shm_tot, shm_rss, shm_swp;
-+      unsigned long __swap_attempts, __swap_successes;
-+};
-+
-diff --git a/arch/riscv64/bits/signal.h b/arch/riscv64/bits/signal.h
-new file mode 100644
-index 00000000..8b992cc8
---- /dev/null
-+++ b/arch/riscv64/bits/signal.h
-@@ -0,0 +1,113 @@
-+#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
-+ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-+
-+#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-+# define MINSIGSTKSZ 2048
-+# define SIGSTKSZ 8192
-+#endif
-+
-+/* gregs[0] holds the program counter. */
-+
-+#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-+typedef unsigned long greg_t;
-+typedef unsigned long gregset_t[32];
-+
-+struct __riscv_f_ext_state {
-+      unsigned int f[32];
-+      unsigned int fcsr;
-+};
-+
-+struct __riscv_d_ext_state {
-+      unsigned long long f[32];
-+      unsigned int fcsr;
-+};
-+
-+struct __riscv_q_ext_state {
-+      unsigned long long f[64] __attribute__((aligned(16)));
-+      unsigned int fcsr;
-+      unsigned int reserved[3];
-+};
-+
-+union __riscv_fp_state {
-+      struct __riscv_f_ext_state f;
-+      struct __riscv_d_ext_state d;
-+      struct __riscv_q_ext_state q;
-+};
-+
-+typedef union __riscv_fp_state fpregset_t;
-+
-+typedef struct sigcontext {
-+      gregset_t gregs;
-+      fpregset_t fpregs;
-+} mcontext_t;
-+
-+#else
-+typedef struct {
-+      unsigned long gregs[32];
-+      unsigned long long fpregs[66];
-+} mcontext_t;
-+#endif
-+
-+struct sigaltstack {
-+      void *ss_sp;
-+      int ss_flags;
-+      size_t ss_size;
-+};
-+
-+typedef struct __ucontext
-+{
-+      unsigned long uc_flags;
-+      struct __ucontext *uc_link;
-+      stack_t uc_stack;
-+      sigset_t uc_sigmask;
-+      char __unused[1024 / 8 - sizeof(sigset_t)];
-+      mcontext_t uc_mcontext;
-+} ucontext_t;
-+
-+#define SA_NOCLDSTOP 1
-+#define SA_NOCLDWAIT 2
-+#define SA_SIGINFO   4
-+#define SA_ONSTACK   0x08000000
-+#define SA_RESTART   0x10000000
-+#define SA_NODEFER   0x40000000
-+#define SA_RESETHAND 0x80000000
-+#define SA_RESTORER  0x04000000
-+
-+#endif
-+
-+#define SIGHUP     1
-+#define SIGINT     2
-+#define SIGQUIT    3
-+#define SIGILL     4
-+#define SIGTRAP    5
-+#define SIGABRT    6
-+#define SIGIOT     SIGABRT
-+#define SIGBUS     7
-+#define SIGFPE     8
-+#define SIGKILL    9
-+#define SIGUSR1   10
-+#define SIGSEGV   11
-+#define SIGUSR2   12
-+#define SIGPIPE   13
-+#define SIGALRM   14
-+#define SIGTERM   15
-+#define SIGSTKFLT 16
-+#define SIGCHLD   17
-+#define SIGCONT   18
-+#define SIGSTOP   19
-+#define SIGTSTP   20
-+#define SIGTTIN   21
-+#define SIGTTOU   22
-+#define SIGURG    23
-+#define SIGXCPU   24
-+#define SIGXFSZ   25
-+#define SIGVTALRM 26
-+#define SIGPROF   27
-+#define SIGWINCH  28
-+#define SIGIO     29
-+#define SIGPOLL   SIGIO
-+#define SIGPWR    30
-+#define SIGSYS    31
-+#define SIGUNUSED SIGSYS
-+
-+#define _NSIG     65
-diff --git a/arch/riscv64/bits/socket.h b/arch/riscv64/bits/socket.h
-new file mode 100644
-index 00000000..c11677e9
---- /dev/null
-+++ b/arch/riscv64/bits/socket.h
-@@ -0,0 +1,33 @@
-+#include <endian.h>
-+
-+struct msghdr {
-+      void *msg_name;
-+      socklen_t msg_namelen;
-+      struct iovec *msg_iov;
-+#if __BYTE_ORDER == __BIG_ENDIAN
-+      int __pad1, msg_iovlen;
-+#else
-+      int msg_iovlen, __pad1;
-+#endif
-+      void *msg_control;
-+#if __BYTE_ORDER == __BIG_ENDIAN
-+      int __pad2;
-+      socklen_t msg_controllen;
-+#else
-+      socklen_t msg_controllen;
-+      int __pad2;
-+#endif
-+      int msg_flags;
-+};
-+
-+struct cmsghdr {
-+#if __BYTE_ORDER == __BIG_ENDIAN
-+      int __pad1;
-+      socklen_t cmsg_len;
-+#else
-+      socklen_t cmsg_len;
-+      int __pad1;
-+#endif
-+      int cmsg_level;
-+      int cmsg_type;
-+};
-diff --git a/arch/riscv64/bits/stat.h b/arch/riscv64/bits/stat.h
-new file mode 100644
-index 00000000..b7f4221b
---- /dev/null
-+++ b/arch/riscv64/bits/stat.h
-@@ -0,0 +1,18 @@
-+struct stat {
-+      dev_t st_dev;
-+      ino_t st_ino;
-+      mode_t st_mode;
-+      nlink_t st_nlink;
-+      uid_t st_uid;
-+      gid_t st_gid;
-+      dev_t st_rdev;
-+      unsigned long __pad;
-+      off_t st_size;
-+      blksize_t st_blksize;
-+      int __pad2;
-+      blkcnt_t st_blocks;
-+      struct timespec st_atim;
-+      struct timespec st_mtim;
-+      struct timespec st_ctim;
-+      unsigned __unused[2];
-+};
-diff --git a/arch/riscv64/bits/stdint.h b/arch/riscv64/bits/stdint.h
-new file mode 100644
-index 00000000..1bb147f2
---- /dev/null
-+++ b/arch/riscv64/bits/stdint.h
-@@ -0,0 +1,20 @@
-+typedef int32_t int_fast16_t;
-+typedef int32_t int_fast32_t;
-+typedef uint32_t uint_fast16_t;
-+typedef uint32_t uint_fast32_t;
-+
-+#define INT_FAST16_MIN  INT32_MIN
-+#define INT_FAST32_MIN  INT32_MIN
-+
-+#define INT_FAST16_MAX  INT32_MAX
-+#define INT_FAST32_MAX  INT32_MAX
-+
-+#define UINT_FAST16_MAX UINT32_MAX
-+#define UINT_FAST32_MAX UINT32_MAX
-+
-+#define INTPTR_MIN      INT64_MIN
-+#define INTPTR_MAX      INT64_MAX
-+#define UINTPTR_MAX     UINT64_MAX
-+#define PTRDIFF_MIN     INT64_MIN
-+#define PTRDIFF_MAX     INT64_MAX
-+#define SIZE_MAX        UINT64_MAX
-diff --git a/arch/riscv64/bits/syscall.h.in b/arch/riscv64/bits/syscall.h.in
-new file mode 100644
-index 00000000..3c81c107
---- /dev/null
-+++ b/arch/riscv64/bits/syscall.h.in
-@@ -0,0 +1,278 @@
-+#define __NR_io_setup 0
-+#define __NR_io_destroy 1
-+#define __NR_io_submit 2
-+#define __NR_io_cancel 3
-+#define __NR_io_getevents 4
-+#define __NR_setxattr 5
-+#define __NR_lsetxattr 6
-+#define __NR_fsetxattr 7
-+#define __NR_getxattr 8
-+#define __NR_lgetxattr 9
-+#define __NR_fgetxattr 10
-+#define __NR_listxattr 11
-+#define __NR_llistxattr 12
-+#define __NR_flistxattr 13
-+#define __NR_removexattr 14
-+#define __NR_lremovexattr 15
-+#define __NR_fremovexattr 16
-+#define __NR_getcwd 17
-+#define __NR_lookup_dcookie 18
-+#define __NR_eventfd2 19
-+#define __NR_epoll_create1 20
-+#define __NR_epoll_ctl 21
-+#define __NR_epoll_pwait 22
-+#define __NR_dup 23
-+#define __NR_dup3 24
-+#define __NR_fcntl 25
-+#define __NR_inotify_init1 26
-+#define __NR_inotify_add_watch 27
-+#define __NR_inotify_rm_watch 28
-+#define __NR_ioctl 29
-+#define __NR_ioprio_set 30
-+#define __NR_ioprio_get 31
-+#define __NR_flock 32
-+#define __NR_mknodat 33
-+#define __NR_mkdirat 34
-+#define __NR_unlinkat 35
-+#define __NR_symlinkat 36
-+#define __NR_linkat 37
-+#define __NR_renameat 38
-+#define __NR_umount2 39
-+#define __NR_mount 40
-+#define __NR_pivot_root 41
-+#define __NR_nfsservctl 42
-+#define __NR_statfs 43
-+#define __NR_fstatfs 44
-+#define __NR_truncate 45
-+#define __NR_ftruncate 46
-+#define __NR_fallocate 47
-+#define __NR_faccessat 48
-+#define __NR_chdir 49
-+#define __NR_fchdir 50
-+#define __NR_chroot 51
-+#define __NR_fchmod 52
-+#define __NR_fchmodat 53
-+#define __NR_fchownat 54
-+#define __NR_fchown 55
-+#define __NR_openat 56
-+#define __NR_close 57
-+#define __NR_vhangup 58
-+#define __NR_pipe2 59
-+#define __NR_quotactl 60
-+#define __NR_getdents64 61
-+#define __NR_lseek 62
-+#define __NR_read 63
-+#define __NR_write 64
-+#define __NR_readv 65
-+#define __NR_writev 66
-+#define __NR_pread64 67
-+#define __NR_pwrite64 68
-+#define __NR_preadv 69
-+#define __NR_pwritev 70
-+#define __NR_sendfile 71
-+#define __NR_pselect6 72
-+#define __NR_ppoll 73
-+#define __NR_signalfd4 74
-+#define __NR_vmsplice 75
-+#define __NR_splice 76
-+#define __NR_tee 77
-+#define __NR_readlinkat 78
-+#define __NR_fstatat 79
-+#define __NR_fstat 80
-+#define __NR_sync 81
-+#define __NR_fsync 82
-+#define __NR_fdatasync 83
-+#define __NR_sync_file_range 84
-+#define __NR_timerfd_create 85
-+#define __NR_timerfd_settime 86
-+#define __NR_timerfd_gettime 87
-+#define __NR_utimensat 88
-+#define __NR_acct 89
-+#define __NR_capget 90
-+#define __NR_capset 91
-+#define __NR_personality 92
-+#define __NR_exit 93
-+#define __NR_exit_group 94
-+#define __NR_waitid 95
-+#define __NR_set_tid_address 96
-+#define __NR_unshare 97
-+#define __NR_futex 98
-+#define __NR_set_robust_list 99
-+#define __NR_get_robust_list 100
-+#define __NR_nanosleep 101
-+#define __NR_getitimer 102
-+#define __NR_setitimer 103
-+#define __NR_kexec_load 104
-+#define __NR_init_module 105
-+#define __NR_delete_module 106
-+#define __NR_timer_create 107
-+#define __NR_timer_gettime 108
-+#define __NR_timer_getoverrun 109
-+#define __NR_timer_settime 110
-+#define __NR_timer_delete 111
-+#define __NR_clock_settime 112
-+#define __NR_clock_gettime 113
-+#define __NR_clock_getres 114
-+#define __NR_clock_nanosleep 115
-+#define __NR_syslog 116
-+#define __NR_ptrace 117
-+#define __NR_sched_setparam 118
-+#define __NR_sched_setscheduler 119
-+#define __NR_sched_getscheduler 120
-+#define __NR_sched_getparam 121
-+#define __NR_sched_setaffinity 122
-+#define __NR_sched_getaffinity 123
-+#define __NR_sched_yield 124
-+#define __NR_sched_get_priority_max 125
-+#define __NR_sched_get_priority_min 126
-+#define __NR_sched_rr_get_interval 127
-+#define __NR_restart_syscall 128
-+#define __NR_kill 129
-+#define __NR_tkill 130
-+#define __NR_tgkill 131
-+#define __NR_sigaltstack 132
-+#define __NR_rt_sigsuspend 133
-+#define __NR_rt_sigaction 134
-+#define __NR_rt_sigprocmask 135
-+#define __NR_rt_sigpending 136
-+#define __NR_rt_sigtimedwait 137
-+#define __NR_rt_sigqueueinfo 138
-+#define __NR_rt_sigreturn 139
-+#define __NR_setpriority 140
-+#define __NR_getpriority 141
-+#define __NR_reboot 142
-+#define __NR_setregid 143
-+#define __NR_setgid 144
-+#define __NR_setreuid 145
-+#define __NR_setuid 146
-+#define __NR_setresuid 147
-+#define __NR_getresuid 148
-+#define __NR_setresgid 149
-+#define __NR_getresgid 150
-+#define __NR_setfsuid 151
-+#define __NR_setfsgid 152
-+#define __NR_times 153
-+#define __NR_setpgid 154
-+#define __NR_getpgid 155
-+#define __NR_getsid 156
-+#define __NR_setsid 157
-+#define __NR_getgroups 158
-+#define __NR_setgroups 159
-+#define __NR_uname 160
-+#define __NR_sethostname 161
-+#define __NR_setdomainname 162
-+#define __NR_getrlimit 163
-+#define __NR_setrlimit 164
-+#define __NR_getrusage 165
-+#define __NR_umask 166
-+#define __NR_prctl 167
-+#define __NR_getcpu 168
-+#define __NR_gettimeofday 169
-+#define __NR_settimeofday 170
-+#define __NR_adjtimex 171
-+#define __NR_getpid 172
-+#define __NR_getppid 173
-+#define __NR_getuid 174
-+#define __NR_geteuid 175
-+#define __NR_getgid 176
-+#define __NR_getegid 177
-+#define __NR_gettid 178
-+#define __NR_sysinfo 179
-+#define __NR_mq_open 180
-+#define __NR_mq_unlink 181
-+#define __NR_mq_timedsend 182
-+#define __NR_mq_timedreceive 183
-+#define __NR_mq_notify 184
-+#define __NR_mq_getsetattr 185
-+#define __NR_msgget 186
-+#define __NR_msgctl 187
-+#define __NR_msgrcv 188
-+#define __NR_msgsnd 189
-+#define __NR_semget 190
-+#define __NR_semctl 191
-+#define __NR_semtimedop 192
-+#define __NR_semop 193
-+#define __NR_shmget 194
-+#define __NR_shmctl 195
-+#define __NR_shmat 196
-+#define __NR_shmdt 197
-+#define __NR_socket 198
-+#define __NR_socketpair 199
-+#define __NR_bind 200
-+#define __NR_listen 201
-+#define __NR_accept 202
-+#define __NR_connect 203
-+#define __NR_getsockname 204
-+#define __NR_getpeername 205
-+#define __NR_sendto 206
-+#define __NR_recvfrom 207
-+#define __NR_setsockopt 208
-+#define __NR_getsockopt 209
-+#define __NR_shutdown 210
-+#define __NR_sendmsg 211
-+#define __NR_recvmsg 212
-+#define __NR_readahead 213
-+#define __NR_brk 214
-+#define __NR_munmap 215
-+#define __NR_mremap 216
-+#define __NR_add_key 217
-+#define __NR_request_key 218
-+#define __NR_keyctl 219
-+#define __NR_clone 220
-+#define __NR_execve 221
-+#define __NR_mmap 222
-+#define __NR_fadvise64 223
-+#define __NR_swapon 224
-+#define __NR_swapoff 225
-+#define __NR_mprotect 226
-+#define __NR_msync 227
-+#define __NR_mlock 228
-+#define __NR_munlock 229
-+#define __NR_mlockall 230
-+#define __NR_munlockall 231
-+#define __NR_mincore 232
-+#define __NR_madvise 233
-+#define __NR_remap_file_pages 234
-+#define __NR_mbind 235
-+#define __NR_get_mempolicy 236
-+#define __NR_set_mempolicy 237
-+#define __NR_migrate_pages 238
-+#define __NR_move_pages 239
-+#define __NR_rt_tgsigqueueinfo 240
-+#define __NR_perf_event_open 241
-+#define __NR_accept4 242
-+#define __NR_recvmmsg 243
-+#define __NR_arch_specific_syscall 244
-+#define __NR_wait4 260
-+#define __NR_prlimit64 261
-+#define __NR_fanotify_init 262
-+#define __NR_fanotify_mark 263
-+#define __NR_name_to_handle_at 264
-+#define __NR_open_by_handle_at 265
-+#define __NR_clock_adjtime 266
-+#define __NR_syncfs 267
-+#define __NR_setns 268
-+#define __NR_sendmmsg 269
-+#define __NR_process_vm_readv 270
-+#define __NR_process_vm_writev 271
-+#define __NR_kcmp 272
-+#define __NR_finit_module 273
-+#define __NR_sched_setattr 274
-+#define __NR_sched_getattr 275
-+#define __NR_renameat2 276
-+#define __NR_seccomp 277
-+#define __NR_getrandom 278
-+#define __NR_memfd_create 279
-+#define __NR_bpf 280
-+#define __NR_execveat 281
-+#define __NR_userfaultfd 282
-+#define __NR_membarrier 283
-+#define __NR_mlock2 284
-+#define __NR_copy_file_range 285
-+#define __NR_preadv2 286
-+#define __NR_pwritev2 287
-+#define __NR_pkey_mprotect 288
-+#define __NR_pkey_alloc 289
-+#define __NR_pkey_free 290
-+#define __NR_sysriscv __NR_arch_specific_syscall
-+
-diff --git a/arch/riscv64/bits/user.h b/arch/riscv64/bits/user.h
-new file mode 100644
-index 00000000..bd0f0fc7
---- /dev/null
-+++ b/arch/riscv64/bits/user.h
-@@ -0,0 +1,43 @@
-+struct user_regs_struct {
-+      unsigned long pc;
-+      unsigned long ra;
-+      unsigned long sp;
-+      unsigned long gp;
-+      unsigned long tp;
-+      unsigned long t0;
-+      unsigned long t1;
-+      unsigned long t2;
-+      unsigned long s0;
-+      unsigned long s1;
-+      unsigned long a0;
-+      unsigned long a1;
-+      unsigned long a2;
-+      unsigned long a3;
-+      unsigned long a4;
-+      unsigned long a5;
-+      unsigned long a6;
-+      unsigned long a7;
-+      unsigned long s2;
-+      unsigned long s3;
-+      unsigned long s4;
-+      unsigned long s5;
-+      unsigned long s6;
-+      unsigned long s7;
-+      unsigned long s8;
-+      unsigned long s9;
-+      unsigned long s10;
-+      unsigned long s11;
-+      unsigned long t3;
-+      unsigned long t4;
-+      unsigned long t5;
-+      unsigned long t6;
-+};
-+
-+struct user_fpregs_struct {
-+      double f[32];
-+      unsigned int fcsr;
-+};
-+
-+#define ELF_NGREG 32
-+typedef unsigned long elf_greg_t, elf_gregset_t[ELF_NGREG];
-+typedef struct user_fpregs_struct elf_fpregset_t;
-diff --git a/arch/riscv64/crt_arch.h b/arch/riscv64/crt_arch.h
-new file mode 100644
-index 00000000..d0e32a6c
---- /dev/null
-+++ b/arch/riscv64/crt_arch.h
-@@ -0,0 +1,18 @@
-+__asm__(
-+".text\n"
-+".global " START "\n"
-+".type " START ",%function\n"
-+START ":\n"
-+".weak __global_pointer$\n"
-+".hidden __global_pointer$\n"
-+".option push\n"
-+".option norelax\n\t"
-+"lla gp, __global_pointer$\n"
-+".option pop\n\t"
-+"mv a0, sp\n"
-+".weak _DYNAMIC\n"
-+".hidden _DYNAMIC\n\t"
-+"lla a1, _DYNAMIC\n\t"
-+"andi sp, sp, -16\n\t"
-+"jal " START "_c"
-+);
-diff --git a/arch/riscv64/pthread_arch.h b/arch/riscv64/pthread_arch.h
-new file mode 100644
-index 00000000..feffaa47
---- /dev/null
-+++ b/arch/riscv64/pthread_arch.h
-@@ -0,0 +1,12 @@
-+static inline struct pthread *__pthread_self()
-+{
-+      char *tp;
-+      __asm__ __volatile__("mv %0, tp" : "=r"(tp));
-+      return (void *)(tp - sizeof(struct pthread));
-+}
-+
-+#define TLS_ABOVE_TP
-+#define GAP_ABOVE_TP 0
-+#define TP_ADJ(p) ((char *)p + sizeof(struct pthread))
-+
-+#define MC_PC gregs[0]
-diff --git a/arch/riscv64/reloc.h b/arch/riscv64/reloc.h
-new file mode 100644
-index 00000000..8bd90dda
---- /dev/null
-+++ b/arch/riscv64/reloc.h
-@@ -0,0 +1,27 @@
-+#if defined __riscv_float_abi_soft
-+#define RISCV_FP_SUFFIX "-sf"
-+#elif defined __riscv_float_abi_single
-+#define RISCV_FP_SUFFIX "-sp"
-+#elif defined __riscv_float_abi_double
-+#define RISCV_FP_SUFFIX ""
-+#endif
-+
-+#define RISCV_LDSO_HELPER(x) "riscv" #x
-+#define RISCV_LDSO(x) RISCV_LDSO_HELPER(x)
-+
-+#define LDSO_ARCH RISCV_LDSO(__riscv_xlen) RISCV_FP_SUFFIX
-+
-+#define NO_LEGACY_INITFINI
-+
-+#define TPOFF_K 0
-+
-+#define REL_SYMBOLIC    R_RISCV_64
-+#define REL_PLT         R_RISCV_JUMP_SLOT
-+#define REL_RELATIVE    R_RISCV_RELATIVE
-+#define REL_COPY        R_RISCV_COPY
-+#define REL_DTPMOD      R_RISCV_TLS_DTPMOD64
-+#define REL_DTPOFF      R_RISCV_TLS_DTPREL64
-+#define REL_TPOFF       R_RISCV_TLS_TPREL64
-+
-+#define CRTJMP(pc,sp) __asm__ __volatile__( \
-+      "mv sp, %1 ; jr %0" : : "r"(pc), "r"(sp) : "memory" )
-diff --git a/arch/riscv64/syscall_arch.h b/arch/riscv64/syscall_arch.h
-new file mode 100644
-index 00000000..7b6e3fd5
---- /dev/null
-+++ b/arch/riscv64/syscall_arch.h
-@@ -0,0 +1,76 @@
-+#define __SYSCALL_LL_E(x) (x)
-+#define __SYSCALL_LL_O(x) (x)
-+
-+#define __asm_syscall(...) \
-+      __asm__ __volatile__ ("scall\n\t" \
-+      : "+r"(a0) : __VA_ARGS__ : "memory"); \
-+      return a0; \
-+
-+static inline long __syscall0(long n)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0");
-+      __asm_syscall("r"(a7))
-+}
-+
-+static inline long __syscall1(long n, long a)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      __asm_syscall("r"(a7), "0"(a0))
-+}
-+
-+static inline long __syscall2(long n, long a, long b)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1))
-+}
-+
-+static inline long __syscall3(long n, long a, long b, long c)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      register long a2 __asm__("a2") = c;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2))
-+}
-+
-+static inline long __syscall4(long n, long a, long b, long c, long d)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      register long a2 __asm__("a2") = c;
-+      register long a3 __asm__("a3") = d;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3))
-+}
-+
-+static inline long __syscall5(long n, long a, long b, long c, long d, long e)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      register long a2 __asm__("a2") = c;
-+      register long a3 __asm__("a3") = d;
-+      register long a4 __asm__("a4") = e;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3), "r"(a4))
-+}
-+
-+static inline long __syscall6(long n, long a, long b, long c, long d, long e, long f)
-+{
-+      register long a7 __asm__("a7") = n;
-+      register long a0 __asm__("a0") = a;
-+      register long a1 __asm__("a1") = b;
-+      register long a2 __asm__("a2") = c;
-+      register long a3 __asm__("a3") = d;
-+      register long a4 __asm__("a4") = e;
-+      register long a5 __asm__("a5") = f;
-+      __asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3), "r"(a4), "r"(a5))
-+}
-+
-+#define VDSO_USEFUL
-+/* We don't have a clock_gettime function.
-+#define VDSO_CGT_SYM "__vdso_clock_gettime"
-+#define VDSO_CGT_VER "LINUX_2.6" */
-diff --git a/configure b/configure
-index 997e6652..4d3d8b44 100755
---- a/configure
-+++ b/configure
-@@ -322,6 +322,8 @@ microblaze*) ARCH=microblaze ;;
- or1k*) ARCH=or1k ;;
- powerpc64*) ARCH=powerpc64 ;;
- powerpc*) ARCH=powerpc ;;
-+riscv64*) ARCH=riscv64 ;;
-+riscv*) ARCH=riscv32 ;;
- sh[1-9bel-]*|sh|superh*) ARCH=sh ;;
- s390x*) ARCH=s390x ;;
- unknown) fail "$0: unable to detect target arch; try $0 --target=..." ;;
-@@ -640,6 +642,11 @@ trycppif __LITTLE_ENDIAN__ "$t" && SUBARCH=${SUBARCH}le
- trycppif _SOFT_FLOAT "$t" && fail "$0: error: soft-float not supported on powerpc64"
- fi
-+if test "$ARCH" = "riscv" || test "$ARCH" = "riscv64" ; then
-+trycppif "RISCVEB || _RISCVEB || __RISCVEB || __RISCVEB__" "$t" && SUBARCH=${SUBARCH}eb
-+trycppif __riscv_soft_float "$t" && SUBARCH=${SUBARCH}-sf
-+fi
-+
- if test "$ARCH" = "sh" ; then
- tryflag CFLAGS_AUTO -Wa,--isa=any
- trycppif __BIG_ENDIAN__ "$t" && SUBARCH=${SUBARCH}eb
-diff --git a/crt/riscv32/crti.s b/crt/riscv32/crti.s
-new file mode 100644
-index 00000000..6916bfd6
---- /dev/null
-+++ b/crt/riscv32/crti.s
-@@ -0,0 +1,11 @@
-+.section .init
-+.global _init
-+.type _init,%function
-+_init:
-+        ret
-+
-+.section .fini
-+.global _fini
-+.type _fini,%function
-+_fini:
-+        ret
-diff --git a/crt/riscv32/crtn.s b/crt/riscv32/crtn.s
-new file mode 100644
-index 00000000..e69de29b
-diff --git a/crt/riscv64/crti.s b/crt/riscv64/crti.s
-new file mode 100644
-index 00000000..8b54a65d
---- /dev/null
-+++ b/crt/riscv64/crti.s
-@@ -0,0 +1,11 @@
-+.section .init
-+.global _init
-+.type _init,%function
-+_init:
-+        ret
-+
-+.section .fini
-+.global _fini
-+.type _fini %function
-+_fini:
-+        ret
-diff --git a/crt/riscv64/crtn.s b/crt/riscv64/crtn.s
-new file mode 100644
-index 00000000..e69de29b
-diff --git a/include/elf.h b/include/elf.h
-index c2297353..ec2e8fd0 100644
---- a/include/elf.h
-+++ b/include/elf.h
-@@ -3164,6 +3164,62 @@ enum
- #define R_BPF_NONE            0
- #define R_BPF_MAP_FD          1
-+#define R_RISCV_NONE            0
-+#define R_RISCV_32              1
-+#define R_RISCV_64              2
-+#define R_RISCV_RELATIVE        3
-+#define R_RISCV_COPY            4
-+#define R_RISCV_JUMP_SLOT       5
-+#define R_RISCV_TLS_DTPMOD32    6
-+#define R_RISCV_TLS_DTPMOD64    7
-+#define R_RISCV_TLS_DTPREL32    8
-+#define R_RISCV_TLS_DTPREL64    9
-+#define R_RISCV_TLS_TPREL32     10
-+#define R_RISCV_TLS_TPREL64     11
-+
-+#define R_RISCV_BRANCH          16
-+#define R_RISCV_JAL             17
-+#define R_RISCV_CALL            18
-+#define R_RISCV_CALL_PLT        19
-+#define R_RISCV_GOT_HI20        20
-+#define R_RISCV_TLS_GOT_HI20    21
-+#define R_RISCV_TLS_GD_HI20     22
-+#define R_RISCV_PCREL_HI20      23
-+#define R_RISCV_PCREL_LO12_I    24
-+#define R_RISCV_PCREL_LO12_S    25
-+#define R_RISCV_HI20            26
-+#define R_RISCV_LO12_I          27
-+#define R_RISCV_LO12_S          28
-+#define R_RISCV_TPREL_HI20      29
-+#define R_RISCV_TPREL_LO12_I    30
-+#define R_RISCV_TPREL_LO12_S    31
-+#define R_RISCV_TPREL_ADD       32
-+#define R_RISCV_ADD8            33
-+#define R_RISCV_ADD16           34
-+#define R_RISCV_ADD32           35
-+#define R_RISCV_ADD64           36
-+#define R_RISCV_SUB8            37
-+#define R_RISCV_SUB16           38
-+#define R_RISCV_SUB32           39
-+#define R_RISCV_SUB64           40
-+#define R_RISCV_GNU_VTINHERIT   41
-+#define R_RISCV_GNU_VTENTRY     42
-+#define R_RISCV_ALIGN           43
-+#define R_RISCV_RVC_BRANCH      44
-+#define R_RISCV_RVC_JUMP        45
-+#define R_RISCV_RVC_LUI         46
-+#define R_RISCV_GPREL_I         47
-+#define R_RISCV_GPREL_S         48
-+#define R_RISCV_TPREL_I         49
-+#define R_RISCV_TPREL_S         50
-+#define R_RISCV_RELAX           51
-+#define R_RISCV_SUB6            52
-+#define R_RISCV_SET6            53
-+#define R_RISCV_SET8            54
-+#define R_RISCV_SET16           55
-+#define R_RISCV_SET32           56
-+#define R_RISCV_32_PCREL        57
-+
- #ifdef __cplusplus
- }
- #endif
-diff --git a/src/fenv/riscv32/fenv-sf.c b/src/fenv/riscv32/fenv-sf.c
-new file mode 100644
-index 00000000..9ff7b792
---- /dev/null
-+++ b/src/fenv/riscv32/fenv-sf.c
-@@ -0,0 +1,3 @@
-+#ifdef __riscv_soft_float
-+#include "../fenv.c"
-+#endif
-diff --git a/src/fenv/riscv32/fenv.S b/src/fenv/riscv32/fenv.S
-new file mode 100644
-index 00000000..a55aa4ab
---- /dev/null
-+++ b/src/fenv/riscv32/fenv.S
-@@ -0,0 +1,53 @@
-+#ifndef __riscv_soft_float
-+
-+.global feclearexcept
-+.type feclearexcept, %function
-+feclearexcept:
-+        csrc fflags, a0
-+        li a0, 0
-+        ret
-+
-+.global feraiseexcept
-+.type feraiseexcept, %function
-+feraiseexcept:
-+        csrs fflags, a0
-+        li a0, 0
-+        ret
-+
-+.global fetestexcept
-+.type fetestexcept, %function
-+fetestexcept:
-+        frflags t0
-+        and a0, t0, a0
-+        ret
-+
-+.global fegetround
-+.type fegetround, %function
-+fegetround:
-+        frrm a0
-+        ret
-+
-+.global __fesetround
-+.type __fesetround, %function
-+__fesetround:
-+        fsrm t0, a0
-+        li a0, 0
-+        ret
-+
-+.global fegetenv
-+.type fegetenv, %function
-+fegetenv:
-+        frcsr t0
-+        sw t0, 0(a0)
-+        li a0, 0
-+        ret
-+
-+.global fesetenv
-+.type fesetenv, %function
-+fesetenv:
-+        lw t1, 0(a0)
-+        fscsr t0, t1
-+        li a0, 0
-+        ret
-+
-+#endif
-diff --git a/src/fenv/riscv64/fenv-sf.c b/src/fenv/riscv64/fenv-sf.c
-new file mode 100644
-index 00000000..9ff7b792
---- /dev/null
-+++ b/src/fenv/riscv64/fenv-sf.c
-@@ -0,0 +1,3 @@
-+#ifdef __riscv_soft_float
-+#include "../fenv.c"
-+#endif
-diff --git a/src/fenv/riscv64/fenv.S b/src/fenv/riscv64/fenv.S
-new file mode 100644
-index 00000000..a55aa4ab
---- /dev/null
-+++ b/src/fenv/riscv64/fenv.S
-@@ -0,0 +1,53 @@
-+#ifndef __riscv_soft_float
-+
-+.global feclearexcept
-+.type feclearexcept, %function
-+feclearexcept:
-+        csrc fflags, a0
-+        li a0, 0
-+        ret
-+
-+.global feraiseexcept
-+.type feraiseexcept, %function
-+feraiseexcept:
-+        csrs fflags, a0
-+        li a0, 0
-+        ret
-+
-+.global fetestexcept
-+.type fetestexcept, %function
-+fetestexcept:
-+        frflags t0
-+        and a0, t0, a0
-+        ret
-+
-+.global fegetround
-+.type fegetround, %function
-+fegetround:
-+        frrm a0
-+        ret
-+
-+.global __fesetround
-+.type __fesetround, %function
-+__fesetround:
-+        fsrm t0, a0
-+        li a0, 0
-+        ret
-+
-+.global fegetenv
-+.type fegetenv, %function
-+fegetenv:
-+        frcsr t0
-+        sw t0, 0(a0)
-+        li a0, 0
-+        ret
-+
-+.global fesetenv
-+.type fesetenv, %function
-+fesetenv:
-+        lw t1, 0(a0)
-+        fscsr t0, t1
-+        li a0, 0
-+        ret
-+
-+#endif
-diff --git a/src/internal/riscv32/syscall.s b/src/internal/riscv32/syscall.s
-new file mode 100644
-index 00000000..a7d125af
---- /dev/null
-+++ b/src/internal/riscv32/syscall.s
-@@ -0,0 +1,15 @@
-+.global __syscall
-+.hidden __syscall
-+.type   __syscall,%function
-+__syscall:
-+        mv t0, a0
-+        mv a0, a1
-+        mv a1, a2
-+        mv a2, a3
-+        mv a3, a4
-+        mv a4, a5
-+        mv a5, a6
-+        mv a6, a7
-+        mv a7, t0
-+        scall
-+        ret
-diff --git a/src/internal/riscv64/syscall.s b/src/internal/riscv64/syscall.s
-new file mode 100644
-index 00000000..a7d125af
---- /dev/null
-+++ b/src/internal/riscv64/syscall.s
-@@ -0,0 +1,15 @@
-+.global __syscall
-+.hidden __syscall
-+.type   __syscall,%function
-+__syscall:
-+        mv t0, a0
-+        mv a0, a1
-+        mv a1, a2
-+        mv a2, a3
-+        mv a3, a4
-+        mv a4, a5
-+        mv a5, a6
-+        mv a6, a7
-+        mv a7, t0
-+        scall
-+        ret
-diff --git a/src/ldso/riscv32/dlsym.s b/src/ldso/riscv32/dlsym.s
-new file mode 100644
-index 00000000..ff9109dc
---- /dev/null
-+++ b/src/ldso/riscv32/dlsym.s
-@@ -0,0 +1,6 @@
-+.global dlsym
-+.hidden __dlsym
-+.type dlsym, %function
-+dlsym:
-+        mv a2, ra
-+        j __dlsym
-diff --git a/src/ldso/riscv64/dlsym.s b/src/ldso/riscv64/dlsym.s
-new file mode 100644
-index 00000000..ff9109dc
---- /dev/null
-+++ b/src/ldso/riscv64/dlsym.s
-@@ -0,0 +1,6 @@
-+.global dlsym
-+.hidden __dlsym
-+.type dlsym, %function
-+dlsym:
-+        mv a2, ra
-+        j __dlsym
-diff --git a/src/math/riscv32/copysign.s b/src/math/riscv32/copysign.s
-new file mode 100644
-index 00000000..81afa8b2
---- /dev/null
-+++ b/src/math/riscv32/copysign.s
-@@ -0,0 +1,5 @@
-+.global copysign
-+.type   copysign, %function
-+copysign:
-+        fsgnj.d fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv32/copysignf.s b/src/math/riscv32/copysignf.s
-new file mode 100644
-index 00000000..fe36f909
---- /dev/null
-+++ b/src/math/riscv32/copysignf.s
-@@ -0,0 +1,5 @@
-+.global copysignf
-+.type   copysignf, %function
-+copysignf:
-+        fsgnj.s fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv32/fabs.s b/src/math/riscv32/fabs.s
-new file mode 100644
-index 00000000..27def33c
---- /dev/null
-+++ b/src/math/riscv32/fabs.s
-@@ -0,0 +1,5 @@
-+.global fabs
-+.type   fabs, %function
-+fabs:
-+        fabs.d fa0, fa0
-+        ret
-diff --git a/src/math/riscv32/fabsf.s b/src/math/riscv32/fabsf.s
-new file mode 100644
-index 00000000..8e0b9d64
---- /dev/null
-+++ b/src/math/riscv32/fabsf.s
-@@ -0,0 +1,5 @@
-+.global fabsf
-+.type   fabsf, %function
-+fabsf:
-+        fabs.s fa0, fa0
-+        ret
-diff --git a/src/math/riscv32/fma.s b/src/math/riscv32/fma.s
-new file mode 100644
-index 00000000..17e1d136
---- /dev/null
-+++ b/src/math/riscv32/fma.s
-@@ -0,0 +1,5 @@
-+.global fma
-+.type   fma, %function
-+fma:
-+        fmadd.d fa0, fa0, fa1, fa2
-+        ret
-diff --git a/src/math/riscv32/fmaf.s b/src/math/riscv32/fmaf.s
-new file mode 100644
-index 00000000..cfe17100
---- /dev/null
-+++ b/src/math/riscv32/fmaf.s
-@@ -0,0 +1,5 @@
-+.global fmaf
-+.type   fmaf, %function
-+fmaf:
-+        fmadd.s fa0, fa0, fa1, fa2
-+        ret
-diff --git a/src/math/riscv32/fmax.s b/src/math/riscv32/fmax.s
-new file mode 100644
-index 00000000..40655d37
---- /dev/null
-+++ b/src/math/riscv32/fmax.s
-@@ -0,0 +1,5 @@
-+.global fmax
-+.type   fmax, %function
-+fmax:
-+        fmax.d fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv32/fmaxf.s b/src/math/riscv32/fmaxf.s
-new file mode 100644
-index 00000000..490b6e91
---- /dev/null
-+++ b/src/math/riscv32/fmaxf.s
-@@ -0,0 +1,5 @@
-+.global fmaxf
-+.type   fmaxf, %function
-+fmaxf:
-+        fmax.s fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv32/fmin.s b/src/math/riscv32/fmin.s
-new file mode 100644
-index 00000000..97f72e08
---- /dev/null
-+++ b/src/math/riscv32/fmin.s
-@@ -0,0 +1,5 @@
-+.global fmin
-+.type   fmin, %function
-+fmin:
-+        fmin.d fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv32/fminf.s b/src/math/riscv32/fminf.s
-new file mode 100644
-index 00000000..4f8e55ee
---- /dev/null
-+++ b/src/math/riscv32/fminf.s
-@@ -0,0 +1,5 @@
-+.global fminf
-+.type   fminf, %function
-+fminf:
-+        fmin.s fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv32/sqrt.s b/src/math/riscv32/sqrt.s
-new file mode 100644
-index 00000000..a4c8b3ea
---- /dev/null
-+++ b/src/math/riscv32/sqrt.s
-@@ -0,0 +1,5 @@
-+.global sqrt
-+.type   sqrt, %function
-+sqrt:
-+        fsqrt.d fa0, fa0
-+        ret
-diff --git a/src/math/riscv32/sqrtf.s b/src/math/riscv32/sqrtf.s
-new file mode 100644
-index 00000000..ff7abcf3
---- /dev/null
-+++ b/src/math/riscv32/sqrtf.s
-@@ -0,0 +1,5 @@
-+.global sqrtf
-+.type   sqrtf, %function
-+sqrtf:
-+        fsqrt.s fa0, fa0
-+        ret
-diff --git a/src/math/riscv64/copysign.s b/src/math/riscv64/copysign.s
-new file mode 100644
-index 00000000..81afa8b2
---- /dev/null
-+++ b/src/math/riscv64/copysign.s
-@@ -0,0 +1,5 @@
-+.global copysign
-+.type   copysign, %function
-+copysign:
-+        fsgnj.d fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv64/copysignf.s b/src/math/riscv64/copysignf.s
-new file mode 100644
-index 00000000..fe36f909
---- /dev/null
-+++ b/src/math/riscv64/copysignf.s
-@@ -0,0 +1,5 @@
-+.global copysignf
-+.type   copysignf, %function
-+copysignf:
-+        fsgnj.s fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv64/fabs.s b/src/math/riscv64/fabs.s
-new file mode 100644
-index 00000000..27def33c
---- /dev/null
-+++ b/src/math/riscv64/fabs.s
-@@ -0,0 +1,5 @@
-+.global fabs
-+.type   fabs, %function
-+fabs:
-+        fabs.d fa0, fa0
-+        ret
-diff --git a/src/math/riscv64/fabsf.s b/src/math/riscv64/fabsf.s
-new file mode 100644
-index 00000000..8e0b9d64
---- /dev/null
-+++ b/src/math/riscv64/fabsf.s
-@@ -0,0 +1,5 @@
-+.global fabsf
-+.type   fabsf, %function
-+fabsf:
-+        fabs.s fa0, fa0
-+        ret
-diff --git a/src/math/riscv64/fma.s b/src/math/riscv64/fma.s
-new file mode 100644
-index 00000000..17e1d136
---- /dev/null
-+++ b/src/math/riscv64/fma.s
-@@ -0,0 +1,5 @@
-+.global fma
-+.type   fma, %function
-+fma:
-+        fmadd.d fa0, fa0, fa1, fa2
-+        ret
-diff --git a/src/math/riscv64/fmaf.s b/src/math/riscv64/fmaf.s
-new file mode 100644
-index 00000000..cfe17100
---- /dev/null
-+++ b/src/math/riscv64/fmaf.s
-@@ -0,0 +1,5 @@
-+.global fmaf
-+.type   fmaf, %function
-+fmaf:
-+        fmadd.s fa0, fa0, fa1, fa2
-+        ret
-diff --git a/src/math/riscv64/fmax.s b/src/math/riscv64/fmax.s
-new file mode 100644
-index 00000000..40655d37
---- /dev/null
-+++ b/src/math/riscv64/fmax.s
-@@ -0,0 +1,5 @@
-+.global fmax
-+.type   fmax, %function
-+fmax:
-+        fmax.d fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv64/fmaxf.s b/src/math/riscv64/fmaxf.s
-new file mode 100644
-index 00000000..490b6e91
---- /dev/null
-+++ b/src/math/riscv64/fmaxf.s
-@@ -0,0 +1,5 @@
-+.global fmaxf
-+.type   fmaxf, %function
-+fmaxf:
-+        fmax.s fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv64/fmin.s b/src/math/riscv64/fmin.s
-new file mode 100644
-index 00000000..97f72e08
---- /dev/null
-+++ b/src/math/riscv64/fmin.s
-@@ -0,0 +1,5 @@
-+.global fmin
-+.type   fmin, %function
-+fmin:
-+        fmin.d fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv64/fminf.s b/src/math/riscv64/fminf.s
-new file mode 100644
-index 00000000..4f8e55ee
---- /dev/null
-+++ b/src/math/riscv64/fminf.s
-@@ -0,0 +1,5 @@
-+.global fminf
-+.type   fminf, %function
-+fminf:
-+        fmin.s fa0, fa0, fa1
-+        ret
-diff --git a/src/math/riscv64/sqrt.s b/src/math/riscv64/sqrt.s
-new file mode 100644
-index 00000000..a4c8b3ea
---- /dev/null
-+++ b/src/math/riscv64/sqrt.s
-@@ -0,0 +1,5 @@
-+.global sqrt
-+.type   sqrt, %function
-+sqrt:
-+        fsqrt.d fa0, fa0
-+        ret
-diff --git a/src/math/riscv64/sqrtf.s b/src/math/riscv64/sqrtf.s
-new file mode 100644
-index 00000000..ff7abcf3
---- /dev/null
-+++ b/src/math/riscv64/sqrtf.s
-@@ -0,0 +1,5 @@
-+.global sqrtf
-+.type   sqrtf, %function
-+sqrtf:
-+        fsqrt.s fa0, fa0
-+        ret
-diff --git a/src/setjmp/riscv32/longjmp.S b/src/setjmp/riscv32/longjmp.S
-new file mode 100644
-index 00000000..fbf2439a
---- /dev/null
-+++ b/src/setjmp/riscv32/longjmp.S
-@@ -0,0 +1,44 @@
-+.global __longjmp
-+.global _longjmp
-+.global longjmp
-+.type __longjmp, %function
-+.type _longjmp,  %function
-+.type longjmp,   %function
-+__longjmp:
-+_longjmp:
-+longjmp:
-+        lw s0,    0(a0)
-+        lw s1,    4(a0)
-+        lw s2,    8(a0)
-+        lw s3,    12(a0)
-+        lw s4,    16(a0)
-+        lw s5,    20(a0)
-+        lw s6,    24(a0)
-+        lw s7,    28(a0)
-+        lw s8,    32(a0)
-+        lw s9,    36(a0)
-+        lw s10,   40(a0)
-+        lw s11,   44(a0)
-+        lw sp,    48(a0)
-+        lw ra,    52(a0)
-+
-+#ifndef __riscv_soft_float
-+        fld fs0,  56(a0)
-+        fld fs1,  64(a0)
-+        fld fs2,  72(a0)
-+        fld fs3,  80(a0)
-+        fld fs3,  88(a0)
-+        fld fs4,  96(a0)
-+        fld fs5,  104(a0)
-+        fld fs6,  112(a0)
-+        fld fs7,  120(a0)
-+        fld fs8,  128(a0)
-+        fld fs9,  136(a0)
-+        fld fs10, 144(a0)
-+        fld fs11, 152(a0)
-+#endif
-+
-+        mv a0, a1
-+        bnez a1, 1f
-+        li a0, 1
-+1:      ret
-diff --git a/src/setjmp/riscv32/setjmp.S b/src/setjmp/riscv32/setjmp.S
-new file mode 100644
-index 00000000..14d5414d
---- /dev/null
-+++ b/src/setjmp/riscv32/setjmp.S
-@@ -0,0 +1,42 @@
-+.global __setjmp
-+.global _setjmp
-+.global setjmp
-+.type __setjmp, %function
-+.type _setjmp,  %function
-+.type setjmp,   %function
-+__setjmp:
-+_setjmp:
-+setjmp:
-+        sw s0,    0(a0)
-+        sw s1,    4(a0)
-+        sw s2,    8(a0)
-+        sw s3,    12(a0)
-+        sw s4,    16(a0)
-+        sw s5,    20(a0)
-+        sw s6,    24(a0)
-+        sw s7,    28(a0)
-+        sw s8,    32(a0)
-+        sw s9,    36(a0)
-+        sw s10,   40(a0)
-+        sw s11,   44(a0)
-+        sw sp,    48(a0)
-+        sw ra,    52(a0)
-+
-+#ifndef __riscv_soft_float
-+        fsd fs0,  56(a0)
-+        fsd fs1,  64(a0)
-+        fsd fs2,  72(a0)
-+        fsd fs3,  80(a0)
-+        fsd fs3,  88(a0)
-+        fsd fs4,  96(a0)
-+        fsd fs5,  104(a0)
-+        fsd fs6,  112(a0)
-+        fsd fs7,  120(a0)
-+        fsd fs8,  128(a0)
-+        fsd fs9,  136(a0)
-+        fsd fs10, 144(a0)
-+        fsd fs11, 152(a0)
-+#endif
-+
-+        li a0, 0
-+        ret
-diff --git a/src/setjmp/riscv64/longjmp.S b/src/setjmp/riscv64/longjmp.S
-new file mode 100644
-index 00000000..d87a1afe
---- /dev/null
-+++ b/src/setjmp/riscv64/longjmp.S
-@@ -0,0 +1,44 @@
-+.global __longjmp
-+.global _longjmp
-+.global longjmp
-+.type __longjmp, %function
-+.type _longjmp,  %function
-+.type longjmp,   %function
-+__longjmp:
-+_longjmp:
-+longjmp:
-+        ld s0,    0(a0)
-+        ld s1,    8(a0)
-+        ld s2,    16(a0)
-+        ld s3,    24(a0)
-+        ld s4,    32(a0)
-+        ld s5,    40(a0)
-+        ld s6,    48(a0)
-+        ld s7,    56(a0)
-+        ld s8,    64(a0)
-+        ld s9,    72(a0)
-+        ld s10,   80(a0)
-+        ld s11,   88(a0)
-+        ld sp,    96(a0)
-+        ld ra,    104(a0)
-+
-+#ifndef __riscv_soft_float
-+        fld fs0,  112(a0)
-+        fld fs1,  120(a0)
-+        fld fs2,  128(a0)
-+        fld fs3,  136(a0)
-+        fld fs3,  144(a0)
-+        fld fs4,  152(a0)
-+        fld fs5,  160(a0)
-+        fld fs6,  168(a0)
-+        fld fs7,  176(a0)
-+        fld fs8,  184(a0)
-+        fld fs9,  192(a0)
-+        fld fs10, 200(a0)
-+        fld fs11, 208(a0)
-+#endif
-+
-+        mv a0, a1
-+        bnez a1, 1f
-+        li a0, 1
-+1:      ret
-diff --git a/src/setjmp/riscv64/setjmp.S b/src/setjmp/riscv64/setjmp.S
-new file mode 100644
-index 00000000..abc05aa5
---- /dev/null
-+++ b/src/setjmp/riscv64/setjmp.S
-@@ -0,0 +1,42 @@
-+.global __setjmp
-+.global _setjmp
-+.global setjmp
-+.type __setjmp, %function
-+.type _setjmp,  %function
-+.type setjmp,   %function
-+__setjmp:
-+_setjmp:
-+setjmp:
-+        sd s0,    0(a0)
-+        sd s1,    8(a0)
-+        sd s2,    16(a0)
-+        sd s3,    24(a0)
-+        sd s4,    32(a0)
-+        sd s5,    40(a0)
-+        sd s6,    48(a0)
-+        sd s7,    56(a0)
-+        sd s8,    64(a0)
-+        sd s9,    72(a0)
-+        sd s10,   80(a0)
-+        sd s11,   88(a0)
-+        sd sp,    96(a0)
-+        sd ra,    104(a0)
-+
-+#ifndef __riscv_soft_float
-+        fsd fs0,  112(a0)
-+        fsd fs1,  120(a0)
-+        fsd fs2,  128(a0)
-+        fsd fs3,  136(a0)
-+        fsd fs3,  144(a0)
-+        fsd fs4,  152(a0)
-+        fsd fs5,  160(a0)
-+        fsd fs6,  168(a0)
-+        fsd fs7,  176(a0)
-+        fsd fs8,  184(a0)
-+        fsd fs9,  192(a0)
-+        fsd fs10, 200(a0)
-+        fsd fs11, 208(a0)
-+#endif
-+
-+        li a0, 0
-+        ret
-diff --git a/src/signal/riscv32/restore.s b/src/signal/riscv32/restore.s
-new file mode 100644
-index 00000000..732736d1
---- /dev/null
-+++ b/src/signal/riscv32/restore.s
-@@ -0,0 +1,8 @@
-+.global __restore
-+.type __restore, %function
-+__restore:
-+.global __restore_rt
-+.type __restore_rt, %function
-+__restore_rt:
-+      li a7, 139 # SYS_rt_sigreturn
-+      scall
-diff --git a/src/signal/riscv32/sigsetjmp.s b/src/signal/riscv32/sigsetjmp.s
-new file mode 100644
-index 00000000..7e4cb1f4
---- /dev/null
-+++ b/src/signal/riscv32/sigsetjmp.s
-@@ -0,0 +1,21 @@
-+.global sigsetjmp
-+.global __sigsetjmp
-+.type sigsetjmp, %function
-+.type __sigsetjmp, %function
-+sigsetjmp:
-+__sigsetjmp:
-+        beqz a1, setjmp
-+
-+        sw ra, 160(a0)
-+        sw s0, 164(a0)
-+        mv s0, a0
-+
-+        jal setjmp
-+
-+        mv a1, a0
-+        mv a0, s0
-+        lw s0, 164(a0)
-+        lw ra, 160(a0)
-+
-+.hidden __sigsetjmp_tail
-+        j __sigsetjmp_tail
-diff --git a/src/signal/riscv64/restore.s b/src/signal/riscv64/restore.s
-new file mode 100644
-index 00000000..732736d1
---- /dev/null
-+++ b/src/signal/riscv64/restore.s
-@@ -0,0 +1,8 @@
-+.global __restore
-+.type __restore, %function
-+__restore:
-+.global __restore_rt
-+.type __restore_rt, %function
-+__restore_rt:
-+      li a7, 139 # SYS_rt_sigreturn
-+      scall
-diff --git a/src/signal/riscv64/sigsetjmp.s b/src/signal/riscv64/sigsetjmp.s
-new file mode 100644
-index 00000000..9ed9500b
---- /dev/null
-+++ b/src/signal/riscv64/sigsetjmp.s
-@@ -0,0 +1,21 @@
-+.global sigsetjmp
-+.global __sigsetjmp
-+.type sigsetjmp, %function
-+.type __sigsetjmp, %function
-+sigsetjmp:
-+__sigsetjmp:
-+        beqz a1, setjmp
-+
-+        sd ra, 216(a0)
-+        sd s0, 224(a0)
-+        mv s0, a0
-+
-+        jal setjmp
-+
-+        mv a1, a0
-+        mv a0, s0
-+        ld s0, 224(a0)
-+        ld ra, 216(a0)
-+
-+.hidden __sigsetjmp_tail
-+        j __sigsetjmp_tail
-diff --git a/src/thread/riscv32/__set_thread_area.s b/src/thread/riscv32/__set_thread_area.s
-new file mode 100644
-index 00000000..828154d2
---- /dev/null
-+++ b/src/thread/riscv32/__set_thread_area.s
-@@ -0,0 +1,6 @@
-+.global __set_thread_area
-+.type   __set_thread_area, %function
-+__set_thread_area:
-+      mv tp, a0
-+      li a0, 0
-+      ret
-diff --git a/src/thread/riscv32/__unmapself.s b/src/thread/riscv32/__unmapself.s
-new file mode 100644
-index 00000000..98e7881f
---- /dev/null
-+++ b/src/thread/riscv32/__unmapself.s
-@@ -0,0 +1,7 @@
-+.global __unmapself
-+.type __unmapself, %function
-+__unmapself:
-+       li a7, 215 # SYS_munmap
-+       scall
-+       li a7, 93  # SYS_exit
-+       scall
-diff --git a/src/thread/riscv32/clone.s b/src/thread/riscv32/clone.s
-new file mode 100644
-index 00000000..30126d2c
---- /dev/null
-+++ b/src/thread/riscv32/clone.s
-@@ -0,0 +1,34 @@
-+# __clone(func, stack, flags, arg, ptid, tls, ctid)
-+#           a0,    a1,    a2,  a3,   a4,  a5,   a6
-+
-+# syscall(SYS_clone, flags, stack, ptid, tls, ctid)
-+#                a7     a0,    a1,   a2,  a3,   a4
-+
-+.global __clone
-+.type  __clone, %function
-+__clone:
-+        # Save func and arg to stack
-+        addi a1, a1, -16
-+        sw a0, 0(a1)
-+        sw a3, 4(a1)
-+
-+        # Call SYS_clone
-+        mv a0, a2
-+        mv a2, a4
-+        mv a3, a5
-+        mv a4, a6
-+        li a7, 220 # SYS_clone
-+        scall
-+
-+        beqz a0, 1f
-+        # Parent
-+        ret
-+
-+        # Child
-+1:      lw a1, 0(sp)
-+        lw a0, 4(sp)
-+        jalr a1
-+
-+        # Exit
-+        li a7, 93 # SYS_exit
-+        scall
-diff --git a/src/thread/riscv32/syscall_cp.s b/src/thread/riscv32/syscall_cp.s
-new file mode 100644
-index 00000000..71bf6d3e
---- /dev/null
-+++ b/src/thread/riscv32/syscall_cp.s
-@@ -0,0 +1,29 @@
-+.global __cp_begin
-+.hidden __cp_begin
-+.global __cp_end
-+.hidden __cp_end
-+.global __cp_cancel
-+.hidden __cp_cancel
-+.hidden __cancel
-+.global __syscall_cp_asm
-+.hidden __syscall_cp_asm
-+.type __syscall_cp_asm, %function
-+__syscall_cp_asm:
-+__cp_begin:
-+        lw t0, 0(a0)
-+        bnez t0, __cp_cancel
-+
-+        mv t0, a1
-+        mv a0, a2
-+        mv a1, a3
-+        mv a2, a4
-+        mv a3, a5
-+        mv a4, a6
-+        mv a5, a7
-+        lw a6, 0(sp)
-+        mv a7, t0
-+        scall
-+__cp_cancel:
-+        ret
-+__cp_end:
-+        j __cancel
-diff --git a/src/thread/riscv64/__set_thread_area.s b/src/thread/riscv64/__set_thread_area.s
-new file mode 100644
-index 00000000..828154d2
---- /dev/null
-+++ b/src/thread/riscv64/__set_thread_area.s
-@@ -0,0 +1,6 @@
-+.global __set_thread_area
-+.type   __set_thread_area, %function
-+__set_thread_area:
-+      mv tp, a0
-+      li a0, 0
-+      ret
-diff --git a/src/thread/riscv64/__unmapself.s b/src/thread/riscv64/__unmapself.s
-new file mode 100644
-index 00000000..98e7881f
---- /dev/null
-+++ b/src/thread/riscv64/__unmapself.s
-@@ -0,0 +1,7 @@
-+.global __unmapself
-+.type __unmapself, %function
-+__unmapself:
-+       li a7, 215 # SYS_munmap
-+       scall
-+       li a7, 93  # SYS_exit
-+       scall
-diff --git a/src/thread/riscv64/clone.s b/src/thread/riscv64/clone.s
-new file mode 100644
-index 00000000..b2d4f02d
---- /dev/null
-+++ b/src/thread/riscv64/clone.s
-@@ -0,0 +1,34 @@
-+# __clone(func, stack, flags, arg, ptid, tls, ctid)
-+#           a0,    a1,    a2,  a3,   a4,  a5,   a6
-+
-+# syscall(SYS_clone, flags, stack, ptid, tls, ctid)
-+#                a7     a0,    a1,   a2,  a3,   a4
-+
-+.global __clone
-+.type  __clone, %function
-+__clone:
-+        # Save func and arg to stack
-+        addi a1, a1, -16
-+        sd a0, 0(a1)
-+        sd a3, 8(a1)
-+
-+        # Call SYS_clone
-+        mv a0, a2
-+        mv a2, a4
-+        mv a3, a5
-+        mv a4, a6
-+        li a7, 220 # SYS_clone
-+        scall
-+
-+        beqz a0, 1f
-+        # Parent
-+        ret
-+
-+        # Child
-+1:      ld a1, 0(sp)
-+        ld a0, 8(sp)
-+        jalr a1
-+
-+        # Exit
-+        li a7, 93 # SYS_exit
-+        scall
-diff --git a/src/thread/riscv64/syscall_cp.s b/src/thread/riscv64/syscall_cp.s
-new file mode 100644
-index 00000000..c745b328
---- /dev/null
-+++ b/src/thread/riscv64/syscall_cp.s
-@@ -0,0 +1,29 @@
-+.global __cp_begin
-+.hidden __cp_begin
-+.global __cp_end
-+.hidden __cp_end
-+.global __cp_cancel
-+.hidden __cp_cancel
-+.hidden __cancel
-+.global __syscall_cp_asm
-+.hidden __syscall_cp_asm
-+.type __syscall_cp_asm, %function
-+__syscall_cp_asm:
-+__cp_begin:
-+        ld t0, 0(a0)
-+        bnez t0, __cp_cancel
-+
-+        mv t0, a1
-+        mv a0, a2
-+        mv a1, a3
-+        mv a2, a4
-+        mv a3, a5
-+        mv a4, a6
-+        mv a5, a7
-+        ld a6, 0(sp)
-+        mv a7, t0
-+        scall
-+__cp_cancel:
-+        ret
-+__cp_end:
-+        j __cancel