blob: 4e64b5cd1558762016ef166b1a73022f9ccfc084 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07002 * S390 version
3 *
4 * Derived from "include/asm-i386/unistd.h"
5 */
6
7#ifndef _ASM_S390_UNISTD_H_
8#define _ASM_S390_UNISTD_H_
9
10/*
11 * This file contains the system call numbers.
12 */
13
14#define __NR_exit 1
15#define __NR_fork 2
16#define __NR_read 3
17#define __NR_write 4
18#define __NR_open 5
19#define __NR_close 6
20#define __NR_restart_syscall 7
21#define __NR_creat 8
22#define __NR_link 9
23#define __NR_unlink 10
24#define __NR_execve 11
25#define __NR_chdir 12
Linus Torvalds1da177e2005-04-16 15:20:36 -070026#define __NR_mknod 14
27#define __NR_chmod 15
Linus Torvalds1da177e2005-04-16 15:20:36 -070028#define __NR_lseek 19
29#define __NR_getpid 20
30#define __NR_mount 21
31#define __NR_umount 22
Linus Torvalds1da177e2005-04-16 15:20:36 -070032#define __NR_ptrace 26
33#define __NR_alarm 27
34#define __NR_pause 29
35#define __NR_utime 30
36#define __NR_access 33
37#define __NR_nice 34
38#define __NR_sync 36
39#define __NR_kill 37
40#define __NR_rename 38
41#define __NR_mkdir 39
42#define __NR_rmdir 40
43#define __NR_dup 41
44#define __NR_pipe 42
45#define __NR_times 43
46#define __NR_brk 45
Linus Torvalds1da177e2005-04-16 15:20:36 -070047#define __NR_signal 48
Linus Torvalds1da177e2005-04-16 15:20:36 -070048#define __NR_acct 51
49#define __NR_umount2 52
50#define __NR_ioctl 54
51#define __NR_fcntl 55
52#define __NR_setpgid 57
53#define __NR_umask 60
54#define __NR_chroot 61
55#define __NR_ustat 62
56#define __NR_dup2 63
57#define __NR_getppid 64
58#define __NR_getpgrp 65
59#define __NR_setsid 66
60#define __NR_sigaction 67
Linus Torvalds1da177e2005-04-16 15:20:36 -070061#define __NR_sigsuspend 72
62#define __NR_sigpending 73
63#define __NR_sethostname 74
64#define __NR_setrlimit 75
Linus Torvalds1da177e2005-04-16 15:20:36 -070065#define __NR_getrusage 77
66#define __NR_gettimeofday 78
67#define __NR_settimeofday 79
Linus Torvalds1da177e2005-04-16 15:20:36 -070068#define __NR_symlink 83
69#define __NR_readlink 85
70#define __NR_uselib 86
71#define __NR_swapon 87
72#define __NR_reboot 88
73#define __NR_readdir 89
74#define __NR_mmap 90
75#define __NR_munmap 91
76#define __NR_truncate 92
77#define __NR_ftruncate 93
78#define __NR_fchmod 94
Linus Torvalds1da177e2005-04-16 15:20:36 -070079#define __NR_getpriority 96
80#define __NR_setpriority 97
81#define __NR_statfs 99
82#define __NR_fstatfs 100
Linus Torvalds1da177e2005-04-16 15:20:36 -070083#define __NR_socketcall 102
84#define __NR_syslog 103
85#define __NR_setitimer 104
86#define __NR_getitimer 105
87#define __NR_stat 106
88#define __NR_lstat 107
89#define __NR_fstat 108
90#define __NR_lookup_dcookie 110
91#define __NR_vhangup 111
92#define __NR_idle 112
93#define __NR_wait4 114
94#define __NR_swapoff 115
95#define __NR_sysinfo 116
96#define __NR_ipc 117
97#define __NR_fsync 118
98#define __NR_sigreturn 119
99#define __NR_clone 120
100#define __NR_setdomainname 121
101#define __NR_uname 122
102#define __NR_adjtimex 124
103#define __NR_mprotect 125
104#define __NR_sigprocmask 126
105#define __NR_create_module 127
106#define __NR_init_module 128
107#define __NR_delete_module 129
108#define __NR_get_kernel_syms 130
109#define __NR_quotactl 131
110#define __NR_getpgid 132
111#define __NR_fchdir 133
112#define __NR_bdflush 134
113#define __NR_sysfs 135
114#define __NR_personality 136
115#define __NR_afs_syscall 137 /* Syscall for Andrew File System */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700116#define __NR_getdents 141
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117#define __NR_flock 143
118#define __NR_msync 144
119#define __NR_readv 145
120#define __NR_writev 146
121#define __NR_getsid 147
122#define __NR_fdatasync 148
123#define __NR__sysctl 149
124#define __NR_mlock 150
125#define __NR_munlock 151
126#define __NR_mlockall 152
127#define __NR_munlockall 153
128#define __NR_sched_setparam 154
129#define __NR_sched_getparam 155
130#define __NR_sched_setscheduler 156
131#define __NR_sched_getscheduler 157
132#define __NR_sched_yield 158
133#define __NR_sched_get_priority_max 159
134#define __NR_sched_get_priority_min 160
135#define __NR_sched_rr_get_interval 161
136#define __NR_nanosleep 162
137#define __NR_mremap 163
Linus Torvalds1da177e2005-04-16 15:20:36 -0700138#define __NR_query_module 167
139#define __NR_poll 168
140#define __NR_nfsservctl 169
Linus Torvalds1da177e2005-04-16 15:20:36 -0700141#define __NR_prctl 172
142#define __NR_rt_sigreturn 173
143#define __NR_rt_sigaction 174
144#define __NR_rt_sigprocmask 175
145#define __NR_rt_sigpending 176
146#define __NR_rt_sigtimedwait 177
147#define __NR_rt_sigqueueinfo 178
148#define __NR_rt_sigsuspend 179
149#define __NR_pread64 180
150#define __NR_pwrite64 181
Linus Torvalds1da177e2005-04-16 15:20:36 -0700151#define __NR_getcwd 183
152#define __NR_capget 184
153#define __NR_capset 185
154#define __NR_sigaltstack 186
155#define __NR_sendfile 187
156#define __NR_getpmsg 188
157#define __NR_putpmsg 189
158#define __NR_vfork 190
Linus Torvalds1da177e2005-04-16 15:20:36 -0700159#define __NR_pivot_root 217
160#define __NR_mincore 218
161#define __NR_madvise 219
162#define __NR_getdents64 220
Linus Torvalds1da177e2005-04-16 15:20:36 -0700163#define __NR_readahead 222
Linus Torvalds1da177e2005-04-16 15:20:36 -0700164#define __NR_setxattr 224
165#define __NR_lsetxattr 225
166#define __NR_fsetxattr 226
167#define __NR_getxattr 227
168#define __NR_lgetxattr 228
169#define __NR_fgetxattr 229
170#define __NR_listxattr 230
171#define __NR_llistxattr 231
172#define __NR_flistxattr 232
173#define __NR_removexattr 233
174#define __NR_lremovexattr 234
175#define __NR_fremovexattr 235
176#define __NR_gettid 236
177#define __NR_tkill 237
178#define __NR_futex 238
179#define __NR_sched_setaffinity 239
180#define __NR_sched_getaffinity 240
181#define __NR_tgkill 241
182/* Number 242 is reserved for tux */
183#define __NR_io_setup 243
184#define __NR_io_destroy 244
185#define __NR_io_getevents 245
186#define __NR_io_submit 246
187#define __NR_io_cancel 247
188#define __NR_exit_group 248
189#define __NR_epoll_create 249
190#define __NR_epoll_ctl 250
191#define __NR_epoll_wait 251
192#define __NR_set_tid_address 252
193#define __NR_fadvise64 253
194#define __NR_timer_create 254
195#define __NR_timer_settime (__NR_timer_create+1)
196#define __NR_timer_gettime (__NR_timer_create+2)
197#define __NR_timer_getoverrun (__NR_timer_create+3)
198#define __NR_timer_delete (__NR_timer_create+4)
199#define __NR_clock_settime (__NR_timer_create+5)
200#define __NR_clock_gettime (__NR_timer_create+6)
201#define __NR_clock_getres (__NR_timer_create+7)
202#define __NR_clock_nanosleep (__NR_timer_create+8)
203/* Number 263 is reserved for vserver */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700204#define __NR_statfs64 265
205#define __NR_fstatfs64 266
206#define __NR_remap_file_pages 267
207/* Number 268 is reserved for new sys_mbind */
208/* Number 269 is reserved for new sys_get_mempolicy */
209/* Number 270 is reserved for new sys_set_mempolicy */
210#define __NR_mq_open 271
211#define __NR_mq_unlink 272
212#define __NR_mq_timedsend 273
213#define __NR_mq_timedreceive 274
214#define __NR_mq_notify 275
215#define __NR_mq_getsetattr 276
Heiko Carstenscf13f0e2005-06-25 14:58:11 -0700216#define __NR_kexec_load 277
Linus Torvalds1da177e2005-04-16 15:20:36 -0700217#define __NR_add_key 278
218#define __NR_request_key 279
219#define __NR_keyctl 280
220#define __NR_waitid 281
Martin Schwidefskyd2013482005-08-01 21:11:34 -0700221#define __NR_ioprio_set 282
222#define __NR_ioprio_get 283
223#define __NR_inotify_init 284
224#define __NR_inotify_add_watch 285
225#define __NR_inotify_rm_watch 286
Heiko Carstens54dfe5d2006-02-01 03:06:38 -0800226/* Number 287 is reserved for new sys_migrate_pages */
227#define __NR_openat 288
228#define __NR_mkdirat 289
229#define __NR_mknodat 290
230#define __NR_fchownat 291
231#define __NR_futimesat 292
Heiko Carstens54dfe5d2006-02-01 03:06:38 -0800232#define __NR_unlinkat 294
233#define __NR_renameat 295
234#define __NR_linkat 296
235#define __NR_symlinkat 297
236#define __NR_readlinkat 298
237#define __NR_fchmodat 299
238#define __NR_faccessat 300
239#define __NR_pselect6 301
240#define __NR_ppoll 302
Heiko Carstense7684272006-02-11 17:56:02 -0800241#define __NR_unshare 303
Martin Schwidefsky01596772006-05-15 09:44:05 -0700242#define __NR_set_robust_list 304
243#define __NR_get_robust_list 305
244#define __NR_splice 306
245#define __NR_sync_file_range 307
246#define __NR_tee 308
247#define __NR_vmsplice 309
Heiko Carstens8abfe012006-10-04 20:02:09 +0200248/* Number 310 is reserved for new sys_move_pages */
249#define __NR_getcpu 311
Heiko Carstensf5956f82006-10-18 18:30:45 +0200250#define __NR_epoll_pwait 312
Heiko Carstensfb1c1712007-03-19 13:19:07 +0100251#define __NR_utimes 313
Martin Schwidefsky7a8e0c82007-07-27 12:29:16 +0200252#define __NR_fallocate 314
Heiko Carstensfd5d8bf2007-05-21 11:25:20 +0200253#define __NR_utimensat 315
Heiko Carstens913f11e2007-05-21 11:25:21 +0200254#define __NR_signalfd 316
255#define __NR_timerfd 317
256#define __NR_eventfd 318
Heiko Carstens1ee92a12008-02-09 18:24:28 +0100257#define __NR_timerfd_create 319
258#define __NR_timerfd_settime 320
259#define __NR_timerfd_gettime 321
Heiko Carstens519620c2008-08-01 16:39:15 +0200260#define __NR_signalfd4 322
261#define __NR_eventfd2 323
262#define __NR_inotify_init1 324
263#define __NR_pipe2 325
264#define __NR_dup3 326
265#define __NR_epoll_create1 327
Heiko Carstensa93e11f2009-04-14 15:36:17 +0200266#define __NR_preadv 328
267#define __NR_pwritev 329
Heiko Carstensfc394532009-06-12 10:26:48 +0200268#define __NR_rt_tgsigqueueinfo 330
Ingo Molnarcdd6c482009-09-21 12:02:48 +0200269#define __NR_perf_event_open 331
Heiko Carstensb47ac632010-08-13 10:06:41 +0200270#define __NR_fanotify_init 332
271#define __NR_fanotify_mark 333
272#define __NR_prlimit64 334
Heiko Carstens737fd5f2011-03-23 10:15:55 +0100273#define __NR_name_to_handle_at 335
Heiko Carstens50694962011-03-23 10:15:56 +0100274#define __NR_open_by_handle_at 336
Heiko Carstens26e8a332011-03-23 10:15:57 +0100275#define __NR_clock_adjtime 337
Heiko Carstensd0d2e312011-03-23 10:15:58 +0100276#define __NR_syncfs 338
Eric W. Biederman7b21fdd2011-05-27 19:28:27 -0700277#define __NR_setns 339
Heiko Carstens80025292011-11-14 11:18:59 +0100278#define __NR_process_vm_readv 340
279#define __NR_process_vm_writev 341
Jan Glaubere4b8b3f2012-07-31 10:52:05 +0200280#define __NR_s390_runtime_instr 342
Heiko Carstensc0162b02012-09-13 15:55:38 +0200281#define __NR_kcmp 343
282#define NR_syscalls 344
Linus Torvalds1da177e2005-04-16 15:20:36 -0700283
284/*
285 * There are some system calls that are not present on 64 bit, some
286 * have a different name although they do the same (e.g. __NR_chown32
287 * is __NR_chown on 64 bit).
288 */
Martin Schwidefskyba8ce5c2006-09-20 15:58:56 +0200289#ifndef __s390x__
290
291#define __NR_time 13
292#define __NR_lchown 16
293#define __NR_setuid 23
294#define __NR_getuid 24
295#define __NR_stime 25
296#define __NR_setgid 46
297#define __NR_getgid 47
298#define __NR_geteuid 49
299#define __NR_getegid 50
300#define __NR_setreuid 70
301#define __NR_setregid 71
302#define __NR_getrlimit 76
303#define __NR_getgroups 80
304#define __NR_setgroups 81
305#define __NR_fchown 95
306#define __NR_ioperm 101
307#define __NR_setfsuid 138
308#define __NR_setfsgid 139
309#define __NR__llseek 140
310#define __NR__newselect 142
311#define __NR_setresuid 164
312#define __NR_getresuid 165
313#define __NR_setresgid 170
314#define __NR_getresgid 171
315#define __NR_chown 182
316#define __NR_ugetrlimit 191 /* SuS compliant getrlimit */
317#define __NR_mmap2 192
318#define __NR_truncate64 193
319#define __NR_ftruncate64 194
320#define __NR_stat64 195
321#define __NR_lstat64 196
322#define __NR_fstat64 197
323#define __NR_lchown32 198
324#define __NR_getuid32 199
325#define __NR_getgid32 200
326#define __NR_geteuid32 201
327#define __NR_getegid32 202
328#define __NR_setreuid32 203
329#define __NR_setregid32 204
330#define __NR_getgroups32 205
331#define __NR_setgroups32 206
332#define __NR_fchown32 207
333#define __NR_setresuid32 208
334#define __NR_getresuid32 209
335#define __NR_setresgid32 210
336#define __NR_getresgid32 211
337#define __NR_chown32 212
338#define __NR_setuid32 213
339#define __NR_setgid32 214
340#define __NR_setfsuid32 215
341#define __NR_setfsgid32 216
342#define __NR_fcntl64 221
343#define __NR_sendfile64 223
344#define __NR_fadvise64_64 264
345#define __NR_fstatat64 293
346
347#else
Linus Torvalds1da177e2005-04-16 15:20:36 -0700348
349#define __NR_select 142
350#define __NR_getrlimit 191 /* SuS compliant getrlimit */
351#define __NR_lchown 198
352#define __NR_getuid 199
353#define __NR_getgid 200
354#define __NR_geteuid 201
355#define __NR_getegid 202
356#define __NR_setreuid 203
357#define __NR_setregid 204
358#define __NR_getgroups 205
359#define __NR_setgroups 206
360#define __NR_fchown 207
361#define __NR_setresuid 208
362#define __NR_getresuid 209
363#define __NR_setresgid 210
364#define __NR_getresgid 211
365#define __NR_chown 212
366#define __NR_setuid 213
367#define __NR_setgid 214
368#define __NR_setfsuid 215
369#define __NR_setfsgid 216
Heiko Carstens19bf9cb2006-02-12 12:35:03 +0100370#define __NR_newfstatat 293
Linus Torvalds1da177e2005-04-16 15:20:36 -0700371
372#endif
373
David Woodhouse56142532006-04-29 01:51:47 +0100374#ifdef __KERNEL__
375
Heiko Carstensfd5d8bf2007-05-21 11:25:20 +0200376#ifndef CONFIG_64BIT
377#define __IGNORE_select
378#else
379#define __IGNORE_time
380#endif
381
382/* Ignore NUMA system calls. Not wired up on s390. */
383#define __IGNORE_mbind
384#define __IGNORE_get_mempolicy
385#define __IGNORE_set_mempolicy
386#define __IGNORE_migrate_pages
387#define __IGNORE_move_pages
388
Heiko Carstens94e587f2010-01-13 20:44:42 +0100389/* Ignore system calls that are also reachable via sys_socket */
390#define __IGNORE_recvmmsg
Heiko Carstensbfac1d22011-05-23 10:24:47 +0200391#define __IGNORE_sendmmsg
Heiko Carstens94e587f2010-01-13 20:44:42 +0100392
Linus Torvalds1da177e2005-04-16 15:20:36 -0700393#define __ARCH_WANT_OLD_READDIR
394#define __ARCH_WANT_SYS_ALARM
395#define __ARCH_WANT_SYS_GETHOSTNAME
396#define __ARCH_WANT_SYS_PAUSE
397#define __ARCH_WANT_SYS_SIGNAL
398#define __ARCH_WANT_SYS_UTIME
399#define __ARCH_WANT_SYS_SOCKETCALL
Heiko Carstens3a3954c2011-12-27 11:27:21 +0100400#define __ARCH_WANT_SYS_IPC
Linus Torvalds1da177e2005-04-16 15:20:36 -0700401#define __ARCH_WANT_SYS_FADVISE64
402#define __ARCH_WANT_SYS_GETPGRP
403#define __ARCH_WANT_SYS_LLSEEK
404#define __ARCH_WANT_SYS_NICE
405#define __ARCH_WANT_SYS_OLD_GETRLIMIT
Christoph Hellwiga4679372010-03-10 15:21:15 -0800406#define __ARCH_WANT_SYS_OLD_MMAP
Linus Torvalds1da177e2005-04-16 15:20:36 -0700407#define __ARCH_WANT_SYS_OLDUMOUNT
408#define __ARCH_WANT_SYS_SIGPENDING
409#define __ARCH_WANT_SYS_SIGPROCMASK
410#define __ARCH_WANT_SYS_RT_SIGACTION
Heiko Carstens54dfe5d2006-02-01 03:06:38 -0800411#define __ARCH_WANT_SYS_RT_SIGSUSPEND
Martin Schwidefsky347a8dc2006-01-06 00:19:28 -0800412# ifndef CONFIG_64BIT
Linus Torvalds1da177e2005-04-16 15:20:36 -0700413# define __ARCH_WANT_STAT64
414# define __ARCH_WANT_SYS_TIME
415# endif
Heiko Carstens54dfe5d2006-02-01 03:06:38 -0800416# ifdef CONFIG_COMPAT
417# define __ARCH_WANT_COMPAT_SYS_TIME
418# define __ARCH_WANT_COMPAT_SYS_RT_SIGSUSPEND
419# endif
Linus Torvalds1da177e2005-04-16 15:20:36 -0700420
Linus Torvalds1da177e2005-04-16 15:20:36 -0700421/*
422 * "Conditional" syscalls
423 *
424 * What we want is __attribute__((weak,alias("sys_ni_syscall"))),
425 * but it doesn't work on all toolchains, so we just do it by hand
426 */
427#define cond_syscall(x) asm(".weak\t" #x "\n\t.set\t" #x ",sys_ni_syscall")
428
David Woodhouse56142532006-04-29 01:51:47 +0100429#endif /* __KERNEL__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700430#endif /* _ASM_S390_UNISTD_H_ */