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