Linux and UNIX Man Pages

Linux & Unix Commands - Search Man Pages

pdwait4(2) [freebsd man page]

PDFORK(2)						      BSD System Calls Manual							 PDFORK(2)

NAME
pdfork, pdgetpid, pdkill, pdwait4 -- System calls to manage process descriptors LIBRARY
Standard C Library (libc, -lc) SYNOPSIS
#include <sys/procdesc.h> pid_t pdfork(int *fdp, int flags); int pdgetpid(int fd, pid_t *pidp); int pdkill(int fd, int signum); int pdwait4(int fd, int *status, int options, struct rusage *rusage); DESCRIPTION
Process descriptors are special file descriptors that represent processes, and are created using pdfork(), a variant of fork(2), which, if successful, returns a process descriptor in the integer pointed to by fdp. Processes created via pdfork() will not cause SIGCHLD on termina- tion. pdfork() can accept the flags: PD_DAEMON Instead of the default terminate-on-close behaviour, allow the process to live until it is explicitly killed with kill(2). This option is not permitted in capsicum(4) capability mode (see cap_enter(2)). pdgetpid() queries the process ID (PID) in the process descriptor fd. pdkill() is functionally identical to kill(2), except that it accepts a process descriptor, fd, rather than a PID. pdwait4() behaves identically to wait4(2), but operates with respect to a process descriptor argument rather than a PID. The following system calls also have effects specific to process descriptors: fstat(2) queries status of a process descriptor; currently only the st_mode, st_birthtime, st_atime, st_ctime and st_mtime fields are defined. If the owner read, write, and execute bits are set then the process represented by the process descriptor is still alive. poll(2) and select(2) allow waiting for process state transitions; currently only POLLHUP is defined, and will be raised when the process dies. Process state transitions can also be monitored using kqueue(2) filter EVFILT_PROCDESC; currently only NOTE_EXIT is implemented. close(2) will close the process descriptor unless PD_DAEMON is set; if the process is still alive and this is the last reference to the process descriptor, the process will be terminated with the signal SIGKILL. RETURN VALUES
pdfork() returns a PID, 0 or -1, as fork(2) does. pdgetpid() and pdkill() return 0 on success and -1 on failure. pdwait4() returns a PID on success and -1 on failure. ERRORS
These functions may return the same error numbers as their PID-based equivalents (e.g. pdfork() may return the same error numbers as fork(2)), with the following additions: [EINVAL] The signal number given to pdkill() is invalid. [ENOTCAPABLE] The process descriptor being operated on has insufficient rights (e.g. CAP_PDKILL for pdkill()). SEE ALSO
close(2), fork(2), fstat(2), kill(2), poll(2), wait4(2), capsicum(4), procdesc(4) HISTORY
The pdfork(), pdgetpid(), pdkill() and pdwait4() system calls first appeared in FreeBSD 9.0. Support for process descriptors mode was developed as part of the TrustedBSD Project. AUTHORS
These functions and the capability facility were created by Robert N. M. Watson <rwatson@FreeBSD.org> and Jonathan Anderson <jonathan@FreeBSD.org> at the University of Cambridge Computer Laboratory with support from a grant from Google, Inc. BUGS
pdwait4() has not yet been implemented. BSD
April 7, 2014 BSD

Check Out this Related Man Page

RIGHTS(4)						   BSD Kernel Interfaces Manual 						 RIGHTS(4)

