1 // SPDX-License-Identifier: GPL-2.0-only
3 * AArch64-specific system calls implementation
5 * Copyright (C) 2012 ARM Ltd.
6 * Author: Catalin Marinas <catalin.marinas@arm.com>
9 #include <linux/compiler.h>
10 #include <linux/errno.h>
13 #include <linux/export.h>
14 #include <linux/sched.h>
15 #include <linux/slab.h>
16 #include <linux/syscalls.h>
18 #include <asm/cpufeature.h>
19 #include <asm/syscall.h>
21 SYSCALL_DEFINE6(mmap
, unsigned long, addr
, unsigned long, len
,
22 unsigned long, prot
, unsigned long, flags
,
23 unsigned long, fd
, unsigned long, off
)
25 if (offset_in_page(off
) != 0)
28 return ksys_mmap_pgoff(addr
, len
, prot
, flags
, fd
, off
>> PAGE_SHIFT
);
31 SYSCALL_DEFINE1(arm64_personality
, unsigned int, personality
)
33 if (personality(personality
) == PER_LINUX32
&&
34 !system_supports_32bit_el0())
36 return ksys_personality(personality
);
39 asmlinkage
long sys_ni_syscall(void);
41 asmlinkage
long __arm64_sys_ni_syscall(const struct pt_regs
*__unused
)
43 return sys_ni_syscall();
47 * Wrappers to pass the pt_regs argument.
49 #define __arm64_sys_personality __arm64_sys_arm64_personality
51 #define __SYSCALL_WITH_COMPAT(nr, native, compat) __SYSCALL(nr, native)
54 #define __SYSCALL(nr, sym) asmlinkage long __arm64_##sym(const struct pt_regs *);
55 #include <asm/syscall_table_64.h>
58 #define __SYSCALL(nr, sym) [nr] = __arm64_##sym,
60 const syscall_fn_t sys_call_table
[__NR_syscalls
] = {
61 [0 ... __NR_syscalls
- 1] = __arm64_sys_ni_syscall
,
62 #include <asm/syscall_table_64.h>