summaryrefslogtreecommitdiff
path: root/sys/kern/kern_fork.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/kern/kern_fork.c')
-rw-r--r--sys/kern/kern_fork.c42
1 files changed, 0 insertions, 42 deletions
diff --git a/sys/kern/kern_fork.c b/sys/kern/kern_fork.c
index 6feeee2..2755ea0 100644
--- a/sys/kern/kern_fork.c
+++ b/sys/kern/kern_fork.c
@@ -29,47 +29,5 @@
#include <sys/types.h>
#include <sys/proc.h>
-#include <sys/errno.h>
-#include <sys/sched.h>
-#include <sys/signal.h>
-#include <vm/dynalloc.h>
-#include <string.h>
-static size_t nthreads = 0;
-/*
- * Fork1 - fork and direct a thread to 'ip'
- *
- * @cur: Current process.
- * @flags: Flags to set.
- * @ip: Location for new thread to start at.
- * @newprocp: Will contain new thread if not NULL.
- */
-int
-fork1(struct proc *cur, int flags, void(*ip)(void), struct proc **newprocp)
-{
- struct proc *newproc;
- int status = 0;
-
- newproc = dynalloc(sizeof(*newproc));
- if (newproc == NULL)
- return -ENOMEM;
-
- memset(newproc, 0, sizeof(*newproc));
- status = md_fork(newproc, cur, (uintptr_t)ip);
- if (status != 0)
- goto done;
-
- /* Set proc output if we can */
- if (newprocp != NULL)
- *newprocp = newproc;
-
- newproc->pid = ++nthreads;
- signals_init(newproc);
- sched_enqueue_td(newproc);
-done:
- if (status != 0)
- dynfree(newproc);
-
- return status;
-}