aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/libthread/test/rdaemon.c96
-rw-r--r--src/libthread/test/tdaemon.c9
-rw-r--r--src/libthread/test/texit.c18
-rw-r--r--src/libthread/test/tprimes.c8
-rw-r--r--src/libthread/test/tspawnloop.c2
5 files changed, 130 insertions, 3 deletions
diff --git a/src/libthread/test/rdaemon.c b/src/libthread/test/rdaemon.c
new file mode 100644
index 00000000..dcb77279
--- /dev/null
+++ b/src/libthread/test/rdaemon.c
@@ -0,0 +1,96 @@
+#include <stdlib.h>
+#include <stdio.h>
+#include <unistd.h>
+#include <sys/wait.h>
+#include <pthread.h>
+
+#undef waitpid
+#undef pipe
+#undef wait
+
+static int sigpid;
+static void
+sigenable(int sig, int enabled)
+{
+ sigset_t mask;
+ sigemptyset(&mask);
+ sigaddset(&mask, sig);
+ sigprocmask(enabled ? SIG_UNBLOCK : SIG_BLOCK, &mask, 0);
+}
+
+static void
+child(void)
+{
+ int status, pid;
+printf("wait %d in %d\n", sigpid, getpid());
+ pid = waitpid(sigpid, &status, __WALL);
+ if(pid < 0)
+ perror("wait");
+ else if(WIFEXITED(status))
+ _exit(WEXITSTATUS(status));
+printf("pid %d if %d %d\n", pid, WIFEXITED(status), WEXITSTATUS(status));
+ _exit(97);
+}
+
+static void
+sigpass(int sig)
+{
+ if(sig == SIGCHLD){
+print("sig\n");
+ child();
+ }else
+ kill(sigpid, sig);
+}
+
+void
+_threadsetupdaemonize(void)
+{
+ int i, n, pid;
+ int p[2];
+ char buf[20];
+
+ sigpid = 1;
+
+ if(pipe(p) < 0)
+ abort();
+
+ signal(SIGCHLD, sigpass);
+ switch(pid = fork()){
+ case -1:
+ abort();
+ default:
+ close(p[1]);
+ break;
+ case 0:
+ close(p[0]);
+ return;
+ }
+
+ sigpid = pid;
+
+ read(p[0], buf, sizeof buf-1);
+print("pipe\n");
+ child();
+}
+
+void*
+sleeper(void *v)
+{
+ pthread_mutex_t m;
+ pthread_cond_t c;
+
+ pthread_mutex_init(&m, 0);
+ pthread_cond_init(&c, 0);
+ pthread_cond_wait(&c, &m);
+ return 0;
+}
+
+void
+main(int argc, char **argv)
+{
+ pthread_t pid;
+
+ _threadsetupdaemonize();
+ pthread_create(&pid, 0, sleeper, 0);
+ exit(1);
+}
diff --git a/src/libthread/test/tdaemon.c b/src/libthread/test/tdaemon.c
index 5ac9768f..d492c48b 100644
--- a/src/libthread/test/tdaemon.c
+++ b/src/libthread/test/tdaemon.c
@@ -3,9 +3,14 @@
#include <thread.h>
void
-threadmain(int argc, char **argv)
+proc(void *v)
{
- threaddaemonize();
sleep(5*1000);
print("still running\n");
}
+
+void
+threadmain(int argc, char **argv)
+{
+ proccreate(proc, nil, 32768);
+}
diff --git a/src/libthread/test/texit.c b/src/libthread/test/texit.c
new file mode 100644
index 00000000..fc2ebb52
--- /dev/null
+++ b/src/libthread/test/texit.c
@@ -0,0 +1,18 @@
+#include <u.h>
+#include <libc.h>
+#include <thread.h>
+
+void
+f(void *v)
+{
+ USED(v);
+
+ recvp(chancreate(sizeof(void*), 0));
+}
+
+void
+threadmain(int argc, char **argv)
+{
+ proccreate(f, nil, 32000);
+ exit(1);
+}
diff --git a/src/libthread/test/tprimes.c b/src/libthread/test/tprimes.c
index 8fcfa2e2..56744984 100644
--- a/src/libthread/test/tprimes.c
+++ b/src/libthread/test/tprimes.c
@@ -9,6 +9,7 @@ enum
int max = 10000;
int (*mk)(void (*fn)(void*), void *arg, uint stack);
+void printmsg(void*, char*);
void
countthread(void *v)
@@ -55,6 +56,7 @@ threadmain(int argc, char **argv)
Channel *c;
int nbuf;
+ notify(printmsg);
nbuf = 0;
mk = threadcreate;
ARGBEGIN{
@@ -79,3 +81,9 @@ threadmain(int argc, char **argv)
mk(filterthread, c, STACK);
recvp(chancreate(sizeof(void*), 0));
}
+
+void
+printmsg(void *v, char *msg)
+{
+ print("note: %s\n", msg);
+}
diff --git a/src/libthread/test/tspawnloop.c b/src/libthread/test/tspawnloop.c
index 8835267f..05636dc9 100644
--- a/src/libthread/test/tspawnloop.c
+++ b/src/libthread/test/tspawnloop.c
@@ -18,7 +18,7 @@ execproc(void *v)
args[2] = nil;
threadexec(nil, fd, args[0], args);
}
-
+
void
threadmain(int argc, char **argv)
{