blob: 1f79e3714533e9ff3080013cafddb1e3697d318e [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001
2#include <linux/linkage.h>
3#include <linux/errno.h>
4
5#include <asm/unistd.h>
6
Adrian Bunk0732a552007-10-16 23:29:25 -07007/* we can't #include <linux/syscalls.h> here,
8 but tell gcc to not warn with -Wmissing-prototypes */
9asmlinkage long sys_ni_syscall(void);
10
Linus Torvalds1da177e2005-04-16 15:20:36 -070011/*
12 * Non-implemented system calls get redirected here.
13 */
14asmlinkage long sys_ni_syscall(void)
15{
16 return -ENOSYS;
17}
18
Linus Torvalds1da177e2005-04-16 15:20:36 -070019cond_syscall(sys_quotactl);
Vasily Tarasovb7163952007-07-15 23:41:12 -070020cond_syscall(sys32_quotactl);
Linus Torvalds1da177e2005-04-16 15:20:36 -070021cond_syscall(sys_acct);
22cond_syscall(sys_lookup_dcookie);
Al Virod5dc77b2013-02-25 18:42:04 -050023cond_syscall(compat_sys_lookup_dcookie);
Linus Torvalds1da177e2005-04-16 15:20:36 -070024cond_syscall(sys_swapon);
25cond_syscall(sys_swapoff);
Eric W. Biedermandc009d92005-06-25 14:57:52 -070026cond_syscall(sys_kexec_load);
27cond_syscall(compat_sys_kexec_load);
Linus Torvalds1da177e2005-04-16 15:20:36 -070028cond_syscall(sys_init_module);
Kees Cook34e11692012-10-16 07:31:07 +103029cond_syscall(sys_finit_module);
Linus Torvalds1da177e2005-04-16 15:20:36 -070030cond_syscall(sys_delete_module);
31cond_syscall(sys_socketpair);
32cond_syscall(sys_bind);
33cond_syscall(sys_listen);
34cond_syscall(sys_accept);
Ulrich Drepperde11def2008-11-19 15:36:14 -080035cond_syscall(sys_accept4);
Linus Torvalds1da177e2005-04-16 15:20:36 -070036cond_syscall(sys_connect);
37cond_syscall(sys_getsockname);
38cond_syscall(sys_getpeername);
39cond_syscall(sys_sendto);
40cond_syscall(sys_send);
41cond_syscall(sys_recvfrom);
42cond_syscall(sys_recv);
43cond_syscall(sys_socket);
44cond_syscall(sys_setsockopt);
David S. Millerf3baa482007-10-29 00:54:39 -070045cond_syscall(compat_sys_setsockopt);
Linus Torvalds1da177e2005-04-16 15:20:36 -070046cond_syscall(sys_getsockopt);
David S. Millerf3baa482007-10-29 00:54:39 -070047cond_syscall(compat_sys_getsockopt);
Linus Torvalds1da177e2005-04-16 15:20:36 -070048cond_syscall(sys_shutdown);
49cond_syscall(sys_sendmsg);
Anton Blanchard228e5482011-05-02 20:21:35 +000050cond_syscall(sys_sendmmsg);
David S. Millerf3baa482007-10-29 00:54:39 -070051cond_syscall(compat_sys_sendmsg);
Anton Blanchard228e5482011-05-02 20:21:35 +000052cond_syscall(compat_sys_sendmmsg);
Linus Torvalds1da177e2005-04-16 15:20:36 -070053cond_syscall(sys_recvmsg);
Arnaldo Carvalho de Meloa2e27252009-10-12 23:40:10 -070054cond_syscall(sys_recvmmsg);
David S. Millerf3baa482007-10-29 00:54:39 -070055cond_syscall(compat_sys_recvmsg);
Stephen Rothwell1ef21192010-09-03 13:19:04 +100056cond_syscall(compat_sys_recv);
Andrew Mortondedcf292009-09-18 09:52:13 +000057cond_syscall(compat_sys_recvfrom);
Arnaldo Carvalho de Meloa2e27252009-10-12 23:40:10 -070058cond_syscall(compat_sys_recvmmsg);
Linus Torvalds1da177e2005-04-16 15:20:36 -070059cond_syscall(sys_socketcall);
60cond_syscall(sys_futex);
61cond_syscall(compat_sys_futex);
Ingo Molnar0771dfe2006-03-27 01:16:22 -080062cond_syscall(sys_set_robust_list);
63cond_syscall(compat_sys_set_robust_list);
64cond_syscall(sys_get_robust_list);
65cond_syscall(compat_sys_get_robust_list);
Linus Torvalds1da177e2005-04-16 15:20:36 -070066cond_syscall(sys_epoll_create);
Wang Chen5df439e2008-07-25 01:45:23 -070067cond_syscall(sys_epoll_create1);
Linus Torvalds1da177e2005-04-16 15:20:36 -070068cond_syscall(sys_epoll_ctl);
69cond_syscall(sys_epoll_wait);
Randy Dunlap39af1142006-10-16 09:01:46 -070070cond_syscall(sys_epoll_pwait);
Atsushi Nemoto5f171562008-07-21 14:21:37 -070071cond_syscall(compat_sys_epoll_pwait);
Linus Torvalds1da177e2005-04-16 15:20:36 -070072cond_syscall(sys_semget);
73cond_syscall(sys_semop);
74cond_syscall(sys_semtimedop);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070075cond_syscall(compat_sys_semtimedop);
Linus Torvalds1da177e2005-04-16 15:20:36 -070076cond_syscall(sys_semctl);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070077cond_syscall(compat_sys_semctl);
Linus Torvalds1da177e2005-04-16 15:20:36 -070078cond_syscall(sys_msgget);
79cond_syscall(sys_msgsnd);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070080cond_syscall(compat_sys_msgsnd);
Linus Torvalds1da177e2005-04-16 15:20:36 -070081cond_syscall(sys_msgrcv);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070082cond_syscall(compat_sys_msgrcv);
Linus Torvalds1da177e2005-04-16 15:20:36 -070083cond_syscall(sys_msgctl);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070084cond_syscall(compat_sys_msgctl);
Linus Torvalds1da177e2005-04-16 15:20:36 -070085cond_syscall(sys_shmget);
Stephen Rothwell7d87e142005-05-01 08:59:12 -070086cond_syscall(sys_shmat);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070087cond_syscall(compat_sys_shmat);
Linus Torvalds1da177e2005-04-16 15:20:36 -070088cond_syscall(sys_shmdt);
89cond_syscall(sys_shmctl);
Kevin Cernekeebe84bfc2011-05-17 10:39:58 -070090cond_syscall(compat_sys_shmctl);
Linus Torvalds1da177e2005-04-16 15:20:36 -070091cond_syscall(sys_mq_open);
92cond_syscall(sys_mq_unlink);
93cond_syscall(sys_mq_timedsend);
94cond_syscall(sys_mq_timedreceive);
95cond_syscall(sys_mq_notify);
96cond_syscall(sys_mq_getsetattr);
97cond_syscall(compat_sys_mq_open);
98cond_syscall(compat_sys_mq_timedsend);
99cond_syscall(compat_sys_mq_timedreceive);
100cond_syscall(compat_sys_mq_notify);
101cond_syscall(compat_sys_mq_getsetattr);
102cond_syscall(sys_mbind);
103cond_syscall(sys_get_mempolicy);
104cond_syscall(sys_set_mempolicy);
105cond_syscall(compat_sys_mbind);
106cond_syscall(compat_sys_get_mempolicy);
107cond_syscall(compat_sys_set_mempolicy);
108cond_syscall(sys_add_key);
109cond_syscall(sys_request_key);
110cond_syscall(sys_keyctl);
111cond_syscall(compat_sys_keyctl);
112cond_syscall(compat_sys_socketcall);
Robert Love0eeca282005-07-12 17:06:03 -0400113cond_syscall(sys_inotify_init);
Ulrich Drepper40065532008-07-23 21:29:32 -0700114cond_syscall(sys_inotify_init1);
Robert Love0eeca282005-07-12 17:06:03 -0400115cond_syscall(sys_inotify_add_watch);
116cond_syscall(sys_inotify_rm_watch);
Christoph Lameter39743882006-01-08 01:00:51 -0800117cond_syscall(sys_migrate_pages);
Christoph Lameter742755a2006-06-23 02:03:55 -0700118cond_syscall(sys_move_pages);
Matt Mackalle585e472006-01-08 01:05:24 -0800119cond_syscall(sys_chown16);
120cond_syscall(sys_fchown16);
121cond_syscall(sys_getegid16);
122cond_syscall(sys_geteuid16);
123cond_syscall(sys_getgid16);
124cond_syscall(sys_getgroups16);
125cond_syscall(sys_getresgid16);
126cond_syscall(sys_getresuid16);
127cond_syscall(sys_getuid16);
128cond_syscall(sys_lchown16);
129cond_syscall(sys_setfsgid16);
130cond_syscall(sys_setfsuid16);
131cond_syscall(sys_setgid16);
132cond_syscall(sys_setgroups16);
133cond_syscall(sys_setregid16);
134cond_syscall(sys_setresgid16);
135cond_syscall(sys_setresuid16);
136cond_syscall(sys_setreuid16);
137cond_syscall(sys_setuid16);
Fabian Frederickf6187762014-06-04 16:11:12 -0700138cond_syscall(sys_sgetmask);
139cond_syscall(sys_ssetmask);
Matt Mackall64ca9002006-01-08 01:05:26 -0800140cond_syscall(sys_vm86old);
141cond_syscall(sys_vm86);
Christoph Hellwigbaed7fc2010-03-10 15:21:18 -0800142cond_syscall(sys_ipc);
Stephen Rothwell7fd105e2006-02-20 18:28:08 -0800143cond_syscall(compat_sys_ipc);
144cond_syscall(compat_sys_sysctl);
Thomas Petazzonibfcd17a2008-08-06 15:12:22 +0200145cond_syscall(sys_flock);
Thomas Petazzoniebf3f092008-10-15 22:05:12 -0700146cond_syscall(sys_io_setup);
147cond_syscall(sys_io_destroy);
148cond_syscall(sys_io_submit);
149cond_syscall(sys_io_cancel);
150cond_syscall(sys_io_getevents);
Fabian Frederick6af9f7b2014-04-03 14:48:25 -0700151cond_syscall(sys_sysfs);
Heiko Carstensf627a742009-01-14 14:13:58 +0100152cond_syscall(sys_syslog);
Christopher Yeohfcf63402011-10-31 17:06:39 -0700153cond_syscall(sys_process_vm_readv);
154cond_syscall(sys_process_vm_writev);
155cond_syscall(compat_sys_process_vm_readv);
156cond_syscall(compat_sys_process_vm_writev);
Josh Triplett69369a72014-04-03 14:48:27 -0700157cond_syscall(sys_uselib);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700158
159/* arch-specific weak syscall entries */
160cond_syscall(sys_pciconfig_read);
161cond_syscall(sys_pciconfig_write);
162cond_syscall(sys_pciconfig_iobase);
Al Viro56e41d32013-01-21 23:15:25 -0500163cond_syscall(compat_sys_s390_ipc);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700164cond_syscall(ppc_rtas);
Arnd Bergmann67207b92005-11-15 15:53:48 -0500165cond_syscall(sys_spu_run);
166cond_syscall(sys_spu_create);
Paul Mackerrasfa282372008-01-24 08:35:13 +1100167cond_syscall(sys_subpage_prot);
Hyok S. Choi3016b422006-04-10 22:53:06 -0700168
169/* mmu depending weak syscall entries */
170cond_syscall(sys_mprotect);
171cond_syscall(sys_msync);
172cond_syscall(sys_mlock);
173cond_syscall(sys_munlock);
174cond_syscall(sys_mlockall);
175cond_syscall(sys_munlockall);
176cond_syscall(sys_mincore);
177cond_syscall(sys_madvise);
178cond_syscall(sys_mremap);
179cond_syscall(sys_remap_file_pages);
Christoph Lameter1b2db9f2006-06-23 02:03:56 -0700180cond_syscall(compat_sys_move_pages);
Stephen Rothwell3fd59392006-11-02 22:07:24 -0800181cond_syscall(compat_sys_migrate_pages);
David Howells93614012006-09-30 20:45:40 +0200182
183/* block-layer dependent */
184cond_syscall(sys_bdflush);
185cond_syscall(sys_ioprio_set);
186cond_syscall(sys_ioprio_get);
Davide Libenzifba2afa2007-05-10 22:23:13 -0700187
188/* New file descriptors */
189cond_syscall(sys_signalfd);
Ulrich Drepper9deb27b2008-07-23 21:29:24 -0700190cond_syscall(sys_signalfd4);
Heiko Carstens8df767d2007-05-12 10:37:02 -0700191cond_syscall(compat_sys_signalfd);
Ingo Molnar9b813612008-07-25 13:02:37 +0200192cond_syscall(compat_sys_signalfd4);
Davide Libenzi4d672e72008-02-04 22:27:26 -0800193cond_syscall(sys_timerfd_create);
194cond_syscall(sys_timerfd_settime);
195cond_syscall(sys_timerfd_gettime);
196cond_syscall(compat_sys_timerfd_settime);
197cond_syscall(compat_sys_timerfd_gettime);
Davide Libenzie1ad7462007-05-10 22:23:19 -0700198cond_syscall(sys_eventfd);
Ulrich Drepperb087498e2008-07-23 21:29:25 -0700199cond_syscall(sys_eventfd2);
David Herrmann9183df22014-08-08 14:25:29 -0700200cond_syscall(sys_memfd_create);
Thomas Gleixner0793a612008-12-04 20:12:29 +0100201
202/* performance counters: */
Ingo Molnarcdd6c482009-09-21 12:02:48 +0200203cond_syscall(sys_perf_event_open);
Eric Paris11637e42009-12-17 21:24:25 -0500204
205/* fanotify! */
206cond_syscall(sys_fanotify_init);
Eric Parisbbaa4162009-12-17 21:24:26 -0500207cond_syscall(sys_fanotify_mark);
Al Viro91c2e0b2013-03-05 20:10:59 -0500208cond_syscall(compat_sys_fanotify_mark);
Aneesh Kumar K.V990d6c22011-01-29 18:43:26 +0530209
210/* open by handle */
211cond_syscall(sys_name_to_handle_at);
Aneesh Kumar K.Vbecfd1f2011-01-29 18:43:26 +0530212cond_syscall(sys_open_by_handle_at);
213cond_syscall(compat_sys_open_by_handle_at);
Cyrill Gorcunovd97b46a2012-05-31 16:26:44 -0700214
215/* compare kernel pointers */
216cond_syscall(sys_kcmp);
Kees Cook48dc92b2014-06-25 16:08:24 -0700217
218/* operate on Secure Computing state */
219cond_syscall(sys_seccomp);