1996-02-23 19:56:55 +00:00
|
|
|
.\"
|
|
|
|
.\" This manual page is taken directly from Plan9, and modified to
|
|
|
|
.\" describe the actual BSD implementation. Permission for
|
|
|
|
.\" use of this page comes from Rob Pike <rob@plan9.att.com>.
|
|
|
|
.\"
|
1999-08-28 00:22:10 +00:00
|
|
|
.\" $FreeBSD$
|
1999-07-12 20:50:10 +00:00
|
|
|
.\"
|
2011-07-12 20:38:42 +00:00
|
|
|
.Dd July 12, 2011
|
1996-02-23 19:56:55 +00:00
|
|
|
.Dt RFORK 2
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm rfork
|
|
|
|
.Nd manipulate process resources
|
2000-04-21 09:42:15 +00:00
|
|
|
.Sh LIBRARY
|
|
|
|
.Lb libc
|
1996-02-23 19:56:55 +00:00
|
|
|
.Sh SYNOPSIS
|
2001-10-01 16:09:29 +00:00
|
|
|
.In unistd.h
|
2003-04-27 21:01:34 +00:00
|
|
|
.Ft pid_t
|
1996-02-23 19:56:55 +00:00
|
|
|
.Fn rfork "int flags"
|
|
|
|
.Sh DESCRIPTION
|
1997-01-12 00:38:36 +00:00
|
|
|
Forking, vforking or rforking are the only ways new processes are created.
|
1996-02-23 19:56:55 +00:00
|
|
|
The
|
|
|
|
.Fa flags
|
|
|
|
argument to
|
|
|
|
.Fn rfork
|
|
|
|
selects which resources of the
|
|
|
|
invoking process (parent) are shared
|
|
|
|
by the new process (child) or initialized to
|
|
|
|
their default values.
|
|
|
|
The resources include
|
|
|
|
the open file descriptor table (which, when shared, permits processes
|
|
|
|
to open and close files for other processes),
|
|
|
|
and open files.
|
2002-12-19 09:40:28 +00:00
|
|
|
The
|
|
|
|
.Fa flags
|
|
|
|
argument
|
1997-01-12 00:38:36 +00:00
|
|
|
is the logical OR of some subset of:
|
2003-02-23 01:47:49 +00:00
|
|
|
.Bl -tag -width ".Dv RFLINUXTHPN"
|
|
|
|
.It Dv RFPROC
|
1996-02-23 19:56:55 +00:00
|
|
|
If set a new process is created; otherwise changes affect the
|
|
|
|
current process.
|
2003-02-23 01:47:49 +00:00
|
|
|
.It Dv RFNOWAIT
|
2000-03-02 09:14:21 +00:00
|
|
|
If set, the child process will be dissociated from the parent.
|
|
|
|
Upon
|
1996-02-23 19:56:55 +00:00
|
|
|
exit the child will not leave a status for the parent to collect.
|
2001-07-15 07:53:42 +00:00
|
|
|
See
|
1996-02-23 19:56:55 +00:00
|
|
|
.Xr wait 2 .
|
2003-02-23 01:47:49 +00:00
|
|
|
.It Dv RFFDG
|
1996-02-23 19:56:55 +00:00
|
|
|
If set, the invoker's file descriptor table (see
|
2001-08-10 17:35:21 +00:00
|
|
|
.Xr intro 2 )
|
|
|
|
is copied; otherwise the two processes share a
|
1996-02-23 19:56:55 +00:00
|
|
|
single table.
|
2003-02-23 01:47:49 +00:00
|
|
|
.It Dv RFCFDG
|
1996-02-23 19:56:55 +00:00
|
|
|
If set, the new process starts with a clean file descriptor table.
|
|
|
|
Is mutually exclusive with
|
|
|
|
.Dv RFFDG .
|
2007-05-14 13:58:54 +00:00
|
|
|
.It Dv RFTHREAD
|
|
|
|
If set, the new process shares file descriptor to process leaders table
|
|
|
|
with its parent.
|
|
|
|
Only applies when neither
|
|
|
|
.Dv RFFDG
|
|
|
|
nor
|
|
|
|
.Dv RFCFDG
|
|
|
|
are set.
|
2003-02-23 01:47:49 +00:00
|
|
|
.It Dv RFMEM
|
2000-07-25 18:50:22 +00:00
|
|
|
If set, the kernel will force sharing of the entire address space,
|
2001-03-16 22:18:26 +00:00
|
|
|
typically by sharing the hardware page table directly.
|
1996-02-23 19:56:55 +00:00
|
|
|
The child
|
2000-07-25 18:50:22 +00:00
|
|
|
will thus inherit and share all the segments the parent process owns,
|
2004-07-02 23:52:20 +00:00
|
|
|
whether they are normally shareable or not.
|
|
|
|
The stack segment is
|
2000-07-25 18:50:22 +00:00
|
|
|
not split (both the parent and child return on the same stack) and thus
|
|
|
|
.Fn rfork
|
2000-07-31 05:43:43 +00:00
|
|
|
with the RFMEM flag may not generally be called directly from high level
|
|
|
|
languages including C.
|
2000-07-25 18:50:22 +00:00
|
|
|
May be set only with
|
1996-02-23 19:56:55 +00:00
|
|
|
.Dv RFPROC .
|
2000-07-31 05:43:43 +00:00
|
|
|
A helper function is provided to assist with this problem and will cause
|
2004-07-02 23:52:20 +00:00
|
|
|
the new process to run on the provided stack.
|
|
|
|
See
|
2002-12-18 09:22:32 +00:00
|
|
|
.Xr rfork_thread 3
|
2000-07-31 05:43:43 +00:00
|
|
|
for information.
|
2011-03-15 23:51:47 +00:00
|
|
|
Note that a lot of code will not run correctly in such an environment.
|
2003-02-23 01:47:49 +00:00
|
|
|
.It Dv RFSIGSHARE
|
1999-01-26 02:38:12 +00:00
|
|
|
If set, the kernel will force sharing the sigacts structure between the
|
|
|
|
child and the parent.
|
2011-07-12 20:38:42 +00:00
|
|
|
.It Dv RFTSIGZMB
|
|
|
|
If set, the kernel will deliver a specified signal to the parent
|
|
|
|
upon the child exit, instead of default SIGCHLD.
|
|
|
|
The signal number
|
|
|
|
.Dv signum
|
|
|
|
is specified by oring the
|
|
|
|
.Dv RFTSIGFLAGS(signum)
|
|
|
|
expression into
|
|
|
|
.Fa flags .
|
|
|
|
Specifying signal number 0 disables signal delivery upon the child exit.
|
2003-02-23 01:47:49 +00:00
|
|
|
.It Dv RFLINUXTHPN
|
2011-07-12 20:38:42 +00:00
|
|
|
If set, the kernel will deliver SIGUSR1 instead of SIGCHLD upon thread
|
2004-07-02 23:52:20 +00:00
|
|
|
exit for the child.
|
|
|
|
This is intended to mimic certain Linux clone behaviour.
|
1996-02-23 19:56:55 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
File descriptors in a shared file descriptor table are kept
|
|
|
|
open until either they are explicitly closed
|
|
|
|
or all processes sharing the table exit.
|
|
|
|
.Pp
|
|
|
|
If
|
|
|
|
.Dv RFPROC
|
|
|
|
is set, the
|
|
|
|
value returned in the parent process
|
|
|
|
is the process id
|
|
|
|
of the child process; the value returned in the child is zero.
|
|
|
|
Without
|
|
|
|
.Dv RFPROC ,
|
|
|
|
the return value is zero.
|
|
|
|
Process id's range from 1 to the maximum integer
|
|
|
|
.Ft ( int )
|
|
|
|
value.
|
2002-12-18 09:22:32 +00:00
|
|
|
The
|
|
|
|
.Fn rfork
|
|
|
|
system call
|
1996-02-23 19:56:55 +00:00
|
|
|
will sleep, if necessary, until required process resources are available.
|
|
|
|
.Pp
|
2002-12-18 09:22:32 +00:00
|
|
|
The
|
|
|
|
.Fn fork
|
|
|
|
system call
|
1996-02-23 19:56:55 +00:00
|
|
|
can be implemented as a call to
|
1997-09-07 04:01:27 +00:00
|
|
|
.Fn rfork "RFFDG | RFPROC"
|
2005-02-13 22:25:33 +00:00
|
|
|
but is not for backwards compatibility.
|
1997-01-12 00:38:36 +00:00
|
|
|
.Sh RETURN VALUES
|
|
|
|
Upon successful completion,
|
|
|
|
.Fn rfork
|
|
|
|
returns a value
|
|
|
|
of 0 to the child process and returns the process ID of the child
|
2004-07-02 23:52:20 +00:00
|
|
|
process to the parent process.
|
|
|
|
Otherwise, a value of -1 is returned
|
1997-01-12 00:38:36 +00:00
|
|
|
to the parent process, no child process is created, and the global
|
|
|
|
variable
|
|
|
|
.Va errno
|
|
|
|
is set to indicate the error.
|
1996-02-23 19:56:55 +00:00
|
|
|
.Sh ERRORS
|
2002-12-18 09:22:32 +00:00
|
|
|
The
|
|
|
|
.Fn rfork
|
|
|
|
system call
|
1996-02-23 19:56:55 +00:00
|
|
|
will fail and no child process will be created if:
|
2000-05-04 13:09:25 +00:00
|
|
|
.Bl -tag -width Er
|
1996-02-23 19:56:55 +00:00
|
|
|
.It Bq Er EAGAIN
|
|
|
|
The system-imposed limit on the total
|
|
|
|
number of processes under execution would be exceeded.
|
1996-09-29 17:47:46 +00:00
|
|
|
The limit is given by the
|
|
|
|
.Xr sysctl 3
|
|
|
|
MIB variable
|
|
|
|
.Dv KERN_MAXPROC .
|
2002-07-30 05:36:34 +00:00
|
|
|
(The limit is actually ten less than this
|
1996-09-29 17:47:46 +00:00
|
|
|
except for the super user).
|
1996-02-23 19:56:55 +00:00
|
|
|
.It Bq Er EAGAIN
|
1996-09-29 17:47:46 +00:00
|
|
|
The user is not the super user, and
|
|
|
|
the system-imposed limit
|
1996-02-23 19:56:55 +00:00
|
|
|
on the total number of
|
|
|
|
processes under execution by a single user would be exceeded.
|
1996-09-29 17:47:46 +00:00
|
|
|
The limit is given by the
|
|
|
|
.Xr sysctl 3
|
|
|
|
MIB variable
|
|
|
|
.Dv KERN_MAXPROCPERUID .
|
|
|
|
.It Bq Er EAGAIN
|
|
|
|
The user is not the super user, and
|
2002-12-19 09:40:28 +00:00
|
|
|
the soft resource limit corresponding to the
|
|
|
|
.Fa resource
|
|
|
|
argument
|
1996-09-29 17:47:46 +00:00
|
|
|
.Dv RLIMIT_NOFILE
|
|
|
|
would be exceeded (see
|
|
|
|
.Xr getrlimit 2 ) .
|
1996-04-18 23:36:41 +00:00
|
|
|
.It Bq Er EINVAL
|
|
|
|
Both the RFFDG and the RFCFDG flags were specified.
|
2001-12-19 00:59:54 +00:00
|
|
|
.It Bq Er EINVAL
|
|
|
|
Any flags not listed above were specified.
|
2011-07-12 20:38:42 +00:00
|
|
|
.It Bq Er EINVAL
|
|
|
|
An invalid signal number was specified.
|
1996-02-23 19:56:55 +00:00
|
|
|
.It Bq Er ENOMEM
|
|
|
|
There is insufficient swap space for the new process.
|
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr fork 2 ,
|
1997-01-20 23:23:22 +00:00
|
|
|
.Xr intro 2 ,
|
|
|
|
.Xr minherit 2 ,
|
2000-07-31 05:43:43 +00:00
|
|
|
.Xr vfork 2 ,
|
2011-03-15 23:51:47 +00:00
|
|
|
.Xr pthread_create 3 ,
|
2000-07-31 05:43:43 +00:00
|
|
|
.Xr rfork_thread 3
|
2005-01-20 09:17:07 +00:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Fn rfork
|
|
|
|
function first appeared in Plan9.
|