X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/55e303ae13a4cf49d70f2294092726f2fffb9ef2..0a7de7458d150b5d4dffc935ba399be265ef0a1a:/bsd/man/man2/fork.2 diff --git a/bsd/man/man2/fork.2 b/bsd/man/man2/fork.2 index 22fbd9354..b5bb420e0 100644 --- a/bsd/man/man2/fork.2 +++ b/bsd/man/man2/fork.2 @@ -40,12 +40,13 @@ .Nm fork .Nd create a new process .Sh SYNOPSIS -.Fd #include .Fd #include .Ft pid_t -.Fn fork void +.Fo fork +.Fa void +.Fc .Sh DESCRIPTION -.Fn Fork +.Fn fork causes creation of a new process. The new process (child process) is an exact copy of the calling process (parent process) except for the following: @@ -77,35 +78,59 @@ are set to 0; see .Sh RETURN VALUES Upon successful completion, .Fn fork -returns a value -of 0 to the child process and returns the process ID of the child -process to the parent process. Otherwise, a value of -1 is returned -to the parent process, no child process is created, and the global -variable +returns a value of 0 to the child process +and returns the process ID of the child process to the parent process. +Otherwise, a value of -1 is returned to the parent process, +no child process is created, and the global variable .Va errno is set to indicate the error. .Sh ERRORS -.Fn Fork +.Fn fork will fail and no child process will be created if: .Bl -tag -width Er +.\" ========== .It Bq Er EAGAIN -The system-imposed limit on the total -number of processes under execution would be exceeded. +The system-imposed limit +on the total number of processes under execution +would be exceeded. This limit is configuration-dependent. +.\" ========== .It Bq Er EAGAIN The system-imposed limit .Dv MAXUPRC .Pq Aq Pa sys/param.h on the total number of processes under execution by a single user would be exceeded. +.\" ========== .It Bq Er ENOMEM There is insufficient swap space for the new process. .El +.Sh LEGACY SYNOPSIS +.Fd #include +.Fd #include +.Pp +The include file +.In sys/types.h +is necessary. .Sh SEE ALSO .Xr execve 2 , -.Xr wait 2 +.Xr sigaction 2 , +.Xr wait 2 , +.Xr compat 5 .Sh HISTORY A .Fn fork function call appeared in .At v6 . +.Sh CAVEATS +There are limits to what you can do in the child process. +To be totally safe you should restrict yourself to only +executing async-signal safe operations until such time +as one of the exec functions is called. All APIs, including +global data symbols, in any framework or library should be +assumed to be unsafe after a +.Fn fork +unless explicitly documented to be safe or async-signal +safe. If you need to use these frameworks in the child +process, you must exec. In this situation it is reasonable +to exec yourself. \ No newline at end of file