WIP FPC-III support
[linux/fpc-iii.git] / arch / riscv / include / asm / vdso.h
blob8454f746bbfd0f3ed6712537847deb332d0e32d0
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * Copyright (C) 2012 ARM Limited
4 * Copyright (C) 2014 Regents of the University of California
5 * Copyright (C) 2017 SiFive
6 */
8 #ifndef _ASM_RISCV_VDSO_H
9 #define _ASM_RISCV_VDSO_H
11 #include <linux/types.h>
13 #ifndef GENERIC_TIME_VSYSCALL
14 struct vdso_data {
16 #endif
19 * The VDSO symbols are mapped into Linux so we can just use regular symbol
20 * addressing to get their offsets in userspace. The symbols are mapped at an
21 * offset of 0, but since the linker must support setting weak undefined
22 * symbols to the absolute address 0 it also happens to support other low
23 * addresses even when the code model suggests those low addresses would not
24 * otherwise be availiable.
26 #define VDSO_SYMBOL(base, name) \
27 ({ \
28 extern const char __vdso_##name[]; \
29 (void __user *)((unsigned long)(base) + __vdso_##name); \
32 asmlinkage long sys_riscv_flush_icache(uintptr_t, uintptr_t, uintptr_t);
34 #endif /* _ASM_RISCV_VDSO_H */