vfork¶
Synopsis¶
#include <unistd.h>
pid_t vfork(void);
Status¶
Partially implemented
Conformance¶
IEEE Std 1003.1, 2004
Description¶
vfork() creates a new process; share virtual memory
The vfork() function shall be equivalent to fork(), except that the behavior is undefined if the process created by
vfork() either modifies any data other than a variable of type pid_t used to store the return value from vfork(),
or returns from the function in which vfork() was called, or calls any other function before successfully calling
_exit() or one of the exec family of functions.
Return value¶
Upon successful completion, vfork() shall return 0 to the child process and return the process ID of the child
process to the parent process. Otherwise, -1 shall be returned to the parent, no child process shall be created,
and errno shall be set to indicate the error.
Errors¶
The vfork() function shall fail if:
EAGAIN- The system-wide limit on the total number of processes under execution would be exceeded, or the system-imposed limit on the total number of processes under execution by a single user would be exceeded.ENOMEM- There is insufficient swap space for the new process.
Tests¶
Untested
Known bugs¶
None