blob: b5189762d275c431901add0f680da05016e782d5 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Linus Torvalds1da177e2005-04-16 15:20:36 -07002
3#include <linux/linkage.h>
4#include <linux/errno.h>
5
6#include <asm/unistd.h>
7
Adrian Bunk0732a552007-10-16 23:29:25 -07008/* we can't #include <linux/syscalls.h> here,
9 but tell gcc to not warn with -Wmissing-prototypes */
10asmlinkage long sys_ni_syscall(void);
11
Linus Torvalds1da177e2005-04-16 15:20:36 -070012/*
13 * Non-implemented system calls get redirected here.
14 */
15asmlinkage long sys_ni_syscall(void)
16{
17 return -ENOSYS;
18}
19
Linus Torvalds1da177e2005-04-16 15:20:36 -070020cond_syscall(sys_quotactl);
Vasily Tarasovb7163952007-07-15 23:41:12 -070021cond_syscall(sys32_quotactl);
Linus Torvalds1da177e2005-04-16 15:20:36 -070022cond_syscall(sys_acct);
23cond_syscall(sys_lookup_dcookie);
Al Virod5dc77b2013-02-25 18:42:04 -050024cond_syscall(compat_sys_lookup_dcookie);
Linus Torvalds1da177e2005-04-16 15:20:36 -070025cond_syscall(sys_swapon);
26cond_syscall(sys_swapoff);
Eric W. Biedermandc009d92005-06-25 14:57:52 -070027cond_syscall(sys_kexec_load);
28cond_syscall(compat_sys_kexec_load);
Vivek Goyalf0895682014-08-08 14:25:55 -070029cond_syscall(sys_kexec_file_load);
Linus Torvalds1da177e2005-04-16 15:20:36 -070030cond_syscall(sys_init_module);
Kees Cook34e11692012-10-16 07:31:07 +103031cond_syscall(sys_finit_module);
Linus Torvalds1da177e2005-04-16 15:20:36 -070032cond_syscall(sys_delete_module);
33cond_syscall(sys_socketpair);
34cond_syscall(sys_bind);
35cond_syscall(sys_listen);
36cond_syscall(sys_accept);
Ulrich Drepperde11def2008-11-19 15:36:14 -080037cond_syscall(sys_accept4);
Linus Torvalds1da177e2005-04-16 15:20:36 -070038cond_syscall(sys_connect);
39cond_syscall(sys_getsockname);
40cond_syscall(sys_getpeername);
41cond_syscall(sys_sendto);
42cond_syscall(sys_send);
43cond_syscall(sys_recvfrom);
44cond_syscall(sys_recv);
45cond_syscall(sys_socket);
46cond_syscall(sys_setsockopt);
David S. Millerf3baa482007-10-29 00:54:39 -070047cond_syscall(compat_sys_setsockopt);
Linus Torvalds1da177e2005-04-16 15:20:36 -070048cond_syscall(sys_getsockopt);
David S. Millerf3baa482007-10-29 00:54:39 -070049cond_syscall(compat_sys_getsockopt);
Linus Torvalds1da177e2005-04-16 15:20:36 -070050cond_syscall(sys_shutdown);
51cond_syscall(sys_sendmsg);
Anton Blanchard228e5482011-05-02 20:21:35 +000052cond_syscall(sys_sendmmsg);
David S. Millerf3baa482007-10-29 00:54:39 -070053cond_syscall(compat_sys_sendmsg);
Anton Blanchard228e5482011-05-02 20:21:35 +000054cond_syscall(compat_sys_sendmmsg);
Linus Torvalds1da177e2005-04-16 15:20:36 -070055cond_syscall(sys_recvmsg);
Arnaldo Carvalho de Meloa2e27252009-10-12 23:40:10 -070056cond_syscall(sys_recvmmsg);
David S. Millerf3baa482007-10-29 00:54:39 -070057cond_syscall(compat_sys_recvmsg);
Stephen Rothwell1ef21192010-09-03 13:19:04 +100058cond_syscall(compat_sys_recv);
Andrew Mortondedcf292009-09-18 09:52:13 +000059cond_syscall(compat_sys_recvfrom);
Arnaldo Carvalho de Meloa2e27252009-10-12 23:40:10 -070060cond_syscall(compat_sys_recvmmsg);
Linus Torvalds1da177e2005-04-16 15:20:36 -070061cond_syscall(sys_socketcall);
62cond_syscall(sys_futex);
63cond_syscall(compat_sys_futex);
Ingo Molnar0771dfe2006-03-27 01:16:22 -080064cond_syscall(sys_set_robust_list);
65cond_syscall(compat_sys_set_robust_list);
66cond_syscall(sys_get_robust_list);
67cond_syscall(compat_sys_get_robust_list);
Linus Torvalds1da177e2005-04-16 15:20:36 -070068cond_syscall(sys_epoll_create);
Wang Chen5df439e2008-07-25 01:45:23 -070069cond_syscall(sys_epoll_create1);
Linus Torvalds1da177e2005-04-16 15:20:36 -070070cond_syscall(sys_epoll_ctl);
71cond_syscall(sys_epoll_wait);
Randy Dunlap39af1142006-10-16 09:01:46 -070072cond_syscall(sys_epoll_pwait);
Atsushi Nemoto5f171562008-07-21 14:21:37 -070073cond_syscall(compat_sys_epoll_pwait);
Linus Torvalds1da177e2005-04-16 15:20:36 -070074cond_syscall(sys_semget);
75cond_syscall(sys_semop);
76cond_syscall(sys_semtimedop);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070077cond_syscall(compat_sys_semtimedop);
Linus Torvalds1da177e2005-04-16 15:20:36 -070078cond_syscall(sys_semctl);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070079cond_syscall(compat_sys_semctl);
Linus Torvalds1da177e2005-04-16 15:20:36 -070080cond_syscall(sys_msgget);
81cond_syscall(sys_msgsnd);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070082cond_syscall(compat_sys_msgsnd);
Linus Torvalds1da177e2005-04-16 15:20:36 -070083cond_syscall(sys_msgrcv);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070084cond_syscall(compat_sys_msgrcv);
Linus Torvalds1da177e2005-04-16 15:20:36 -070085cond_syscall(sys_msgctl);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070086cond_syscall(compat_sys_msgctl);
Linus Torvalds1da177e2005-04-16 15:20:36 -070087cond_syscall(sys_shmget);
Stephen Rothwell7d87e14c2005-05-01 08:59:12 -070088cond_syscall(sys_shmat);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070089cond_syscall(compat_sys_shmat);
Linus Torvalds1da177e2005-04-16 15:20:36 -070090cond_syscall(sys_shmdt);
91cond_syscall(sys_shmctl);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070092cond_syscall(compat_sys_shmctl);
Linus Torvalds1da177e2005-04-16 15:20:36 -070093cond_syscall(sys_mq_open);
94cond_syscall(sys_mq_unlink);
95cond_syscall(sys_mq_timedsend);
96cond_syscall(sys_mq_timedreceive);
97cond_syscall(sys_mq_notify);
98cond_syscall(sys_mq_getsetattr);
99cond_syscall(compat_sys_mq_open);
100cond_syscall(compat_sys_mq_timedsend);
101cond_syscall(compat_sys_mq_timedreceive);
102cond_syscall(compat_sys_mq_notify);
103cond_syscall(compat_sys_mq_getsetattr);
104cond_syscall(sys_mbind);
105cond_syscall(sys_get_mempolicy);
106cond_syscall(sys_set_mempolicy);
107cond_syscall(compat_sys_mbind);
108cond_syscall(compat_sys_get_mempolicy);
109cond_syscall(compat_sys_set_mempolicy);
110cond_syscall(sys_add_key);
111cond_syscall(sys_request_key);
112cond_syscall(sys_keyctl);
113cond_syscall(compat_sys_keyctl);
114cond_syscall(compat_sys_socketcall);
Robert Love0eeca282005-07-12 17:06:03 -0400115cond_syscall(sys_inotify_init);
Ulrich Drepper40065532008-07-23 21:29:32 -0700116cond_syscall(sys_inotify_init1);
Robert Love0eeca282005-07-12 17:06:03 -0400117cond_syscall(sys_inotify_add_watch);
118cond_syscall(sys_inotify_rm_watch);
Christoph Lameter39743882006-01-08 01:00:51 -0800119cond_syscall(sys_migrate_pages);
Christoph Lameter742755a2006-06-23 02:03:55 -0700120cond_syscall(sys_move_pages);
Matt Mackalle585e472006-01-08 01:05:24 -0800121cond_syscall(sys_chown16);
122cond_syscall(sys_fchown16);
123cond_syscall(sys_getegid16);
124cond_syscall(sys_geteuid16);
125cond_syscall(sys_getgid16);
126cond_syscall(sys_getgroups16);
127cond_syscall(sys_getresgid16);
128cond_syscall(sys_getresuid16);
129cond_syscall(sys_getuid16);
130cond_syscall(sys_lchown16);
131cond_syscall(sys_setfsgid16);
132cond_syscall(sys_setfsuid16);
133cond_syscall(sys_setgid16);
134cond_syscall(sys_setgroups16);
135cond_syscall(sys_setregid16);
136cond_syscall(sys_setresgid16);
137cond_syscall(sys_setresuid16);
138cond_syscall(sys_setreuid16);
139cond_syscall(sys_setuid16);
Fabian Frederickf6187762014-06-04 16:11:12 -0700140cond_syscall(sys_sgetmask);
141cond_syscall(sys_ssetmask);
Matt Mackall64ca9002006-01-08 01:05:26 -0800142cond_syscall(sys_vm86old);
143cond_syscall(sys_vm86);
Andy Lutomirskia5b9e5a2015-07-30 14:31:34 -0700144cond_syscall(sys_modify_ldt);
Christoph Hellwigbaed7fc2010-03-10 15:21:18 -0800145cond_syscall(sys_ipc);
Stephen Rothwell7fd105e2006-02-20 18:28:08 -0800146cond_syscall(compat_sys_ipc);
147cond_syscall(compat_sys_sysctl);
Thomas Petazzonibfcd17a2008-08-06 15:12:22 +0200148cond_syscall(sys_flock);
Thomas Petazzoniebf3f092008-10-15 22:05:12 -0700149cond_syscall(sys_io_setup);
150cond_syscall(sys_io_destroy);
151cond_syscall(sys_io_submit);
152cond_syscall(sys_io_cancel);
153cond_syscall(sys_io_getevents);
Al Viroc00d2c72016-12-20 07:04:57 -0500154cond_syscall(compat_sys_io_setup);
155cond_syscall(compat_sys_io_submit);
156cond_syscall(compat_sys_io_getevents);
Fabian Frederick6af9f7b2014-04-03 14:48:25 -0700157cond_syscall(sys_sysfs);
Heiko Carstensf627a742009-01-14 14:13:58 +0100158cond_syscall(sys_syslog);
Christopher Yeohfcf63402011-10-31 17:06:39 -0700159cond_syscall(sys_process_vm_readv);
160cond_syscall(sys_process_vm_writev);
161cond_syscall(compat_sys_process_vm_readv);
162cond_syscall(compat_sys_process_vm_writev);
Josh Triplett69369a72014-04-03 14:48:27 -0700163cond_syscall(sys_uselib);
Josh Triplettd3ac21c2014-08-17 19:41:09 -0500164cond_syscall(sys_fadvise64);
165cond_syscall(sys_fadvise64_64);
166cond_syscall(sys_madvise);
Iulia Manda28138932015-04-15 16:16:41 -0700167cond_syscall(sys_setuid);
168cond_syscall(sys_setregid);
169cond_syscall(sys_setgid);
170cond_syscall(sys_setreuid);
171cond_syscall(sys_setresuid);
172cond_syscall(sys_getresuid);
173cond_syscall(sys_setresgid);
174cond_syscall(sys_getresgid);
175cond_syscall(sys_setgroups);
176cond_syscall(sys_getgroups);
177cond_syscall(sys_setfsuid);
178cond_syscall(sys_setfsgid);
179cond_syscall(sys_capget);
180cond_syscall(sys_capset);
Zach Brown29732932015-11-10 16:53:30 -0500181cond_syscall(sys_copy_file_range);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700182
183/* arch-specific weak syscall entries */
184cond_syscall(sys_pciconfig_read);
185cond_syscall(sys_pciconfig_write);
186cond_syscall(sys_pciconfig_iobase);
Al Viro56e41d32013-01-21 23:15:25 -0500187cond_syscall(compat_sys_s390_ipc);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700188cond_syscall(ppc_rtas);
Arnd Bergmann67207b92005-11-15 15:53:48 -0500189cond_syscall(sys_spu_run);
190cond_syscall(sys_spu_create);
Paul Mackerrasfa282372008-01-24 08:35:13 +1100191cond_syscall(sys_subpage_prot);
Alexey Ishchuk4eafad72014-11-14 14:27:58 +0100192cond_syscall(sys_s390_pci_mmio_read);
193cond_syscall(sys_s390_pci_mmio_write);
Hyok S. Choi3016b422006-04-10 22:53:06 -0700194
195/* mmu depending weak syscall entries */
196cond_syscall(sys_mprotect);
197cond_syscall(sys_msync);
198cond_syscall(sys_mlock);
199cond_syscall(sys_munlock);
200cond_syscall(sys_mlockall);
201cond_syscall(sys_munlockall);
Eric B Munsona8ca5d02015-11-05 18:51:33 -0800202cond_syscall(sys_mlock2);
Hyok S. Choi3016b422006-04-10 22:53:06 -0700203cond_syscall(sys_mincore);
204cond_syscall(sys_madvise);
205cond_syscall(sys_mremap);
206cond_syscall(sys_remap_file_pages);
Christoph Lameter1b2db9f2006-06-23 02:03:56 -0700207cond_syscall(compat_sys_move_pages);
Stephen Rothwell3fd59392006-11-02 22:07:24 -0800208cond_syscall(compat_sys_migrate_pages);
David Howells93614012006-09-30 20:45:40 +0200209
210/* block-layer dependent */
211cond_syscall(sys_bdflush);
212cond_syscall(sys_ioprio_set);
213cond_syscall(sys_ioprio_get);
Davide Libenzifba2afa2007-05-10 22:23:13 -0700214
215/* New file descriptors */
216cond_syscall(sys_signalfd);
Ulrich Drepper9deb27b2008-07-23 21:29:24 -0700217cond_syscall(sys_signalfd4);
Heiko Carstens8df767d2007-05-12 10:37:02 -0700218cond_syscall(compat_sys_signalfd);
Ingo Molnar9b813612008-07-25 13:02:37 +0200219cond_syscall(compat_sys_signalfd4);
Davide Libenzi4d672e72008-02-04 22:27:26 -0800220cond_syscall(sys_timerfd_create);
221cond_syscall(sys_timerfd_settime);
222cond_syscall(sys_timerfd_gettime);
223cond_syscall(compat_sys_timerfd_settime);
224cond_syscall(compat_sys_timerfd_gettime);
Davide Libenzie1ad7462007-05-10 22:23:19 -0700225cond_syscall(sys_eventfd);
Ulrich Drepperb087498e2008-07-23 21:29:25 -0700226cond_syscall(sys_eventfd2);
David Herrmann9183df22014-08-08 14:25:29 -0700227cond_syscall(sys_memfd_create);
Andrea Arcangeli1380fca2015-09-04 15:46:58 -0700228cond_syscall(sys_userfaultfd);
Thomas Gleixner0793a612008-12-04 20:12:29 +0100229
230/* performance counters: */
Ingo Molnarcdd6c482009-09-21 12:02:48 +0200231cond_syscall(sys_perf_event_open);
Eric Paris11637e42009-12-17 21:24:25 -0500232
233/* fanotify! */
234cond_syscall(sys_fanotify_init);
Eric Parisbbaa4162009-12-17 21:24:26 -0500235cond_syscall(sys_fanotify_mark);
Al Viro91c2e0b2013-03-05 20:10:59 -0500236cond_syscall(compat_sys_fanotify_mark);
Aneesh Kumar K.V990d6c22011-01-29 18:43:26 +0530237
238/* open by handle */
239cond_syscall(sys_name_to_handle_at);
Aneesh Kumar K.Vbecfd1f2011-01-29 18:43:26 +0530240cond_syscall(sys_open_by_handle_at);
241cond_syscall(compat_sys_open_by_handle_at);
Cyrill Gorcunovd97b46a2012-05-31 16:26:44 -0700242
243/* compare kernel pointers */
244cond_syscall(sys_kcmp);
Kees Cook48dc92b2014-06-25 16:08:24 -0700245
246/* operate on Secure Computing state */
247cond_syscall(sys_seccomp);
Alexei Starovoitov749730c2014-09-26 00:16:58 -0700248
249/* access BPF programs and maps */
250cond_syscall(sys_bpf);
David Drysdale51f39a12014-12-12 16:57:29 -0800251
252/* execveat */
253cond_syscall(sys_execveat);
Mathieu Desnoyers5b25b132015-09-11 13:07:39 -0700254
255/* membarrier */
256cond_syscall(sys_membarrier);
Dave Hansene2753292016-09-12 13:38:42 -0700257
258/* memory protection keys */
259cond_syscall(sys_pkey_mprotect);
260cond_syscall(sys_pkey_alloc);
261cond_syscall(sys_pkey_free);