xref: /illumos-gate/usr/src/uts/common/sys/syscall.h (revision b1dd958f54f8bfa984d306bb8ca8264855761d7b)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 /*	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	*/
28 /*	  All Rights Reserved  	*/
29 
30 
31 #ifndef	_SYS_SYSCALL_H
32 #define	_SYS_SYSCALL_H
33 
34 #pragma ident	"%Z%%M%	%I%	%E% SMI"
35 
36 #ifdef	__cplusplus
37 extern "C" {
38 #endif
39 
40 /*
41  *	system call numbers
42  *		syscall(SYS_xxxx, ...)
43  */
44 
45 	/* syscall enumeration MUST begin with 1 */
46 
47 	/*
48 	 * SunOS/SPARC uses 0 for the indirect system call SYS_syscall
49 	 * but this doesn't count because it is just another way
50 	 * to specify the real system call number.
51 	 */
52 
53 #define	SYS_syscall	0
54 #define	SYS_exit	1
55 #define	SYS_forkall	2
56 #define	SYS_fork	SYS_forkall	/* historical */
57 #define	SYS_read	3
58 #define	SYS_write	4
59 #define	SYS_open	5
60 #define	SYS_close	6
61 #define	SYS_wait	7
62 #define	SYS_creat	8
63 #define	SYS_link	9
64 #define	SYS_unlink	10
65 #define	SYS_exec	11
66 #define	SYS_chdir	12
67 #define	SYS_time	13
68 #define	SYS_mknod	14
69 #define	SYS_chmod	15
70 #define	SYS_chown	16
71 #define	SYS_brk		17
72 #define	SYS_stat	18
73 #define	SYS_lseek	19
74 #define	SYS_getpid	20
75 #define	SYS_mount	21
76 #define	SYS_umount	22
77 #define	SYS_setuid	23
78 #define	SYS_getuid	24
79 #define	SYS_stime	25
80 #define	SYS_pcsample	26
81 #define	SYS_alarm	27
82 #define	SYS_fstat	28
83 #define	SYS_pause	29
84 #define	SYS_utime	30
85 #define	SYS_stty	31
86 #define	SYS_gtty	32
87 #define	SYS_access	33
88 #define	SYS_nice	34
89 #define	SYS_statfs	35
90 #define	SYS_sync	36
91 #define	SYS_kill	37
92 #define	SYS_fstatfs	38
93 #define	SYS_pgrpsys	39
94 	/*
95 	 * subcodes:
96 	 *	getpgrp()	  :: syscall(39,0)
97 	 *	setpgrp()	  :: syscall(39,1)
98 	 *	getsid(pid)	  :: syscall(39,2,pid)
99 	 *	setsid()	  :: syscall(39,3)
100 	 *	getpgid(pid)	  :: syscall(39,4,pid)
101 	 *	setpgid(pid,pgid) :: syscall(39,5,pid,pgid)
102 	 */
103 #define	SYS_reserved_40	40	/* 40 not used, was xenix */
104 #define	SYS_dup		41
105 #define	SYS_pipe	42
106 #define	SYS_times	43
107 #define	SYS_profil	44
108 #define	SYS_plock	45
109 #define	SYS_setgid	46
110 #define	SYS_getgid	47
111 #define	SYS_signal	48
112 	/*
113 	 * subcodes:
114 	 *	signal(sig, f) :: signal(sig, f)    ((sig&SIGNO_MASK) == sig)
115 	 *	sigset(sig, f) :: signal(sig|SIGDEFER, f)
116 	 *	sighold(sig)   :: signal(sig|SIGHOLD)
117 	 *	sigrelse(sig)  :: signal(sig|SIGRELSE)
118 	 *	sigignore(sig) :: signal(sig|SIGIGNORE)
119 	 *	sigpause(sig)  :: signal(sig|SIGPAUSE)
120 	 *	see <sys/signal.h>
121 	 */
122 #define	SYS_msgsys	49
123 	/*
124 	 * subcodes:
125 	 *	msgget(...)  :: msgsys(0, ...)
126 	 *	msgctl(...)  :: msgsys(1, ...)
127 	 *	msgrcv(...)  :: msgsys(2, ...)
128 	 *	msgsnd(...)  :: msgsys(3, ...)
129 	 *	msgids(...)  :: msgsys(4, ...)
130 	 *	msgsnap(...) :: msgsys(5, ...)
131 	 *	see <sys/msg.h>
132 	 */
133 #define	SYS_syssun	50
134 #define	SYS_sysi86	50
135 	/*
136 	 * subcodes:
137 	 *	syssun(code, ...)
138 	 *	see <sys/sys3b.h>
139 	 */
140 #define	SYS_acct	51
141 #define	SYS_shmsys	52
142 	/*
143 	 * subcodes:
144 	 *	shmat (...) :: shmsys(0, ...)
145 	 *	shmctl(...) :: shmsys(1, ...)
146 	 *	shmdt (...) :: shmsys(2, ...)
147 	 *	shmget(...) :: shmsys(3, ...)
148 	 *	shmids(...) :: shmsys(4, ...)
149 	 *	see <sys/shm.h>
150 	 */
151 #define	SYS_semsys	53
152 	/*
153 	 * subcodes:
154 	 *	semctl(...) :: semsys(0, ...)
155 	 *	semget(...) :: semsys(1, ...)
156 	 *	semop (...) :: semsys(2, ...)
157 	 *	semids(...) :: semsys(3, ...)
158 	 *	semtimedop(...) :: semsys(4, ...)
159 	 *	see <sys/sem.h>
160 	 */
161 #define	SYS_ioctl	54
162 #define	SYS_uadmin	55
163 #define	SYS_utssys	57
164 	/*
165 	 * subcodes (third argument):
166 	 *	uname(obuf)  (obsolete)   :: syscall(57, obuf, ign, 0)
167 	 *					subcode 1 unused
168 	 *	ustat(dev, obuf)	  :: syscall(57, obuf, dev, 2)
169 	 *	fusers(path, flags, obuf) :: syscall(57, path, flags, 3, obuf)
170 	 *	see <sys/utssys.h>
171 	 */
172 #define	SYS_fdsync	58
173 #define	SYS_execve	59
174 #define	SYS_umask	60
175 #define	SYS_chroot	61
176 #define	SYS_fcntl	62
177 #define	SYS_ulimit	63
178 #define	SYS_reserved_64	64	/* 64 reserved */
179 #define	SYS_reserved_65	65	/* 65 reserved */
180 #define	SYS_reserved_66	66	/* 66 reserved */
181 #define	SYS_reserved_67	67	/* 67 reserved */
182 #define	SYS_reserved_68	68	/* 68 reserved */
183 #define	SYS_reserved_69	69	/* 69 reserved */
184 #define	SYS_tasksys	70
185 	/*
186 	 * subcodes:
187 	 * 	settaskid(...) :: tasksys(0, ...)
188 	 * 	gettaskid(...) :: tasksys(1, ...)
189 	 * 	getprojid(...) :: tasksys(2, ...)
190 	 */
191 #define	SYS_acctctl	71
192 #define	SYS_exacctsys	72
193 	/*
194 	 * subcodes:
195 	 * 	getacct(...) :: exacct(0, ...)
196 	 * 	putacct(...) :: exacct(1, ...)
197 	 * 	wracct(...) :: exacct(2, ...)
198 	 */
199 #define	SYS_getpagesizes	73
200 #define	SYS_rctlsys	74
201 	/*
202 	 * subcodes:
203 	 * 	getrctl(...) :: rctlsys(0, ...)
204 	 * 	setrctl(...) :: rctlsys(1, ...)
205 	 * 	rctllist(...) :: rctlsys(2, ...)
206 	 * 	rctlctl(...) :: rctlsys(3, ...)
207 	 */
208 #define	SYS_issetugid	75
209 #define	SYS_fsat	76
210 	/*
211 	 * subcodes:
212 	 *	openat(...)	:: fsat(0, ...)
213 	 *	openat64(...)	:: fsat(1, ...)
214 	 *	fstatat64(...)	:: fsat(2, ...)
215 	 *	fstatat(...)	:: fsat(3, ...)
216 	 *	renameat(...)	:: fsat(4, ...)
217 	 *	fchownat(...)	:: fsat(5, ...)
218 	 *	unlinkat(...)	:: fsat(6, ...)
219 	 *	futimesat(...)	:: fsat(7, ...)
220 	 */
221 #define	SYS_lwp_park	77
222 	/*
223 	 * subcodes:
224 	 * 	_lwp_park(timespec_t *, lwpid_t) :: syslwp_park(0, ...)
225 	 * 	_lwp_unpark(lwpid_t, int)	 :: syslwp_park(1, ...)
226 	 * 	_lwp_unpark_all(lwpid_t *, int)  :: syslwp_park(2, ...)
227 	 */
228 #define	SYS_sendfilev	78
229 	/*
230 	 * subcodes :
231 	 * 	sendfilev()   :: sendfilev(0, ...)
232 	 * 	sendfilev64() :: sendfilev(1, ...)
233 	 */
234 #define	SYS_rmdir	79
235 #define	SYS_mkdir	80
236 #define	SYS_getdents	81
237 #define	SYS_privsys	82
238 	/*
239 	 * subcodes:
240 	 * 	setppriv(...)		:: privsys(0, ...)
241 	 * 	getppriv(...)		:: privsys(1, ...)
242 	 * 	getimplinfo(...)	:: privsys(2, ...)
243 	 * 	setpflags(...) 		:: privsys(3, ...)
244 	 * 	getpflags(...) 		:: privsys(4, ...)
245 	 */
246 #define	SYS_ucredsys	83
247 	/*
248 	 * subcodes:
249 	 *	ucred_get(...)		:: ucredsys(0, ...)
250 	 *	getpeerucred(...)	:: ucredsys(1, ...)
251 	 */
252 #define	SYS_sysfs	84
253 	/*
254 	 * subcodes:
255 	 *	sysfs(code, ...)
256 	 *	see <sys/fstyp.h>
257 	 */
258 #define	SYS_getmsg	85
259 #define	SYS_putmsg	86
260 #define	SYS_poll	87
261 
262 #define	SYS_lstat	88
263 #define	SYS_symlink	89
264 #define	SYS_readlink	90
265 #define	SYS_setgroups	91
266 #define	SYS_getgroups	92
267 #define	SYS_fchmod	93
268 #define	SYS_fchown	94
269 #define	SYS_sigprocmask	95
270 #define	SYS_sigsuspend	96
271 #define	SYS_sigaltstack	97
272 #define	SYS_sigaction	98
273 #define	SYS_sigpending	99
274 	/*
275 	 * subcodes:
276 	 *			subcode 0 unused
277 	 *	sigpending(...) :: syscall(99, 1, ...)
278 	 *	sigfillset(...) :: syscall(99, 2, ...)
279 	 */
280 #define	SYS_context	100
281 	/*
282 	 * subcodes:
283 	 *	getcontext(...) :: syscall(100, 0, ...)
284 	 *	setcontext(...) :: syscall(100, 1, ...)
285 	 */
286 #define	SYS_evsys	101
287 #define	SYS_evtrapret	102
288 #define	SYS_statvfs	103
289 #define	SYS_fstatvfs	104
290 #define	SYS_getloadavg	105
291 #define	SYS_nfssys	106
292 #define	SYS_waitsys	107
293 #define	SYS_sigsendsys	108
294 #define	SYS_hrtsys	109
295 #define	SYS_acancel	110
296 #define	SYS_async	111
297 #define	SYS_priocntlsys	112
298 #define	SYS_pathconf	113
299 #define	SYS_mincore	114
300 #define	SYS_mmap	115
301 #define	SYS_mprotect	116
302 #define	SYS_munmap	117
303 #define	SYS_fpathconf	118
304 #define	SYS_vfork	119
305 #define	SYS_fchdir	120
306 #define	SYS_readv	121
307 #define	SYS_writev	122
308 #define	SYS_xstat	123
309 #define	SYS_lxstat	124
310 #define	SYS_fxstat	125
311 #define	SYS_xmknod	126
312 #define	SYS_setrlimit	128
313 #define	SYS_getrlimit	129
314 #define	SYS_lchown	130
315 #define	SYS_memcntl	131
316 #define	SYS_getpmsg	132
317 #define	SYS_putpmsg	133
318 #define	SYS_rename	134
319 #define	SYS_uname	135
320 #define	SYS_setegid	136
321 #define	SYS_sysconfig	137
322 #define	SYS_adjtime	138
323 #define	SYS_systeminfo	139
324 #define	SYS_seteuid	141
325 #define	SYS_fork1	143
326 #define	SYS_sigtimedwait	144
327 #define	SYS_lwp_info	145
328 #define	SYS_yield	146
329 #define	SYS_lwp_sema_wait	147
330 #define	SYS_lwp_sema_post	148
331 #define	SYS_lwp_sema_trywait	149
332 #define	SYS_lwp_detach	150
333 #define	SYS_corectl	151
334 #define	SYS_modctl	152
335 #define	SYS_fchroot	153
336 #define	SYS_utimes	154
337 #define	SYS_vhangup	155
338 #define	SYS_gettimeofday	156
339 #define	SYS_getitimer		157
340 #define	SYS_setitimer		158
341 #define	SYS_lwp_create		159
342 #define	SYS_lwp_exit		160
343 #define	SYS_lwp_suspend		161
344 #define	SYS_lwp_continue	162
345 #define	SYS_lwp_kill		163
346 #define	SYS_lwp_self		164
347 #define	SYS_lwp_sigmask		165
348 #define	SYS_lwp_private		166
349 #define	SYS_lwp_wait		167
350 #define	SYS_lwp_mutex_wakeup	168
351 #define	SYS_lwp_mutex_lock	169
352 #define	SYS_lwp_cond_wait	170
353 #define	SYS_lwp_cond_signal	171
354 #define	SYS_lwp_cond_broadcast	172
355 #define	SYS_pread		173
356 #define	SYS_pwrite		174
357 #define	SYS_llseek		175
358 #define	SYS_inst_sync		176
359 #define	SYS_reserved_177	177	/* 177 reserved */
360 #define	SYS_kaio		178
361 	/*
362 	 * subcodes:
363 	 *	aioread(...)	:: kaio(AIOREAD, ...)
364 	 *	aiowrite(...)	:: kaio(AIOWRITE, ...)
365 	 *	aiowait(...)	:: kaio(AIOWAIT, ...)
366 	 *	aiocancel(...)	:: kaio(AIOCANCEL, ...)
367 	 *	aionotify()	:: kaio(AIONOTIFY)
368 	 *	aioinit()	:: kaio(AIOINIT)
369 	 *	aiostart()	:: kaio(AIOSTART)
370 	 *	see <sys/aio.h>
371 	 */
372 #define	SYS_cpc			179
373 #define	SYS_lgrpsys		180
374 #define	SYS_meminfosys		SYS_lgrpsys
375 	/*
376 	 * subcodes:
377 	 * 	meminfo(...) :: meminfosys(MISYS_MEMINFO, ...)
378 	 */
379 #define	SYS_rusagesys		181
380 	/*
381 	 * subcodes:
382 	 *	getrusage(...) :: rusagesys(RUSAGESYS_GETRUSAGE,...)
383 	 */
384 #define	SYS_port		182
385 	/*
386 	 * subcodes:
387 	 *	port_create(...) :: portfs(PORT_CREATE, ...)
388 	 *	port_associate(...) :: portfs(PORT_ASSOCIATE, ...)
389 	 *	port_dissociate(...) :: portfs(PORT_DISSOCIATE, ...)
390 	 *	port_send(...) :: portfs(PORT_SEND, ...)
391 	 *	port_sendn(...) :: portfs(PORT_SENDN, ...)
392 	 *	port_get(...) :: portfs(PORT_GET, ...)
393 	 *	port_getn(...) :: portfs(PORT_GETN, ...)
394 	 *	port_alert(...) :: portfs(PORT_ALERT, ...)
395 	 *	port_dispatch(...) :: portfs(PORT_DISPATCH, ...)
396 	 */
397 #define	SYS_pollsys		183
398 #define	SYS_tsolsys		184
399 #define	SYS_acl			185
400 #define	SYS_auditsys		186
401 #define	SYS_processor_bind	187
402 #define	SYS_processor_info	188
403 #define	SYS_p_online		189
404 #define	SYS_sigqueue		190
405 #define	SYS_clock_gettime	191
406 #define	SYS_clock_settime	192
407 #define	SYS_clock_getres	193
408 #define	SYS_timer_create	194
409 #define	SYS_timer_delete	195
410 #define	SYS_timer_settime	196
411 #define	SYS_timer_gettime	197
412 #define	SYS_timer_getoverrun	198
413 #define	SYS_nanosleep		199
414 #define	SYS_facl		200
415 #define	SYS_door		201
416 	/*
417 	 * Door Subcodes:
418 	 *	0	door_create
419 	 *	1	door_revoke
420 	 *	2	door_info
421 	 *	3	door_call
422 	 *	4	door_return
423 	 */
424 #define	SYS_setreuid		202
425 #define	SYS_setregid		203
426 #define	SYS_install_utrap	204
427 #define	SYS_signotify		205
428 #define	SYS_schedctl		206
429 #define	SYS_pset		207
430 #define	SYS_sparc_utrap_install	208
431 #define	SYS_resolvepath		209
432 #define	SYS_lwp_mutex_timedlock	210
433 #define	SYS_lwp_sema_timedwait	211
434 #define	SYS_lwp_rwlock_sys	212
435 	/*
436 	 * subcodes:
437 	 *	lwp_rwlock_rdlock(...)    :: syscall(212, 0, ...)
438 	 *	lwp_rwlock_wrlock(...)    :: syscall(212, 1, ...)
439 	 *	lwp_rwlock_tryrdlock(...) :: syscall(212, 2, ...)
440 	 *	lwp_rwlock_trywrlock(...) :: syscall(212, 3, ...)
441 	 *	lwp_rwlock_unlock(...)    :: syscall(212, 4, ...)
442 	 */
443 /* system calls for large file ( > 2 gigabyte) support */
444 #define	SYS_getdents64		213
445 #define	SYS_mmap64		214
446 #define	SYS_stat64		215
447 #define	SYS_lstat64		216
448 #define	SYS_fstat64		217
449 #define	SYS_statvfs64		218
450 #define	SYS_fstatvfs64		219
451 #define	SYS_setrlimit64		220
452 #define	SYS_getrlimit64		221
453 #define	SYS_pread64		222
454 #define	SYS_pwrite64		223
455 #define	SYS_creat64		224
456 #define	SYS_open64		225
457 #define	SYS_rpcsys		226
458 #define	SYS_zone		227
459 	/*
460 	 * subcodes:
461 	 *	zone_create(...) :: zone(ZONE_CREATE, ...)
462 	 *	zone_destroy(...) :: zone(ZONE_DESTROY, ...)
463 	 *	zone_getattr(...) :: zone(ZONE_GETATTR, ...)
464 	 *	zone_enter(...) :: zone(ZONE_ENTER, ...)
465 	 *	zone_list(...) :: zone(ZONE_LIST, ...)
466 	 *	zone_shutdown(...) :: zone(ZONE_SHUTDOWN, ...)
467 	 *	zone_lookup(...) :: zone(ZONE_LOOKUP, ...)
468 	 */
469 #define	SYS_autofssys		228
470 #define	SYS_getcwd		229
471 #define	SYS_so_socket		230
472 #define	SYS_so_socketpair	231
473 #define	SYS_bind		232
474 #define	SYS_listen		233
475 #define	SYS_accept		234
476 #define	SYS_connect		235
477 #define	SYS_shutdown		236
478 #define	SYS_recv		237
479 #define	SYS_recvfrom		238
480 #define	SYS_recvmsg		239
481 #define	SYS_send		240
482 #define	SYS_sendmsg		241
483 #define	SYS_sendto		242
484 #define	SYS_getpeername		243
485 #define	SYS_getsockname		244
486 #define	SYS_getsockopt		245
487 #define	SYS_setsockopt		246
488 #define	SYS_sockconfig		247
489 	/*
490 	 * NTP codes
491 	 */
492 #define	SYS_ntp_gettime		248
493 #define	SYS_ntp_adjtime		249
494 #define	SYS_lwp_mutex_unlock	250
495 #define	SYS_lwp_mutex_trylock	251
496 #define	SYS_lwp_mutex_init	252
497 #define	SYS_cladm		253
498 #define	SYS_reserved_254	254	/* 254 reserved */
499 #define	SYS_umount2		255
500 
501 
502 #ifndef	_ASM
503 
504 typedef struct {		/* syscall set type */
505 	unsigned int	word[16];
506 } sysset_t;
507 
508 #if !defined(_KERNEL)
509 
510 typedef struct {	/* return values from system call */
511 	long	sys_rval1;	/* primary return value from system call */
512 	long	sys_rval2;	/* second return value from system call */
513 } sysret_t;
514 
515 #if defined(__STDC__)
516 extern int	syscall(int, ...);
517 extern int	__systemcall(sysret_t *, int, ...);
518 extern int	__set_errno(int);
519 #else
520 extern int	syscall();
521 extern int	__systemcall();
522 extern int	__set_errno();
523 #endif
524 
525 #endif	/* _KERNEL */
526 
527 #endif	/* _ASM */
528 
529 #ifdef	__cplusplus
530 }
531 #endif
532 
533 #endif	/* _SYS_SYSCALL_H */
534