Commit Diff


commit - e9dbe11dbf43197892680f3b5084cd12b6dc198b
commit + 37cc72d323478b1d98ee741e3d88557d141e7767
blob - 8f4d5eee24a0e184579e4b8e415349b5ef98e6ff
blob + c6e00d19e2854b6d499e9277e2692d8dc5e4ee21
--- src/libthread/daemonize.c
+++ src/libthread/daemonize.c
@@ -38,7 +38,15 @@ child(void)
 		raise(WTERMSIG(status));
 		_exit(98);	/* not reached */
 	}
-	fprint(2, "%s: wait pid %d status 0x%ux\n", pid, status);
+	if(WIFSTOPPED(status)){
+		fprint(2, "%s: wait pid %d stopped\n", argv0, pid);
+		return;
+	}
+	if(WIFCONTINUED(status)){
+		fprint(2, "%s: wait pid %d continued\n", argv0, pid);
+		return;
+	}
+	fprint(2, "%s: wait pid %d status 0x%ux\n", argv0, pid, status);
 	_exit(99);
 }
 
blob - 550cc0568c6673bd22acb4a70f0fd905a3c07afc
blob + 2b6d1e3748d8dafb92eb2a0bcb63af78d92a1d56
--- src/libthread/thread.c
+++ src/libthread/thread.c
@@ -112,12 +112,19 @@ threadalloc(void (*fn)(void*), void *arg, uint stack)
 	sigprocmask(SIG_BLOCK, &zero, &t->context.uc.uc_sigmask);
 
 	/* must initialize with current context */
-	getcontext(&t->context.uc);
+	if(getcontext(&t->context.uc) < 0)
+		sysfatal("threadalloc getcontext: %r");
 
 	/* call makecontext to do the real work. */
 	/* leave a few words open on both ends */
 	t->context.uc.uc_stack.ss_sp = t->stk+8;
 	t->context.uc.uc_stack.ss_size = t->stksize-64;
+#ifdef __sun__		/* sigh */
+	/* can avoid this with __MAKECONTEXT_V2_SOURCE but only on SunOS 5.9 */
+	t->context.uc_stack.ss_sp = 
+		(char*)t->context.uc_stack.ss_sp
+		+t->context.uc_stack.ss_size;
+#endif
 	makecontext(&t->context.uc, (void(*)())threadstart, 1, t);
 
 	return t;