summaryrefslogtreecommitdiff
path: root/meta-openembedded/meta-networking/recipes-support/netperf/files/vfork.patch
blob: eff98bfdeec3fc7ee8bb5fd51d39bfe1f4ed02fd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
Subject: [PATCH] netperf: fix vfork/fork

Upstream-Status: Pending

Signed-off-by: Xin Ouyang <Xin.Ouyang@windriver.com>
---
 src/netserver.c |   12 ++++++++++--
 1 files changed, 10 insertions(+), 2 deletions(-)

diff --git a/src/netserver.c b/src/netserver.c
index 379a106..f6a8b09 100644
--- a/src/netserver.c
+++ b/src/netserver.c
@@ -1020,7 +1020,7 @@ process_requests()
 void
 spawn_child() {
 
-#if defined(HAVE_FORK)
+#if defined(HAVE_FORK) || defined(HAVE_VFORK)
 
   if (debug) {
     fprintf(where,
@@ -1038,7 +1038,11 @@ spawn_child() {
 
   signal(SIGCLD,SIG_IGN);
 
+#if defined(HAVE_FORK)
   switch (fork()) {
+#else
+  switch (vfork()) {
+#endif
   case -1:
     fprintf(where,
 	    "%s: fork() error %s (errno %d)\n",
@@ -1405,7 +1409,7 @@ scan_netserver_args(int argc, char *argv[]) {
 
 void
 daemonize() {
-#if defined(HAVE_FORK)
+#if defined(HAVE_FORK) || defined(HAVE_VFORK)
 
   if (debug) {
     fprintf(where,
@@ -1419,7 +1423,11 @@ daemonize() {
   fflush(stdout);
   fflush(stderr);
 
+#if defined(HAVE_FORK)
   switch (fork()) {
+#else
+  switch (vfork()) {
+#endif
   case -1:
     fprintf(stderr,
 	    "%s: fork() error %s (errno %d)\n",
-- 
1.7.1.1