Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 27 Nov 2003 11:04:13 -0800
From:      Peter Wemm <peter@wemm.org>
To:        current@freebsd.org
Subject:   fork speed vs /bin/sh
Message-ID:  <20031127190413.6E8152A8FC@canning.wemm.org>

next in thread | raw e-mail | index | archive | help
I *know* I'm going to regret posting this, but if people care about
the speed of their shell, then perhaps you want to look at this:

peter@overcee[10:46am]/tmp-149> cc -O -o vforkathon.dynamic vforkathon.c
peter@overcee[10:46am]/tmp-150> cc -O -static -o vforkathon.static vforkathon.c
peter@overcee[10:47am]/tmp-151> cc -O -static -o forkathon.static forkathon.c
peter@overcee[10:47am]/tmp-152> cc -O -o forkathon.dynamic forkathon.c
peter@overcee[10:47am]/tmp-153> time ./forkathon.dynamic
0.120u 17.192s 0:17.81 97.1%    5+169k 0+0io 0pf+0w
peter@overcee[10:47am]/tmp-154> time ./forkathon.static
0.051u 5.939s 0:06.38 93.7%     15+177k 0+0io 0pf+0w
peter@overcee[10:47am]/tmp-155> time ./vforkathon.dynamic
0.015u 2.006s 0:02.30 87.3%     5+176k 0+0io 0pf+0w
peter@overcee[10:48am]/tmp-156> time ./vforkathon.static
0.022u 2.020s 0:02.34 87.1%     16+182k 0+0io 0pf+0w

What this shows is that vfork() is 3 times faster than fork() on static
binaries, and 9 times faster on dynamic binaries.  If people are
worried about a 40% slowdown, then perhaps they'd like to investigate
a speedup that works no matter whether its static or dynamic?  There is
a reason that popen(3) uses vfork().  /bin/sh should too, regardless of
whether its dynamic or static.  csh/tcsh already uses vfork() for the
same reason.

NetBSD have already taken advantage of this speedup and their /bin/sh uses
vfork().  Some enterprising individual who cares about /bin/sh speed should
check out that.  Start looking near #ifdef DO_SHAREDVFORK.

In case anybody was wondering:

peter@overcee[10:48am]/tmp-157> cat forkathon.c
#include <sys/types.h>
#include <sys/signal.h>
#include <stdio.h>

int
main(int ac, char *av[])
{
        int i;
        pid_t pid;

        for (i = 0; i < 100000; i++) {
                pid = fork();
                switch (pid) {
                case 0:
                        _exit(0);
                default:
                        waitpid(pid, NULL, 0);
                }
        }
}
peter@overcee[10:53am]/tmp-158> diff forkathon.c vforkathon.c
12c12
<               pid = fork();
---
>               pid = vfork();


Cheers,
-Peter
--
Peter Wemm - peter@wemm.org; peter@FreeBSD.org; peter@yahoo-inc.com
"All of this is for nothing if we don't go to the stars" - JMS/B5



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20031127190413.6E8152A8FC>