linux/arch/riscv/kernel
Andrew Waterman 921ebd8f2c RISC-V: Allow userspace to flush the instruction cache
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.

This patch adds both a system call and a VDSO entry.  If possible, we'd
like to avoid having the system call be considered part of the
user-facing ABI and instead restrict that to the VDSO entry -- both just
in general to avoid having additional user-visible ABI to maintain, and
because we'd prefer that users just call the VDSO entry because there
might be a better way to do this in the future (ie, one that doesn't
require entering the kernel).

Signed-off-by: Andrew Waterman <andrew@sifive.com>
Signed-off-by: Palmer Dabbelt <palmer@sifive.com>
2017-11-30 12:58:29 -08:00
..
vdso RISC-V: Allow userspace to flush the instruction cache 2017-11-30 12:58:29 -08:00
.gitignore RISC-V: Build Infrastructure 2017-09-26 15:26:49 -07:00
asm-offsets.c RISC-V: Task implementation 2017-09-26 15:26:46 -07:00
cacheinfo.c
cpu.c
cpufeature.c RISC-V: User-facing API 2017-09-26 15:26:48 -07:00
entry.S RISC-V: Task implementation 2017-09-26 15:26:46 -07:00
head.S
irq.c
Makefile RISC-V: Build Infrastructure 2017-09-26 15:26:49 -07:00
module.c RISC-V: User-facing API 2017-09-26 15:26:48 -07:00
process.c RISC-V: Task implementation 2017-09-26 15:26:46 -07:00
ptrace.c RISC-V: User-facing API 2017-09-26 15:26:48 -07:00
reset.c
riscv_ksyms.c RISC-V: User-facing API 2017-09-26 15:26:48 -07:00
setup.c
signal.c RISC-V: User-facing API 2017-09-26 15:26:48 -07:00
smp.c RISC-V: Flush I$ when making a dirty page executable 2017-11-30 12:58:25 -08:00
smpboot.c
stacktrace.c
sys_riscv.c RISC-V: Allow userspace to flush the instruction cache 2017-11-30 12:58:29 -08:00
syscall_table.c RISC-V: Allow userspace to flush the instruction cache 2017-11-30 12:58:29 -08:00
time.c
traps.c
vdso.c
vmlinux.lds.S RISC-V: Build Infrastructure 2017-09-26 15:26:49 -07:00