/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2014 Garrett D'Amore <garrett@damore.org>
* Copyright (c) 2013 by Delphix. All rights reserved.
* Copyright (c) 2015, Joyent, Inc. All rights reserved.
*/
/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
#ifndef _SYS_SYSCALL_H
#define _SYS_SYSCALL_H
#ifdef __cplusplus
extern "C" {
#endif
/*
* system call numbers
* syscall(SYS_xxxx, ...)
*/
/* syscall enumeration MUST begin with 1 */
/*
* but this doesn't count because it is just another way
* to specify the real system call number.
*/
#define SYS_syscall 0
/*
* subcodes:
* getpgrp() :: syscall(39,0)
* setpgrp() :: syscall(39,1)
* getsid(pid) :: syscall(39,2,pid)
* setsid() :: syscall(39,3)
* getpgid(pid) :: syscall(39,4,pid)
* setpgid(pid,pgid) :: syscall(39,5,pid,pgid)
*/
/*
* subcodes:
* msgget(...) :: msgsys(0, ...)
* msgctl(...) :: msgsys(1, ...)
* msgrcv(...) :: msgsys(2, ...)
* msgsnd(...) :: msgsys(3, ...)
* msgids(...) :: msgsys(4, ...)
* msgsnap(...) :: msgsys(5, ...)
*/
/*
* subcodes:
* sysi86(code, ...)
*/
/*
* subcodes:
* shmat (...) :: shmsys(0, ...)
* shmctl(...) :: shmsys(1, ...)
* shmdt (...) :: shmsys(2, ...)
* shmget(...) :: shmsys(3, ...)
* shmids(...) :: shmsys(4, ...)
*/
/*
* subcodes:
* semctl(...) :: semsys(0, ...)
* semget(...) :: semsys(1, ...)
* semop (...) :: semsys(2, ...)
* semids(...) :: semsys(3, ...)
* semtimedop(...) :: semsys(4, ...)
*/
/*
* subcodes (third argument):
* uname(obuf) (obsolete) :: syscall(57, obuf, ign, 0)
* subcode 1 unused
* ustat(dev, obuf) :: syscall(57, obuf, dev, 2)
* fusers(path, flags, obuf) :: syscall(57, path, flags, 3, obuf)
*/
/*
* subcodes:
* settaskid(...) :: tasksys(0, ...)
* gettaskid(...) :: tasksys(1, ...)
* getprojid(...) :: tasksys(2, ...)
*/
/*
* subcodes:
* getacct(...) :: exacct(0, ...)
* putacct(...) :: exacct(1, ...)
* wracct(...) :: exacct(2, ...)
*/
/*
* subcodes:
* getpagesizes2(...) :: getpagesizes(0, ...)
* getpagesizes(...) :: getpagesizes(1, ...) legacy
*/
/*
* subcodes:
* getrctl(...) :: rctlsys(0, ...)
* setrctl(...) :: rctlsys(1, ...)
* rctllist(...) :: rctlsys(2, ...)
* rctlctl(...) :: rctlsys(3, ...)
*/
/*
* subcodes:
* allocids(...) :: sidsys(0, ...)
* idmap_reg(...) :: sidsys(1, ...)
* idmap_unreg(...) :: sidsys(2, ...)
*/
/*
* subcodes:
* _lwp_park(timespec_t *, lwpid_t) :: syslwp_park(0, ...)
* _lwp_unpark(lwpid_t, int) :: syslwp_park(1, ...)
* _lwp_unpark_all(lwpid_t *, int) :: syslwp_park(2, ...)
* _lwp_unpark_cancel(lwpid_t *, int) :: syslwp_park(3, ...)
* _lwp_set_park(lwpid_t *, int) :: syslwp_park(4, ...)
*/
/*
* subcodes :
* sendfilev() :: sendfilev(0, ...)
* sendfilev64() :: sendfilev(1, ...)
*/
/*
* subcodes:
* setppriv(...) :: privsys(0, ...)
* getppriv(...) :: privsys(1, ...)
* getimplinfo(...) :: privsys(2, ...)
* setpflags(...) :: privsys(3, ...)
* getpflags(...) :: privsys(4, ...)
* issetugid(); :: privsys(5)
*/
/*
* subcodes:
* ucred_get(...) :: ucredsys(0, ...)
* getpeerucred(...) :: ucredsys(1, ...)
*/
/*
* subcodes:
* sysfs(code, ...)
*/
/*
* subcodes:
* subcode 0 unused
* sigpending(...) :: syscall(99, 1, ...)
* sigfillset(...) :: syscall(99, 2, ...)
*/
/*
* subcodes:
* getcontext(...) :: syscall(100, 0, ...)
* setcontext(...) :: syscall(100, 1, ...)
*/
/*
* subcodes:
* futimens(...) :: syscall(110, 0, ...)
* utimensat(...) :: syscall(110, 1, ...)
*/
/*
* subcodes:
* forkx(flags) :: forksys(0, flags)
* forkallx(flags) :: forksys(1, flags)
* vforkx(flags) :: forksys(2, flags)
*/
/*
* subcodes:
* aioread(...) :: kaio(AIOREAD, ...)
* aiowrite(...) :: kaio(AIOWRITE, ...)
* aiowait(...) :: kaio(AIOWAIT, ...)
* aiocancel(...) :: kaio(AIOCANCEL, ...)
* aionotify() :: kaio(AIONOTIFY)
* aioinit() :: kaio(AIOINIT)
* aiostart() :: kaio(AIOSTART)
*/
/*
* subcodes:
* meminfo(...) :: meminfosys(MISYS_MEMINFO, ...)
*/
/*
* subcodes:
* getrusage(...) :: rusagesys(RUSAGESYS_GETRUSAGE, ...)
* getvmusage(...) :: rusagesys(RUSAGESYS_GETVMUSAGE, ...)
*/
/*
* subcodes:
* port_create(...) :: portfs(PORT_CREATE, ...)
* port_associate(...) :: portfs(PORT_ASSOCIATE, ...)
* port_dissociate(...) :: portfs(PORT_DISSOCIATE, ...)
* port_send(...) :: portfs(PORT_SEND, ...)
* port_sendn(...) :: portfs(PORT_SENDN, ...)
* port_get(...) :: portfs(PORT_GET, ...)
* port_getn(...) :: portfs(PORT_GETN, ...)
* port_alert(...) :: portfs(PORT_ALERT, ...)
* port_dispatch(...) :: portfs(PORT_DISPATCH, ...)
*/
/*
* Door Subcodes:
* 0 door_create
* 1 door_revoke
* 2 door_info
* 3 door_call
* 4 door_return
*/
/*
* subcodes:
* lwp_rwlock_rdlock(...) :: syscall(212, 0, ...)
* lwp_rwlock_wrlock(...) :: syscall(212, 1, ...)
* lwp_rwlock_tryrdlock(...) :: syscall(212, 2, ...)
* lwp_rwlock_trywrlock(...) :: syscall(212, 3, ...)
* lwp_rwlock_unlock(...) :: syscall(212, 4, ...)
*/
/* system calls for large file ( > 2 gigabyte) support */
/*
* subcodes:
* zone_create(...) :: zone(ZONE_CREATE, ...)
* zone_destroy(...) :: zone(ZONE_DESTROY, ...)
* zone_getattr(...) :: zone(ZONE_GETATTR, ...)
* zone_enter(...) :: zone(ZONE_ENTER, ...)
* zone_list(...) :: zone(ZONE_LIST, ...)
* zone_shutdown(...) :: zone(ZONE_SHUTDOWN, ...)
* zone_lookup(...) :: zone(ZONE_LOOKUP, ...)
* zone_boot(...) :: zone(ZONE_BOOT, ...)
* zone_version(...) :: zone(ZONE_VERSION, ...)
* zone_setattr(...) :: zone(ZONE_SETATTR, ...)
* zone_add_datalink(...) :: zone(ZONE_ADD_DATALINK, ...)
* zone_remove_datalink(...) :: zone(ZONE_DEL_DATALINK, ...)
* zone_check_datalink(...) :: zone(ZONE_CHECK_DATALINK, ...)
* zone_list_datalink(...) :: zone(ZONE_LIST_DATALINK, ...)
*/
/*
* NTP codes
*/
#ifndef _ASM
typedef struct { /* syscall set type */
} sysset_t;
typedef struct { /* return values from system call */
} sysret_t;
#if !defined(_KERNEL)
extern long syscall(int, ...);
extern long __systemcall(sysret_t *, int, ...);
extern int __set_errno(int);
#endif /* _KERNEL */
#endif /* _ASM */
#ifdef __cplusplus
}
#endif
#endif /* _SYS_SYSCALL_H */