NAME
Capability rights -- Capsicum capability rights for file descriptors DESCRIPTION
When a file descriptor is created by a function such as accept(2), accept4(2), fhopen(2), kqueue(2), mq_open(2), open(2), openat(2), pdfork(2), pipe(2), shm_open(2), socket(2) or socketpair(2), it is assigned all capability rights. Those rights can be reduced (but never expanded) by using the cap_rights_limit(2), cap_fcntls_limit(2) and cap_ioctls_limit(2) system calls. Once capability rights are reduced, operations on the file descriptor will be limited to those permitted by rights. The complete list of capability rights is provided below. The cap_rights_t type is used to store list of capability rights. The cap_rights_init(3) family of functions should be used to manage the structure. RIGHTS
The following rights may be specified in a rights mask: CAP_ACCEPT Permit accept(2) and accept4(2). CAP_ACL_CHECK Permit acl_valid_fd_np(3). CAP_ACL_DELETE Permit acl_delete_fd_np(3). CAP_ACL_GET Permit acl_get_fd(3) and acl_get_fd_np(3). CAP_ACL_SET Permit acl_set_fd(3) and acl_set_fd_np(3). CAP_BIND Permit bind(2). Note that sockets can also become bound implicitly as a result of connect(2) or send(2), and that socket options set with setsockopt(2) may also affect binding behavior. CAP_BINDAT Permit bindat(2). This right has to be present on the directory descriptor. This right includes the CAP_LOOKUP right. CAP_CHFLAGSAT An alias to CAP_FCHFLAGS and CAP_LOOKUP. CAP_CONNECT Permit connect(2); also required for sendto(2) with a non-NULL destination address. CAP_CONNECTAT Permit connectat(2). This right has to be present on the directory descriptor. This right includes the CAP_LOOKUP right. CAP_CREATE Permit openat(2) with the O_CREAT flag. CAP_EVENT Permit select(2), poll(2), and kevent(2) to be used in monitoring the file descriptor for events. CAP_EXTATTR_DELETE Permit extattr_delete_fd(2). CAP_EXTATTR_GET Permit extattr_get_fd(2). CAP_EXTATTR_LIST Permit extattr_list_fd(2). CAP_EXTATTR_SET Permit extattr_set_fd(2). CAP_FCHDIR Permit fchdir(2). CAP_FCHFLAGS Permit fchflags(2) and chflagsat(2) if the CAP_LOOKUP right is also present. CAP_FCHMOD Permit fchmod(2) and fchmodat(2) if the CAP_LOOKUP right is also present. CAP_FCHMODAT An alias to CAP_FCHMOD and CAP_LOOKUP. CAP_FCHOWN Permit fchown(2) and fchownat(2) if the CAP_LOOKUP right is also present. CAP_FCHOWNAT An alias to CAP_FCHOWN and CAP_LOOKUP. CAP_FCNTL Permit fcntl(2). Note that only the F_GETFL, F_SETFL, F_GETOWN and F_SETOWN commands require this capability right. Also note that the list of permitted commands can be further limited with the cap_fcntls_limit(2) system call. CAP_FEXECVE Permit fexecve(2) and openat(2) with the O_EXEC flag; CAP_READ is also be required. CAP_FLOCK Permit flock(2), fcntl(2) (with F_GETLK, F_SETLK, F_SETLKW or F_SETLK_REMOTE flag) and openat(2) (with O_EXLOCK or O_SHLOCK flag). CAP_FPATHCONF Permit fpathconf(2). CAP_FSCK Permit UFS background-fsck operations on the descriptor. CAP_FSTAT Permit fstat(2) and fstatat(2) if the CAP_LOOKUP right is also present. CAP_FSTATAT An alias to CAP_FSTAT and CAP_LOOKUP. CAP_FSTATFS Permit fstatfs(2). CAP_FSYNC Permit aio_fsync(2), fsync(2) and openat(2) with O_FSYNC or O_SYNC flag. CAP_FTRUNCATE Permit ftruncate(2) and openat(2) with the O_TRUNC flag. CAP_FUTIMES Permit futimens(2) and futimes(2), and permit futimesat(2) and utimensat(2) if the CAP_LOOKUP right is also present. CAP_FUTIMESAT An alias to CAP_FUTIMES and CAP_LOOKUP. CAP_GETPEERNAME Permit getpeername(2). CAP_GETSOCKNAME Permit getsockname(2). CAP_GETSOCKOPT Permit getsockopt(2). CAP_IOCTL Permit ioctl(2). Be aware that this system call has enormous scope, including potentially global scope for some objects. The list of permitted ioctl commands can be further limited with the cap_ioctls_limit(2) system call. CAP_KQUEUE An alias to CAP_KQUEUE_CHANGE and CAP_KQUEUE_EVENT. CAP_KQUEUE_CHANGE Permit kevent(2) on a kqueue(2) descriptor that modifies list of monitored events (the changelist argument is non-NULL). CAP_KQUEUE_EVENT Permit kevent(2) on a kqueue(2) descriptor that monitors events (the eventlist argument is non-NULL). CAP_EVENT is also required on file descriptors that will be monitored using kevent(2). CAP_LINKAT Permit linkat(2) and renameat(2) on the destination directory descriptor. This right includes the CAP_LOOKUP right. CAP_LISTEN Permit listen(2); not much use (generally) without CAP_BIND. CAP_LOOKUP Permit the file descriptor to be used as a starting directory for calls such as linkat(2), openat(2), and unlinkat(2). CAP_MAC_GET Permit mac_get_fd(3). CAP_MAC_SET Permit mac_set_fd(3). CAP_MKDIRAT Permit mkdirat(2). This right includes the CAP_LOOKUP right. CAP_MKFIFOAT Permit mkfifoat(2). This right includes the CAP_LOOKUP right. CAP_MKNODAT Permit mknodat(2). This right includes the CAP_LOOKUP right. CAP_MMAP Permit mmap(2) with the PROT_NONE protection. CAP_MMAP_R Permit mmap(2) with the PROT_READ protection. This right includes the CAP_READ and CAP_SEEK rights. CAP_MMAP_RW An alias to CAP_MMAP_R and CAP_MMAP_W. CAP_MMAP_RWX An alias to CAP_MMAP_R, CAP_MMAP_W and CAP_MMAP_X. CAP_MMAP_RX An alias to CAP_MMAP_R and CAP_MMAP_X. CAP_MMAP_W Permit mmap(2) with the PROT_WRITE protection. This right includes the CAP_WRITE and CAP_SEEK rights. CAP_MMAP_WX An alias to CAP_MMAP_W and CAP_MMAP_X. CAP_MMAP_X Permit mmap(2) with the PROT_EXEC protection. This right includes the CAP_SEEK right. CAP_PDGETPID Permit pdgetpid(2). CAP_PDKILL Permit pdkill(2). CAP_PDWAIT Permit pdwait4(2). CAP_PEELOFF Permit sctp_peeloff(2). CAP_PREAD An alias to CAP_READ and CAP_SEEK. CAP_PWRITE An alias to CAP_SEEK and CAP_WRITE. CAP_READ Permit aio_read(2) (CAP_SEEK is also required), openat(2) with the O_RDONLY flag, read(2), readv(2), recv(2), recvfrom(2), recvmsg(2), pread(2) (CAP_SEEK is also required), preadv(2) (CAP_SEEK is also required) and related system calls. CAP_RECV An alias to CAP_READ. CAP_RENAMEAT Permit renameat(2). This right is required on the source directory descriptor. This right includes the CAP_LOOKUP right. CAP_SEEK Permit operations that seek on the file descriptor, such as lseek(2), but also required for I/O system calls that can read or write at any position in the file, such as pread(2) and pwrite(2). CAP_SEM_GETVALUE Permit sem_getvalue(3). CAP_SEM_POST Permit sem_post(3). CAP_SEM_WAIT Permit sem_wait(3) and sem_trywait(3). CAP_SEND An alias to CAP_WRITE. CAP_SETSOCKOPT Permit setsockopt(2); this controls various aspects of socket behavior and may affect binding, connecting, and other behaviors with global scope. CAP_SHUTDOWN Permit explicit shutdown(2); closing the socket will also generally shut down any connections on it. CAP_SYMLINKAT Permit symlinkat(2). This right includes the CAP_LOOKUP right. CAP_TTYHOOK Allow configuration of TTY hooks, such as snp(4), on the file descriptor. CAP_UNLINKAT Permit unlinkat(2) and renameat(2). This right is only required for renameat(2) on the destination directory descriptor if the destination object already exists and will be removed by the rename. This right includes the CAP_LOOKUP right. CAP_WRITE Allow aio_write(2), openat(2) with O_WRONLY and O_APPEND flags set, send(2), sendmsg(2), sendto(2), write(2), writev(2), pwrite(2), pwritev(2) and related system calls. For sendto(2) with a non-NULL connection address, CAP_CONNECT is also required. For openat(2) with the O_WRONLY flag, but without the O_APPEND flag, CAP_SEEK is also required. For aio_write(2), pwrite(2) and pwritev(2) CAP_SEEK is also required. SEE ALSO
accept(2), accept4(2), aio_fsync(2), aio_read(2), aio_write(2), bind(2), bindat(2), cap_enter(2), cap_fcntls_limit(2), cap_ioctls_limit(2), cap_rights_limit(2), chflagsat(2), connect(2), connectat(2), extattr_delete_fd(2), extattr_get_fd(2), extattr_list_fd(2), extattr_set_fd(2), fchflags(2), fchmod(2), fchmodat(2), fchown(2), fchownat(2), fcntl(2), fexecve(2), fhopen(2), flock(2), fpathconf(2), fstat(2), fstatat(2), fstatfs(2), fsync(2), ftruncate(2), futimes(2), getpeername(2), getsockname(2), getsockopt(2), ioctl(2), kevent(2), kqueue(2), linkat(2), listen(2), mmap(2), mq_open(2), open(2), openat(2), pdfork(2), pdgetpid(2), pdkill(2), pdwait4(2), pipe(2), poll(2), pread(2), preadv(2), pwrite(2), pwritev(2), read(2), readv(2), recv(2), recvfrom(2), recvmsg(2), renameat(2), sctp_peeloff(2), select(2), send(2), sendmsg(2), sendto(2), setsockopt(2), shm_open(2), shutdown(2), socket(2), socketpair(2), symlinkat(2), unlinkat(2), write(2), writev(2), acl_delete_fd_np(3), acl_get_fd(3), acl_get_fd_np(3), acl_set_fd(3), acl_set_fd_np(3), acl_valid_fd_np(3), mac_get_fd(3), mac_set_fd(3), sem_getvalue(3), sem_post(3), sem_trywait(3), sem_wait(3), capsicum(4), snp(4) HISTORY
Support for capabilities and capabilities mode was developed as part of the TrustedBSD Project. AUTHORS
This manual page was created by Pawel Jakub Dawidek <pawel@dawidek.net> under sponsorship from the FreeBSD Foundation based on the cap_new(2) manual page by Robert Watson <rwatson@FreeBSD.org>. BSD
January 23, 2015 BSD
Man Page