diff options
author | Philip Guenthe <guenther@cvs.openbsd.org> | 2012-04-12 14:00:23 +0000 |
---|---|---|
committer | Philip Guenthe <guenther@cvs.openbsd.org> | 2012-04-12 14:00:23 +0000 |
commit | bcc80ee02f051d35a08f455d3f34fa401882dbfc (patch) | |
tree | a654a035dae5222e687fe43ae72d70856e7f533b | |
parent | 1085047e8635095083ba5f535703469755011a1b (diff) |
rfork RIP
-rw-r--r-- | regress/sys/kern/Makefile | 3 | ||||
-rw-r--r-- | regress/sys/kern/rfork/Makefile | 10 | ||||
-rw-r--r-- | regress/sys/kern/rfork/kqueue/Makefile | 5 | ||||
-rw-r--r-- | regress/sys/kern/rfork/kqueue/kqueue.c | 50 | ||||
-rw-r--r-- | regress/sys/kern/rfork/madness/Makefile | 5 | ||||
-rw-r--r-- | regress/sys/kern/rfork/madness/madness.c | 55 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfcfdg/Makefile | 5 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfcfdg/rfcfdg.c | 38 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfmem-stack/Makefile | 5 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfmem-stack/rfmem-stack.c | 54 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfmem/Makefile | 5 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfmem/rfmem.c | 50 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfnowait/Makefile | 5 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfnowait/rfnowait.c | 32 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfsharefd/Makefile | 5 | ||||
-rw-r--r-- | regress/sys/kern/rfork/rfsharefd/rfsharefd.c | 42 |
16 files changed, 1 insertions, 368 deletions
diff --git a/regress/sys/kern/Makefile b/regress/sys/kern/Makefile index 0953ca1ad48..23e794decb6 100644 --- a/regress/sys/kern/Makefile +++ b/regress/sys/kern/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.57 2012/03/05 02:40:21 guenther Exp $ +# $OpenBSD: Makefile,v 1.58 2012/04/12 14:00:22 guenther Exp $ SUBDIR+= __syscall accept dup2 dup2_self exec_self execve exit extent SUBDIR+= fchdir @@ -10,7 +10,6 @@ SUBDIR+= main-thread-exited SUBDIR+= mmap mmap2 mmap3 mmap-fail #SUBDIR+= mquery SUBDIR+= nanosleep noexec pread preadv ptmget pwrite pwritev rcvtimeo -#SUBDIR+= rfork SUBDIR+= rlimit-file signal signal-stress sigsuspend SUBDIR+= syscall sysvmsg sysvsem SUBDIR+= sysvshm unalign unfdpass wait diff --git a/regress/sys/kern/rfork/Makefile b/regress/sys/kern/rfork/Makefile deleted file mode 100644 index 8449dcb2e0f..00000000000 --- a/regress/sys/kern/rfork/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -# $OpenBSD: Makefile,v 1.8 2010/08/04 06:06:31 guenther Exp $ - -SUBDIR=rfcfdg rfnowait rfsharefd kqueue - -# RFMEM requires something like rfork_thread() to fix up the stack -#SUBDIR=rfmem madness rfmem-stack - -install: - -.include <bsd.subdir.mk> diff --git a/regress/sys/kern/rfork/kqueue/Makefile b/regress/sys/kern/rfork/kqueue/Makefile deleted file mode 100644 index 7a3dcf68cc5..00000000000 --- a/regress/sys/kern/rfork/kqueue/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2010/08/04 06:05:26 guenther Exp $ - -PROG=kqueue - -.include <bsd.regress.mk> diff --git a/regress/sys/kern/rfork/kqueue/kqueue.c b/regress/sys/kern/rfork/kqueue/kqueue.c deleted file mode 100644 index f21fadc5798..00000000000 --- a/regress/sys/kern/rfork/kqueue/kqueue.c +++ /dev/null @@ -1,50 +0,0 @@ -/* $OpenBSD: kqueue.c,v 1.1 2010/08/04 06:05:26 guenther Exp $ */ -/* - * Written by Philip Guenther <guenther@openbsd.org>, 2010 Public Domain. - * - * Verify that having a process exit while it has knotes attached to it - * that are from a kqueue that is open in another process doesn't cause - * problems. - */ -#include <sys/param.h> -#include <sys/event.h> -#include <sys/time.h> -#include <sys/wait.h> -#include <err.h> -#include <fcntl.h> -#include <signal.h> -#include <stdio.h> -#include <stdlib.h> -#include <unistd.h> - -int -main(int argc, char *argv[]) -{ - struct kevent ev; - int status; - int kq; - - if ((kq = kqueue()) < 0) - err(1, "kqueue"); - - signal(SIGINT, SIG_IGN); - EV_SET(&ev, SIGINT, EVFILT_SIGNAL, EV_ADD|EV_ENABLE, 0, 0, 0); - - switch(rfork(RFPROC)) { - case -1: - err(1, "rfork"); - case 0: - if (kevent(kq, &ev, 1, NULL, 0, NULL)) - err(1, "kevent"); - raise(SIGINT); - _exit(0); - } - - if (wait(&status) < 0) - err(1, "wait"); - - if (!WIFEXITED(status)) - err(1, "child error"); - - return WEXITSTATUS(status) != 0; -} diff --git a/regress/sys/kern/rfork/madness/Makefile b/regress/sys/kern/rfork/madness/Makefile deleted file mode 100644 index d44f5ff2b76..00000000000 --- a/regress/sys/kern/rfork/madness/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2002/02/17 05:58:51 art Exp $ - -PROG=madness - -.include <bsd.regress.mk> diff --git a/regress/sys/kern/rfork/madness/madness.c b/regress/sys/kern/rfork/madness/madness.c deleted file mode 100644 index 7b1006bffa5..00000000000 --- a/regress/sys/kern/rfork/madness/madness.c +++ /dev/null @@ -1,55 +0,0 @@ -/* $OpenBSD: madness.c,v 1.3 2003/08/02 01:24:36 david Exp $ */ -/* - * Written by Artur Grabowski <art@openbsd.org>, 2002 Public Domain. - */ -#include <sys/param.h> -#include <stdio.h> -#include <unistd.h> -#include <signal.h> -#include <stdlib.h> -#include <err.h> - -volatile int step; - -int -main(int argc, char *argv[]) -{ - int fds[2], fd; - pid_t pid1, pid2, pid3; - - if (pipe(fds) < 0) - err(1, "pipe"); - - fd = fds[0]; - - if ((pid1 = rfork(RFPROC|RFMEM|RFFDG|RFNOWAIT)) == 0) { - char foo[1024]; - step = 1; - read(fd, foo, sizeof(foo)); - _exit(0); - } - - if ((pid2 = rfork(RFPROC|RFMEM|RFFDG|RFNOWAIT)) == 0) { - while (step < 1) - sleep(1); - sleep(1); - step = 2; - close(fd); - _exit(0); - } - if ((pid3 = rfork(RFPROC|RFMEM|RFFDG|RFNOWAIT)) == 0) { - while (step < 2) - sleep(1); - sleep(1); - step = 3; - dup2(0, fd); - _exit(0); - } - while (step < 3) - sleep(1); - sleep(1); - kill(pid1, SIGKILL); - kill(pid2, SIGKILL); - kill(pid3, SIGKILL); - return 0; -} diff --git a/regress/sys/kern/rfork/rfcfdg/Makefile b/regress/sys/kern/rfork/rfcfdg/Makefile deleted file mode 100644 index d0fd9ab703b..00000000000 --- a/regress/sys/kern/rfork/rfcfdg/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2002/02/17 05:16:41 art Exp $ - -PROG=rfcfdg - -.include <bsd.regress.mk> diff --git a/regress/sys/kern/rfork/rfcfdg/rfcfdg.c b/regress/sys/kern/rfork/rfcfdg/rfcfdg.c deleted file mode 100644 index 95fd6204368..00000000000 --- a/regress/sys/kern/rfork/rfcfdg/rfcfdg.c +++ /dev/null @@ -1,38 +0,0 @@ -/* $OpenBSD: rfcfdg.c,v 1.3 2003/07/31 21:48:09 deraadt Exp $ */ -/* - * Written by Artur Grabowski <art@openbsd.org>, 2002 Public Domain. - */ -#include <sys/param.h> -#include <sys/wait.h> -#include <unistd.h> -#include <stdio.h> -#include <stdlib.h> -#include <err.h> -#include <fcntl.h> - -int -main(int argc, char *argv[]) -{ - int status; - - /* Make sure that at least fd 0 is allocated. */ - if (open("/dev/null", O_RDONLY) < 0) - err(1, "open(/dev/null)"); - - switch(rfork(RFCFDG|RFPROC)) { - case -1: - err(1, "fork"); - case 0: - if (open("/dev/null", O_RDONLY) != 0) - _exit(1); /* pretty hard to print to stderr */ - _exit(0); - } - - if (wait(&status) < 0) - err(1, "wait"); - - if (!WIFEXITED(status)) - err(1, "child error"); - - return WEXITSTATUS(status) != 0; -} diff --git a/regress/sys/kern/rfork/rfmem-stack/Makefile b/regress/sys/kern/rfork/rfmem-stack/Makefile deleted file mode 100644 index 491df13bda7..00000000000 --- a/regress/sys/kern/rfork/rfmem-stack/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2002/02/21 21:07:11 art Exp $ - -PROG=rfmem-stack - -.include <bsd.regress.mk> diff --git a/regress/sys/kern/rfork/rfmem-stack/rfmem-stack.c b/regress/sys/kern/rfork/rfmem-stack/rfmem-stack.c deleted file mode 100644 index 29dbf7e11b4..00000000000 --- a/regress/sys/kern/rfork/rfmem-stack/rfmem-stack.c +++ /dev/null @@ -1,54 +0,0 @@ -/* $OpenBSD: rfmem-stack.c,v 1.5 2003/08/02 01:24:37 david Exp $ */ -/* - * Written by Artur Grabowski <art@openbsd.org>, 2002 Public Domain. - */ -#include <sys/param.h> -#include <sys/wait.h> -#include <sys/mman.h> - -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <unistd.h> -#include <err.h> - -#define MAGIC "inherited" - -int -main(int argc, char *argv[]) -{ - char *map, *map2; - int status; - - map = alloca(sizeof(MAGIC)); - memset(map, 0, sizeof(MAGIC)); - - map2 = alloca(sizeof(MAGIC)); - memset(map2, 0, sizeof(MAGIC)); - - switch(rfork(RFFDG|RFPROC|RFMEM)) { - case -1: - err(1, "fork"); - case 0: - memcpy(map, MAGIC, sizeof(MAGIC)); - sleep(1); - if (memcmp(map2, MAGIC, sizeof(MAGIC)) == 0) { - write(2, "child stack polluted\n", 21); - _exit(1); - } - _exit(0); - } - - memcpy(map2, MAGIC, sizeof(MAGIC)); - - if (wait(&status) < 0) - err(1, "wait"); - - if (!WIFEXITED(status)) - err(1, "child error"); - - if (memcmp(map, MAGIC, sizeof(MAGIC)) == 0) - return 1; - - return WEXITSTATUS(status) != 0; -} diff --git a/regress/sys/kern/rfork/rfmem/Makefile b/regress/sys/kern/rfork/rfmem/Makefile deleted file mode 100644 index 3e2df82ce58..00000000000 --- a/regress/sys/kern/rfork/rfmem/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2002/02/17 05:10:40 art Exp $ - -PROG=rfmem - -.include <bsd.regress.mk> diff --git a/regress/sys/kern/rfork/rfmem/rfmem.c b/regress/sys/kern/rfork/rfmem/rfmem.c deleted file mode 100644 index 84ae38d1f62..00000000000 --- a/regress/sys/kern/rfork/rfmem/rfmem.c +++ /dev/null @@ -1,50 +0,0 @@ -/* $OpenBSD: rfmem.c,v 1.4 2003/08/02 01:24:37 david Exp $ */ -/* - * Written by Artur Grabowski <art@openbsd.org>, 2002 Public Domain. - */ -#include <sys/param.h> -#include <sys/wait.h> -#include <sys/mman.h> - -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <err.h> -#include <unistd.h> - -#define MAGIC "inherited" - -int -main(int argc, char *argv[]) -{ - void *map; - int page_size; - int status; - - page_size = getpagesize(); - - if ((map = mmap(NULL, page_size, PROT_READ|PROT_WRITE, MAP_ANON, - -1, 0)) == MAP_FAILED) - err(1, "mmap"); - - memset(map, 0, sizeof(MAGIC)); - - switch(rfork(RFFDG|RFPROC|RFMEM)) { - case -1: - err(1, "fork"); - case 0: - memcpy(map, MAGIC, sizeof(MAGIC)); - _exit(0); - } - - if (wait(&status) < 0) - err(1, "wait"); - - if (!WIFEXITED(status)) - err(1, "child error"); - - if (memcmp(map, MAGIC, sizeof(MAGIC)) != 0) - return 1; - - return WEXITSTATUS(status) != 0; -} diff --git a/regress/sys/kern/rfork/rfnowait/Makefile b/regress/sys/kern/rfork/rfnowait/Makefile deleted file mode 100644 index 7f716a0315f..00000000000 --- a/regress/sys/kern/rfork/rfnowait/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2002/02/17 05:22:41 art Exp $ - -PROG=rfnowait - -.include <bsd.regress.mk> diff --git a/regress/sys/kern/rfork/rfnowait/rfnowait.c b/regress/sys/kern/rfork/rfnowait/rfnowait.c deleted file mode 100644 index 58d2421557d..00000000000 --- a/regress/sys/kern/rfork/rfnowait/rfnowait.c +++ /dev/null @@ -1,32 +0,0 @@ -/* $OpenBSD: rfnowait.c,v 1.3 2003/07/31 21:48:09 deraadt Exp $ */ -/* - * Written by Artur Grabowski <art@openbsd.org>, 2002 Public Domain. - */ -#include <sys/param.h> -#include <sys/wait.h> -#include <unistd.h> -#include <stdio.h> -#include <stdlib.h> -#include <err.h> -#include <errno.h> - -int -main(int argc, char *argv[]) -{ - int status; - - switch(rfork(RFFDG|RFNOWAIT|RFPROC)) { - case -1: - err(1, "fork"); - case 0: - _exit(0); - } - - if (wait(&status) >= 0) - errx(1, "wait returned a child?"); - - if (errno != ECHILD) - err(1, "unexpected errno (%d)"); - - return 0; -} diff --git a/regress/sys/kern/rfork/rfsharefd/Makefile b/regress/sys/kern/rfork/rfsharefd/Makefile deleted file mode 100644 index a6246575273..00000000000 --- a/regress/sys/kern/rfork/rfsharefd/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.1 2002/02/17 05:44:07 art Exp $ - -PROG=rfsharefd - -.include <bsd.regress.mk> diff --git a/regress/sys/kern/rfork/rfsharefd/rfsharefd.c b/regress/sys/kern/rfork/rfsharefd/rfsharefd.c deleted file mode 100644 index ad7c0a3f331..00000000000 --- a/regress/sys/kern/rfork/rfsharefd/rfsharefd.c +++ /dev/null @@ -1,42 +0,0 @@ -/* $OpenBSD: rfsharefd.c,v 1.3 2003/07/31 21:48:09 deraadt Exp $ */ -/* - * Written by Artur Grabowski <art@openbsd.org>, 2002 Public Domain. - */ -#include <sys/param.h> -#include <sys/wait.h> -#include <unistd.h> -#include <stdio.h> -#include <stdlib.h> -#include <err.h> -#include <fcntl.h> - -int -main(int argc, char *argv[]) -{ - int status; - int fd; - - /* Make sure that at least fd 0 is allocated. */ - if ((fd = open("/dev/null", O_RDONLY)) < 0) - err(1, "open(/dev/null)"); - - switch(rfork(RFPROC)) { - case -1: - err(1, "fork"); - case 0: - if (close(fd) < 0) - _exit(1); - _exit(0); - } - - if (wait(&status) < 0) - err(1, "wait"); - - if (!WIFEXITED(status)) - err(1, "child error"); - - if (close(fd) == 0) - errx(1, "fd 0 not closed"); - - return WEXITSTATUS(status) != 0; -} |