aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/libthread/daemonize.c1
-rw-r--r--src/libthread/thread.c32
-rw-r--r--src/libthread/threadimpl.h1
3 files changed, 22 insertions, 12 deletions
diff --git a/src/libthread/daemonize.c b/src/libthread/daemonize.c
index 286df9c9..c86f941f 100644
--- a/src/libthread/daemonize.c
+++ b/src/libthread/daemonize.c
@@ -121,7 +121,6 @@ _threadsetupdaemonize(void)
close(p[1]);
break;
case 0:
- for(i=0; i<100; i++) sched_yield();
notedisable("sys: child");
signal(SIGCHLD, SIG_DFL);
/* rfork(RFNOTEG); */
diff --git a/src/libthread/thread.c b/src/libthread/thread.c
index c07a84f3..57ffa1cb 100644
--- a/src/libthread/thread.c
+++ b/src/libthread/thread.c
@@ -281,6 +281,24 @@ procscheduler(Proc *p)
Out:
_threaddebug("scheduler exit");
+ if(p->mainproc){
+ /*
+ * Stupid bug - on Linux 2.6 and maybe elsewhere,
+ * if the main thread exits then the others keep running
+ * but the process shows up as a zombie in ps and is not
+ * attachable with ptrace. We'll just sit around pretending
+ * to be a system proc instead of exiting.
+ */
+ _threaddaemonize();
+ lock(&threadnproclock);
+ if(++threadnsysproc == threadnproc)
+ threadexitsall(p->msg);
+ p->sysproc = 1;
+ unlock(&threadnproclock);
+ for(;;)
+ sleep(1000);
+ }
+
delproc(p);
lock(&threadnproclock);
if(p->sysproc)
@@ -298,7 +316,7 @@ _threadsetsysproc(void)
{
lock(&threadnproclock);
if(++threadnsysproc == threadnproc)
- exit(0);
+ threadexitsall(nil);
unlock(&threadnproclock);
proc()->sysproc = 1;
}
@@ -576,21 +594,13 @@ main(int argc, char **argv)
_pthreadinit();
p = procalloc();
+ p->mainproc = 1;
_threadsetproc(p);
if(mainstacksize == 0)
mainstacksize = 256*1024;
_threadcreate(p, threadmainstart, nil, mainstacksize);
procscheduler(p);
- _threaddaemonize();
- /*
- * On Linux 2.6, if the main thread exits then the others
- * keep running but the process shows up as a zombie in ps
- * and is not attachable with ptrace. We'll just sit around
- * instead of exiting.
- */
- for(;;)
- sleep(1000);
- _threadpexit();
+ /* does not return */
return 0;
}
diff --git a/src/libthread/threadimpl.h b/src/libthread/threadimpl.h
index f0b55d97..d41b918b 100644
--- a/src/libthread/threadimpl.h
+++ b/src/libthread/threadimpl.h
@@ -108,6 +108,7 @@ struct Proc
Context schedcontext;
void *udata;
Jmp sigjmp;
+ int mainproc;
};
#define proc() _threadproc()