[ramdisk] add cvitek pre-built ramdisk
Change-Id: Ic7d2046a23358129eaf621b5558984a64fa7361d
This commit is contained in:
13
ramdisk/initramfs/glibc_riscv64/usr/include/asm/auxvec.h
Normal file
13
ramdisk/initramfs/glibc_riscv64/usr/include/asm/auxvec.h
Normal file
@ -0,0 +1,13 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */
|
||||
/*
|
||||
* Copyright (C) 2012 ARM Ltd.
|
||||
* Copyright (C) 2015 Regents of the University of California
|
||||
*/
|
||||
|
||||
#ifndef _ASM_RISCV_AUXVEC_H
|
||||
#define _ASM_RISCV_AUXVEC_H
|
||||
|
||||
/* vDSO location */
|
||||
#define AT_SYSINFO_EHDR 33
|
||||
|
||||
#endif /* _ASM_RISCV_AUXVEC_H */
|
||||
@ -0,0 +1,14 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */
|
||||
/*
|
||||
* Copyright (C) 2012 ARM Ltd.
|
||||
* Copyright (C) 2015 Regents of the University of California
|
||||
*/
|
||||
|
||||
#ifndef _ASM_RISCV_BITSPERLONG_H
|
||||
#define _ASM_RISCV_BITSPERLONG_H
|
||||
|
||||
#define __BITS_PER_LONG (__SIZEOF_POINTER__ * 8)
|
||||
|
||||
#include <asm-generic/bitsperlong.h>
|
||||
|
||||
#endif /* _ASM_RISCV_BITSPERLONG_H */
|
||||
@ -0,0 +1 @@
|
||||
#include <asm-generic/bpf_perf_event.h>
|
||||
12
ramdisk/initramfs/glibc_riscv64/usr/include/asm/byteorder.h
Normal file
12
ramdisk/initramfs/glibc_riscv64/usr/include/asm/byteorder.h
Normal file
@ -0,0 +1,12 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */
|
||||
/*
|
||||
* Copyright (C) 2012 ARM Ltd.
|
||||
* Copyright (C) 2015 Regents of the University of California
|
||||
*/
|
||||
|
||||
#ifndef _ASM_RISCV_BYTEORDER_H
|
||||
#define _ASM_RISCV_BYTEORDER_H
|
||||
|
||||
#include <linux/byteorder/little_endian.h>
|
||||
|
||||
#endif /* _ASM_RISCV_BYTEORDER_H */
|
||||
100
ramdisk/initramfs/glibc_riscv64/usr/include/asm/elf.h
Normal file
100
ramdisk/initramfs/glibc_riscv64/usr/include/asm/elf.h
Normal file
@ -0,0 +1,100 @@
|
||||
/*
|
||||
* Copyright (C) 2003 Matjaz Breskvar <phoenix@bsemi.com>
|
||||
* Copyright (C) 2010-2011 Jonas Bonn <jonas@southpole.se>
|
||||
* Copyright (C) 2012 Regents of the University of California
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*/
|
||||
|
||||
#ifndef _ASM_ELF_H
|
||||
#define _ASM_ELF_H
|
||||
|
||||
#include <asm/ptrace.h>
|
||||
|
||||
/* ELF register definitions */
|
||||
typedef unsigned long elf_greg_t;
|
||||
typedef struct user_regs_struct elf_gregset_t;
|
||||
#define ELF_NGREG (sizeof(elf_gregset_t) / sizeof(elf_greg_t))
|
||||
|
||||
/* We don't support f without d, or q. */
|
||||
typedef __u64 elf_fpreg_t;
|
||||
typedef union __riscv_fp_state elf_fpregset_t;
|
||||
#define ELF_NFPREG (sizeof(struct __riscv_d_ext_state) / sizeof(elf_fpreg_t))
|
||||
|
||||
#define ELF_NVREG (sizeof(struct __riscv_v_state) / sizeof(elf_greg_t))
|
||||
|
||||
#if __riscv_xlen == 64
|
||||
#define ELF_RISCV_R_SYM(r_info) ELF64_R_SYM(r_info)
|
||||
#define ELF_RISCV_R_TYPE(r_info) ELF64_R_TYPE(r_info)
|
||||
#else
|
||||
#define ELF_RISCV_R_SYM(r_info) ELF32_R_SYM(r_info)
|
||||
#define ELF_RISCV_R_TYPE(r_info) ELF32_R_TYPE(r_info)
|
||||
#endif
|
||||
|
||||
/*
|
||||
* RISC-V relocation types
|
||||
*/
|
||||
|
||||
/* Relocation types used by the dynamic linker */
|
||||
#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
|
||||
|
||||
/* Relocation types not used by the dynamic linker */
|
||||
#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_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
|
||||
|
||||
|
||||
#endif /* _ASM_ELF_H */
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/errno.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/errno.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/errno.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/fcntl.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/fcntl.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/fcntl.h>
|
||||
26
ramdisk/initramfs/glibc_riscv64/usr/include/asm/hwcap.h
Normal file
26
ramdisk/initramfs/glibc_riscv64/usr/include/asm/hwcap.h
Normal file
@ -0,0 +1,26 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */
|
||||
/*
|
||||
* Copied from arch/arm64/include/asm/hwcap.h
|
||||
*
|
||||
* Copyright (C) 2012 ARM Ltd.
|
||||
* Copyright (C) 2017 SiFive
|
||||
*/
|
||||
#ifndef __UAPI_ASM_HWCAP_H
|
||||
#define __UAPI_ASM_HWCAP_H
|
||||
|
||||
/*
|
||||
* Linux saves the floating-point registers according to the ISA Linux is
|
||||
* executing on, as opposed to the ISA the user program is compiled for. This
|
||||
* is necessary for a handful of esoteric use cases: for example, userpsace
|
||||
* threading libraries must be able to examine the actual machine state in
|
||||
* order to fully reconstruct the state of a thread.
|
||||
*/
|
||||
#define COMPAT_HWCAP_ISA_I (1 << ('I' - 'A'))
|
||||
#define COMPAT_HWCAP_ISA_M (1 << ('M' - 'A'))
|
||||
#define COMPAT_HWCAP_ISA_A (1 << ('A' - 'A'))
|
||||
#define COMPAT_HWCAP_ISA_F (1 << ('F' - 'A'))
|
||||
#define COMPAT_HWCAP_ISA_D (1 << ('D' - 'A'))
|
||||
#define COMPAT_HWCAP_ISA_C (1 << ('C' - 'A'))
|
||||
#define COMPAT_HWCAP_ISA_V (1 << ('V' - 'A'))
|
||||
|
||||
#endif
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ioctl.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ioctl.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/ioctl.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ioctls.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ioctls.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/ioctls.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ipcbuf.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ipcbuf.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/ipcbuf.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/mman.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/mman.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/mman.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/msgbuf.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/msgbuf.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/msgbuf.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/param.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/param.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/param.h>
|
||||
42
ramdisk/initramfs/glibc_riscv64/usr/include/asm/perf_regs.h
Normal file
42
ramdisk/initramfs/glibc_riscv64/usr/include/asm/perf_regs.h
Normal file
@ -0,0 +1,42 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
||||
/* Copyright (C) 2019 Hangzhou C-SKY Microsystems co.,ltd. */
|
||||
|
||||
#ifndef _ASM_RISCV_PERF_REGS_H
|
||||
#define _ASM_RISCV_PERF_REGS_H
|
||||
|
||||
enum perf_event_riscv_regs {
|
||||
PERF_REG_RISCV_PC,
|
||||
PERF_REG_RISCV_RA,
|
||||
PERF_REG_RISCV_SP,
|
||||
PERF_REG_RISCV_GP,
|
||||
PERF_REG_RISCV_TP,
|
||||
PERF_REG_RISCV_T0,
|
||||
PERF_REG_RISCV_T1,
|
||||
PERF_REG_RISCV_T2,
|
||||
PERF_REG_RISCV_S0,
|
||||
PERF_REG_RISCV_S1,
|
||||
PERF_REG_RISCV_A0,
|
||||
PERF_REG_RISCV_A1,
|
||||
PERF_REG_RISCV_A2,
|
||||
PERF_REG_RISCV_A3,
|
||||
PERF_REG_RISCV_A4,
|
||||
PERF_REG_RISCV_A5,
|
||||
PERF_REG_RISCV_A6,
|
||||
PERF_REG_RISCV_A7,
|
||||
PERF_REG_RISCV_S2,
|
||||
PERF_REG_RISCV_S3,
|
||||
PERF_REG_RISCV_S4,
|
||||
PERF_REG_RISCV_S5,
|
||||
PERF_REG_RISCV_S6,
|
||||
PERF_REG_RISCV_S7,
|
||||
PERF_REG_RISCV_S8,
|
||||
PERF_REG_RISCV_S9,
|
||||
PERF_REG_RISCV_S10,
|
||||
PERF_REG_RISCV_S11,
|
||||
PERF_REG_RISCV_T3,
|
||||
PERF_REG_RISCV_T4,
|
||||
PERF_REG_RISCV_T5,
|
||||
PERF_REG_RISCV_T6,
|
||||
PERF_REG_RISCV_MAX,
|
||||
};
|
||||
#endif /* _ASM_RISCV_PERF_REGS_H */
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/poll.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/poll.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/poll.h>
|
||||
@ -0,0 +1 @@
|
||||
#include <asm-generic/posix_types.h>
|
||||
91
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ptrace.h
Normal file
91
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ptrace.h
Normal file
@ -0,0 +1,91 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */
|
||||
/*
|
||||
* Copyright (C) 2012 Regents of the University of California
|
||||
*/
|
||||
|
||||
#ifndef _ASM_RISCV_PTRACE_H
|
||||
#define _ASM_RISCV_PTRACE_H
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
|
||||
#include <linux/types.h>
|
||||
|
||||
/*
|
||||
* User-mode register state for core dumps, ptrace, sigcontext
|
||||
*
|
||||
* This decouples struct pt_regs from the userspace ABI.
|
||||
* struct user_regs_struct must form a prefix of struct pt_regs.
|
||||
*/
|
||||
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 __riscv_f_ext_state {
|
||||
__u32 f[32];
|
||||
__u32 fcsr;
|
||||
};
|
||||
|
||||
struct __riscv_d_ext_state {
|
||||
__u64 f[32];
|
||||
__u32 fcsr;
|
||||
};
|
||||
|
||||
struct __riscv_q_ext_state {
|
||||
__u64 f[64] __attribute__((aligned(16)));
|
||||
__u32 fcsr;
|
||||
/*
|
||||
* Reserved for expansion of sigcontext structure. Currently zeroed
|
||||
* upon signal, and must be zero upon sigreturn.
|
||||
*/
|
||||
__u32 reserved[3];
|
||||
};
|
||||
|
||||
union __riscv_fp_state {
|
||||
struct __riscv_f_ext_state f;
|
||||
struct __riscv_d_ext_state d;
|
||||
struct __riscv_q_ext_state q;
|
||||
};
|
||||
|
||||
struct __riscv_v_state {
|
||||
__uint128_t v[32];
|
||||
unsigned long vstart;
|
||||
unsigned long vxsat;
|
||||
unsigned long vxrm;
|
||||
unsigned long vl;
|
||||
unsigned long vtype;
|
||||
};
|
||||
|
||||
#endif /* __ASSEMBLY__ */
|
||||
|
||||
#endif /* _ASM_RISCV_PTRACE_H */
|
||||
@ -0,0 +1 @@
|
||||
#include <asm-generic/resource.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/sembuf.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/sembuf.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/sembuf.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/setup.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/setup.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/setup.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/shmbuf.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/shmbuf.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/shmbuf.h>
|
||||
23
ramdisk/initramfs/glibc_riscv64/usr/include/asm/sigcontext.h
Normal file
23
ramdisk/initramfs/glibc_riscv64/usr/include/asm/sigcontext.h
Normal file
@ -0,0 +1,23 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */
|
||||
/*
|
||||
* Copyright (C) 2012 Regents of the University of California
|
||||
*/
|
||||
|
||||
#ifndef _ASM_RISCV_SIGCONTEXT_H
|
||||
#define _ASM_RISCV_SIGCONTEXT_H
|
||||
|
||||
#include <asm/ptrace.h>
|
||||
|
||||
/*
|
||||
* Signal context structure
|
||||
*
|
||||
* This contains the context saved before a signal handler is invoked;
|
||||
* it is restored by sys_sigreturn / sys_rt_sigreturn.
|
||||
*/
|
||||
struct sigcontext {
|
||||
struct user_regs_struct sc_regs;
|
||||
union __riscv_fp_state sc_fpregs;
|
||||
struct __riscv_v_state sc_vregs;
|
||||
};
|
||||
|
||||
#endif /* _ASM_RISCV_SIGCONTEXT_H */
|
||||
@ -0,0 +1 @@
|
||||
#include <asm-generic/siginfo.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/signal.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/signal.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/signal.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/socket.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/socket.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/socket.h>
|
||||
@ -0,0 +1 @@
|
||||
#include <asm-generic/sockios.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/stat.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/stat.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/stat.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/statfs.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/statfs.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/statfs.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/swab.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/swab.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/swab.h>
|
||||
@ -0,0 +1 @@
|
||||
#include <asm-generic/termbits.h>
|
||||
@ -0,0 +1 @@
|
||||
#include <asm-generic/termios.h>
|
||||
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/types.h
Normal file
1
ramdisk/initramfs/glibc_riscv64/usr/include/asm/types.h
Normal file
@ -0,0 +1 @@
|
||||
#include <asm-generic/types.h>
|
||||
34
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ucontext.h
Normal file
34
ramdisk/initramfs/glibc_riscv64/usr/include/asm/ucontext.h
Normal file
@ -0,0 +1,34 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */
|
||||
/*
|
||||
* Copyright (C) 2012 ARM Ltd.
|
||||
* Copyright (C) 2017 SiFive, Inc.
|
||||
*
|
||||
* This file was copied from arch/arm64/include/uapi/asm/ucontext.h
|
||||
*/
|
||||
#ifndef __ASM_UCONTEXT_H
|
||||
#define __ASM_UCONTEXT_H
|
||||
|
||||
#include <linux/types.h>
|
||||
|
||||
struct ucontext {
|
||||
unsigned long uc_flags;
|
||||
struct ucontext *uc_link;
|
||||
stack_t uc_stack;
|
||||
sigset_t uc_sigmask;
|
||||
/* There's some padding here to allow sigset_t to be expanded in the
|
||||
* future. Though this is unlikely, other architectures put uc_sigmask
|
||||
* at the end of this structure and explicitly state it can be
|
||||
* expanded, so we didn't want to box ourselves in here. */
|
||||
__u8 __unused[1024 / 8 - sizeof(sigset_t)];
|
||||
/* We can't put uc_sigmask at the end of this structure because we need
|
||||
* to be able to expand sigcontext in the future. For example, the
|
||||
* vector ISA extension will almost certainly add ISA state. We want
|
||||
* to ensure all user-visible ISA state can be saved and restored via a
|
||||
* ucontext, so we're putting this at the end in order to allow for
|
||||
* infinite extensibility. Since we know this will be extended and we
|
||||
* assume sigset_t won't be extended an extreme amount, we're
|
||||
* prioritizing this. */
|
||||
struct sigcontext uc_mcontext;
|
||||
};
|
||||
|
||||
#endif /* __ASM_UCONTEXT_H */
|
||||
43
ramdisk/initramfs/glibc_riscv64/usr/include/asm/unistd.h
Normal file
43
ramdisk/initramfs/glibc_riscv64/usr/include/asm/unistd.h
Normal file
@ -0,0 +1,43 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
||||
/*
|
||||
* Copyright (C) 2018 David Abdurachmanov <david.abdurachmanov@gmail.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifdef __LP64__
|
||||
#define __ARCH_WANT_NEW_STAT
|
||||
#define __ARCH_WANT_SET_GET_RLIMIT
|
||||
#define __ARCH_WANT_SYS_CLONE3
|
||||
#endif /* __LP64__ */
|
||||
|
||||
#include <asm-generic/unistd.h>
|
||||
|
||||
/*
|
||||
* Allows the instruction cache to be flushed from userspace. Despite RISC-V
|
||||
* having a direct 'fence.i' instruction available to userspace (which we
|
||||
* can't trap!), that's not actually viable when running on Linux because the
|
||||
* kernel might schedule a process on another hart. There is no way for
|
||||
* userspace to handle this without invoking the kernel (as it doesn't know the
|
||||
* thread->hart mappings), so we've defined a RISC-V specific system call to
|
||||
* flush the instruction cache.
|
||||
*
|
||||
* __NR_riscv_flush_icache is defined to flush the instruction cache over an
|
||||
* address range, with the flush applying to either all threads or just the
|
||||
* caller. We don't currently do anything with the address range, that's just
|
||||
* in there for forwards compatibility.
|
||||
*/
|
||||
#ifndef __NR_riscv_flush_icache
|
||||
#define __NR_riscv_flush_icache (__NR_arch_specific_syscall + 15)
|
||||
#endif
|
||||
__SYSCALL(__NR_riscv_flush_icache, sys_riscv_flush_icache)
|
||||
Reference in New Issue
Block a user