summaryrefslogtreecommitdiff
path: root/test/unistd/clone.c
diff options
context:
space:
mode:
authorWaldemar Brodkorb <wbx@uclibc-ng.org>2016-10-28 20:29:21 +0200
committerWaldemar Brodkorb <wbx@uclibc-ng.org>2016-10-28 20:31:55 +0200
commit99ef2719fb3d703fe38c4113cd7f5adec516dd3a (patch)
tree2c1f77cb41b60ccbf8faa77a3640491a3546b546 /test/unistd/clone.c
parent543308f6c46cf2edf8a524bc9c631e472570fe72 (diff)
test: remove test suite
The test suite is now a developed in a separate git repository. See here: http://cgit.uclibc-ng.org/cgi/cgit/uclibc-ng-test.git The test suite should be just like every other software compiled with the cross-toolchain. In the past strange problems where found when the test suite got build in the toolchain creation step.
Diffstat (limited to 'test/unistd/clone.c')
-rw-r--r--test/unistd/clone.c101
1 files changed, 0 insertions, 101 deletions
diff --git a/test/unistd/clone.c b/test/unistd/clone.c
deleted file mode 100644
index ea7e6ac64..000000000
--- a/test/unistd/clone.c
+++ /dev/null
@@ -1,101 +0,0 @@
-/* vi: set sw=4 ts=4: */
-/*
- * clone test for uClibc
- * Copyright (C) 2000-2006 by Erik Andersen <andersen@uclibc.org>
- *
- * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball.
- */
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <signal.h>
-#include <sched.h>
-#include <sys/wait.h>
-#include "clone_cruft.h"
-
-#define GOT1 (1 << 1)
-#define GOT2 (1 << 2)
-#define GOT3 (1 << 3)
-#define ALLGOT (GOT1|GOT2|GOT3)
-
-static void child_handler(int sig)
-{
- printf("I got a SIGCHLD\n");
-}
-
-static int clone_main(void *arg)
-{
- unsigned long input = (unsigned long)arg;
- int secs = (input / 10) * 4;
- printf("Clone got %lu, sleeping for %i secs\n", input, secs);
- sleep(secs);
- return input + 20;
-}
-
-int main(void)
-{
- int clone1, clone2, clone3;
- char clone1_stack[8192], clone2_stack[8192], clone3_stack[8192];
- int status, nostatus, result, wpid;
-
- signal(SIGCHLD, child_handler);
-
- if ((clone1 = do_clone(clone_main, clone1_stack, 0, (void*)11)) == -1) {
- perror("Clone 1 failed");
- exit(-1);
- }
- if ((clone2 = do_clone(clone_main, clone2_stack, 0, (void*)22)) == -1) {
- perror("Clone 2 failed");
- exit(-2);
- }
- if ((clone3 = do_clone(clone_main, clone3_stack, 0, (void*)33)) == -1) {
- perror("Clone 3 failed");
- exit(-3);
- }
-
- sleep(1);
- printf("Parent: waiting for the clones to die.\n");
- nostatus = status = 0;
- while (1) {
- if ((wpid = waitpid(clone1, &result, WNOHANG|__WCLONE)) == -1)
- nostatus |= GOT1;
- if (wpid == clone1) {
- status |= GOT1;
- printf("Clone1 gave back %i\n", WEXITSTATUS(result));
- }
-
- if ((wpid = waitpid(clone2, &result, WNOHANG|__WCLONE)) == -1)
- nostatus |= GOT2;
- if (wpid == clone2) {
- status |= GOT2;
- printf("Clone2 gave back %i\n", WEXITSTATUS(result));
- }
-
- if ((wpid = waitpid(clone3, &result, WNOHANG|__WCLONE)) == -1)
- nostatus |= GOT3;
- if (wpid == clone3) {
- status |= GOT3;
- printf("Clone3 gave back %i\n", WEXITSTATUS(result));
- }
-
- if (status == ALLGOT || nostatus == ALLGOT)
- break;
- }
-
- if (status == ALLGOT) {
- printf("Clones exited.\nGoodbye.\n");
- return EXIT_SUCCESS;
- } else {
- perror("Waiting for clones failed");
- return EXIT_FAILURE;
- }
-}
-
-/*
-Local Variables:
-c-file-style: "linux"
-c-basic-offset: 4
-tab-width: 4
-End:
-*/