syscallsubr.h revision 151909
1139825Simp/*- 2102779Siedowse * Copyright (c) 2002 Ian Dowse. All rights reserved. 3102779Siedowse * 4102779Siedowse * Redistribution and use in source and binary forms, with or without 5102779Siedowse * modification, are permitted provided that the following conditions 6102779Siedowse * are met: 7102779Siedowse * 1. Redistributions of source code must retain the above copyright 8102779Siedowse * notice, this list of conditions and the following disclaimer. 9102779Siedowse * 2. Redistributions in binary form must reproduce the above copyright 10102779Siedowse * notice, this list of conditions and the following disclaimer in the 11102779Siedowse * documentation and/or other materials provided with the distribution. 12102779Siedowse * 13102779Siedowse * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 14102779Siedowse * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15102779Siedowse * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16102779Siedowse * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 17102779Siedowse * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18102779Siedowse * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 19102779Siedowse * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 20102779Siedowse * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21102779Siedowse * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22102779Siedowse * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 23102779Siedowse * SUCH DAMAGE. 24102779Siedowse * 25102779Siedowse * $FreeBSD: head/sys/sys/syscallsubr.h 151909 2005-10-31 21:09:56Z ps $ 26102779Siedowse */ 27102779Siedowse 28102779Siedowse#ifndef _SYS_SYSCALLSUBR_H_ 29102779Siedowse#define _SYS_SYSCALLSUBR_H_ 30102779Siedowse 31102779Siedowse#include <sys/signal.h> 32102779Siedowse#include <sys/uio.h> 33132313Sdwmalone#include <sys/socket.h> 34136221Sdavidxu#include <sys/mac.h> 35141471Sjhb#include <sys/mount.h> 36102779Siedowse 37141471Sjhbstruct itimerval; 38141471Sjhbstruct image_args; 39135764Sjhbstruct mbuf; 40135764Sjhbstruct msghdr; 41141471Sjhbstruct msqid_ds; 42139739Sjhbstruct rlimit; 43136152Sjhbstruct rusage; 44110294Sumestruct sockaddr; 45141471Sjhbstruct stat; 46142933Spsstruct kevent; 47146950Spsstruct kevent_copyops; 48110294Sume 49102870Siedowseint kern___getcwd(struct thread *td, u_char *buf, enum uio_seg bufseg, 50102870Siedowse u_int buflen); 51102779Siedowseint kern_access(struct thread *td, char *path, enum uio_seg pathseg, 52102779Siedowse int flags); 53144445Sjhbint kern_adjtime(struct thread *td, struct timeval *delta, 54144445Sjhb struct timeval *olddelta); 55141471Sjhbint kern_alternate_path(struct thread *td, const char *prefix, char *path, 56141471Sjhb enum uio_seg pathseg, char **pathbuf, int create); 57110294Sumeint kern_bind(struct thread *td, int fd, struct sockaddr *sa); 58102779Siedowseint kern_chdir(struct thread *td, char *path, enum uio_seg pathseg); 59102779Siedowseint kern_chmod(struct thread *td, char *path, enum uio_seg pathseg, 60102779Siedowse int mode); 61102779Siedowseint kern_chown(struct thread *td, char *path, enum uio_seg pathseg, int uid, 62102779Siedowse int gid); 63151357Spsint kern_clock_getres(struct thread *td, clockid_t clock_id, 64151357Sps struct timespec *ts); 65151357Spsint kern_clock_gettime(struct thread *td, clockid_t clock_id, 66151357Sps struct timespec *ats); 67151357Spsint kern_clock_settime(struct thread *td, clockid_t clock_id, 68151357Sps struct timespec *ats); 69110294Sumeint kern_connect(struct thread *td, int fd, struct sockaddr *sa); 70140992Ssobomaxint kern_execve(struct thread *td, struct image_args *args, 71139739Sjhb struct mac *mac_p); 72102868Siedowseint kern_fcntl(struct thread *td, int fd, int cmd, intptr_t arg); 73141471Sjhbint kern_fhstatfs(struct thread *td, fhandle_t fh, struct statfs *buf); 74141471Sjhbint kern_fstat(struct thread *td, int fd, struct stat *sbp); 75141471Sjhbint kern_fstatfs(struct thread *td, int fd, struct statfs *buf); 76102779Siedowseint kern_futimes(struct thread *td, int fd, struct timeval *tptr, 77102779Siedowse enum uio_seg tptrseg); 78147302Spjdint kern_getfsstat(struct thread *td, struct statfs **buf, size_t bufsize, 79147178Spjd enum uio_seg bufseg, int flags); 80140836Ssobomaxint kern_getitimer(struct thread *, u_int, struct itimerval *); 81136152Sjhbint kern_getrusage(struct thread *td, int who, struct rusage *rup); 82132313Sdwmaloneint kern_getsockopt(struct thread *td, int s, int level, int name, 83132313Sdwmalone void *optval, enum uio_seg valseg, socklen_t *valsize); 84146950Spsint kern_kevent(struct thread *td, int fd, int nchanges, int nevents, 85146950Sps struct kevent_copyops *k_ops, const struct timespec *timeout); 86102779Siedowseint kern_lchown(struct thread *td, char *path, enum uio_seg pathseg, 87102779Siedowse int uid, int gid); 88102779Siedowseint kern_link(struct thread *td, char *path, char *link, 89102779Siedowse enum uio_seg segflg); 90141471Sjhbint kern_lstat(struct thread *td, char *path, enum uio_seg pathseg, 91141471Sjhb struct stat *sbp); 92102779Siedowseint kern_lutimes(struct thread *td, char *path, enum uio_seg pathseg, 93102779Siedowse struct timeval *tptr, enum uio_seg tptrseg); 94102779Siedowseint kern_mkdir(struct thread *td, char *path, enum uio_seg segflg, 95102779Siedowse int mode); 96102779Siedowseint kern_mkfifo(struct thread *td, char *path, enum uio_seg pathseg, 97102779Siedowse int mode); 98102779Siedowseint kern_mknod(struct thread *td, char *path, enum uio_seg pathseg, 99102779Siedowse int mode, int dev); 100141471Sjhbint kern_msgctl(struct thread *, int, int, struct msqid_ds *); 101140483Spsint kern_nanosleep(struct thread *td, struct timespec *rqt, 102140483Sps struct timespec *rmt); 103102779Siedowseint kern_open(struct thread *td, char *path, enum uio_seg pathseg, 104102779Siedowse int flags, int mode); 105141484Sjhbint kern_pathconf(struct thread *td, char *path, enum uio_seg pathseg, 106141484Sjhb int name); 107147813Sjhbint kern_preadv(struct thread *td, int fd, struct uio *auio, off_t offset); 108102946Siedowseint kern_ptrace(struct thread *td, int req, pid_t pid, void *addr, 109102946Siedowse int data); 110147813Sjhbint kern_pwritev(struct thread *td, int fd, struct uio *auio, off_t offset); 111102779Siedowseint kern_readlink(struct thread *td, char *path, enum uio_seg pathseg, 112102779Siedowse char *buf, enum uio_seg bufseg, int count); 113144445Sjhbint kern_readv(struct thread *td, int fd, struct uio *auio); 114151359Spsint kern_recvit(struct thread *td, int s, struct msghdr *mp, void *namelenp, 115151909Sps enum uio_seg segflg, struct mbuf **controlp); 116102779Siedowseint kern_rename(struct thread *td, char *from, char *to, 117102779Siedowse enum uio_seg pathseg); 118102779Siedowseint kern_rmdir(struct thread *td, char *path, enum uio_seg pathseg); 119144445Sjhbint kern_sched_rr_get_interval(struct thread *td, pid_t pid, 120144445Sjhb struct timespec *ts); 121102779Siedowseint kern_select(struct thread *td, int nd, fd_set *fd_in, fd_set *fd_ou, 122102779Siedowse fd_set *fd_ex, struct timeval *tvp); 123114749Sdwmaloneint kern_sendit(struct thread *td, int s, struct msghdr *mp, int flags, 124141029Ssobomax struct mbuf *control, enum uio_seg segflg); 125140836Ssobomaxint kern_setitimer(struct thread *, u_int, struct itimerval *, 126140836Ssobomax struct itimerval *); 127139739Sjhbint kern_setrlimit(struct thread *, u_int, struct rlimit *); 128132313Sdwmaloneint kern_setsockopt(struct thread *td, int s, int level, int name, 129132313Sdwmalone void *optval, enum uio_seg valseg, socklen_t valsize); 130144445Sjhbint kern_settimeofday(struct thread *td, struct timeval *tv, 131144445Sjhb struct timezone *tzp); 132114724Smbrint kern_shmat(struct thread *td, int shmid, const void *shmaddr, 133122088Sfjoe int shmflg); 134114724Smbrint kern_shmctl(struct thread *td, int shmid, int cmd, void *buf, 135122088Sfjoe size_t *bufsz); 136102779Siedowseint kern_sigaction(struct thread *td, int sig, struct sigaction *act, 137105950Speter struct sigaction *oact, int flags); 138102779Siedowseint kern_sigaltstack(struct thread *td, stack_t *ss, stack_t *oss); 139113685Sjhbint kern_sigprocmask(struct thread *td, int how, 140113685Sjhb sigset_t *set, sigset_t *oset, int old); 141102779Siedowseint kern_sigsuspend(struct thread *td, sigset_t mask); 142141471Sjhbint kern_stat(struct thread *td, char *path, enum uio_seg pathseg, 143141471Sjhb struct stat *sbp); 144141471Sjhbint kern_statfs(struct thread *td, char *path, enum uio_seg pathseg, 145141471Sjhb struct statfs *buf); 146102779Siedowseint kern_symlink(struct thread *td, char *path, char *link, 147102779Siedowse enum uio_seg segflg); 148102779Siedowseint kern_truncate(struct thread *td, char *path, enum uio_seg pathseg, 149102779Siedowse off_t length); 150102779Siedowseint kern_unlink(struct thread *td, char *path, enum uio_seg pathseg); 151102779Siedowseint kern_utimes(struct thread *td, char *path, enum uio_seg pathseg, 152102779Siedowse struct timeval *tptr, enum uio_seg tptrseg); 153139739Sjhbint kern_wait(struct thread *td, pid_t pid, int *status, int options, 154139739Sjhb struct rusage *rup); 155144445Sjhbint kern_writev(struct thread *td, int fd, struct uio *auio); 156102779Siedowse 157105950Speter/* flags for kern_sigaction */ 158105950Speter#define KSA_OSIGSET 0x0001 /* uses osigact_t */ 159105950Speter#define KSA_FREEBSD4 0x0002 /* uses ucontext4 */ 160105950Speter 161102779Siedowse#endif /* !_SYS_SYSCALLSUBR_H_ */ 162