blob: 1453a2f563bcc8180101763585e776c0abe5e426 [file] [log] [blame]
David Brazdil0f672f62019-12-10 10:32:29 +00001/* SPDX-License-Identifier: GPL-2.0-only */
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00002/*
3 * Copyright (C) 2012 ARM Limited
4 * Copyright (C) 2014 Regents of the University of California
5 * Copyright (C) 2017 SiFive
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00006 */
7
8#ifndef _ASM_RISCV_VDSO_H
9#define _ASM_RISCV_VDSO_H
10
11#include <linux/types.h>
12
Olivier Deprez157378f2022-04-04 15:47:50 +020013#ifndef CONFIG_GENERIC_TIME_VSYSCALL
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000014struct vdso_data {
15};
Olivier Deprez157378f2022-04-04 15:47:50 +020016#endif
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000017
18/*
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.
25 */
26#define VDSO_SYMBOL(base, name) \
27({ \
28 extern const char __vdso_##name[]; \
29 (void __user *)((unsigned long)(base) + __vdso_##name); \
30})
31
32asmlinkage long sys_riscv_flush_icache(uintptr_t, uintptr_t, uintptr_t);
33
34#endif /* _ASM_RISCV_VDSO_H */