commit f19d56825d36b224a376b4012c7656871d9b1535
parent d407972b54c11282a62788f5d1812ac6603c4234
Author: rsc <devnull@localhost>
Date: Thu, 28 Jul 2005 12:43:41 +0000
different fix
Diffstat:
2 files changed, 12 insertions(+), 5 deletions(-)
diff --git a/src/libthread/BSD.c b/src/libthread/BSD.c
@@ -285,6 +285,9 @@ threadexitsall(char *msg)
int i, npid, mypid;
Proc *p;
+ if(msg == nil)
+ msg = "";
+
/*
* Only one guy, ever, gets to run this.
* If two guys do it, inevitably they end up
@@ -296,7 +299,9 @@ threadexitsall(char *msg)
*/
{
static Lock onelock;
- lock(&onelock);
+ if(!canlock(&onelock))
+ _exits(threadexitsmsg);
+ threadexitsmsg = msg;
}
if(msg == nil)
diff --git a/src/libthread/Linux.c b/src/libthread/Linux.c
@@ -311,6 +311,9 @@ threadexitsall(char *msg)
int i, npid, mypid;
Proc *p;
+ if(msg == nil)
+ msg = "";
+
/*
* Only one guy, ever, gets to run this.
* If two guys do it, inevitably they end up
@@ -322,14 +325,13 @@ threadexitsall(char *msg)
*/
{
static Lock onelock;
- lock(&onelock);
+ if(!canlock(&onelock))
+ _exits(threadexitsmsg);
+ threadexitsmsg = msg;
}
- if(msg == nil)
- msg = "";
mypid = getpid();
lock(&_threadprocslock);
- threadexitsmsg = msg;
npid = 0;
for(p=_threadprocs; p; p=p->next)
if(p->osprocid != mypid && p->osprocid >= 1)