diff options
author | Roland McGrath <roland@gnu.org> | 2003-03-23 10:01:48 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 2003-03-23 10:01:48 +0000 |
commit | b910f7887bdc3c07e460c8ee25ba552c6a2249a5 (patch) | |
tree | 06271b5c9ed70bf9c3dd2a08c551a2a54c1ed302 /nptl/tst-spin2.c | |
parent | 24eaaef61dffee283b6d32328f3e5126063d9d2a (diff) | |
download | glibc-b910f7887bdc3c07e460c8ee25ba552c6a2249a5.tar.gz |
* tst-join5.c (tf1, tf2): Add a cast.
* Makeconfig (includes): Append -I$(..)nptl to this variable.
* tst-barrier2.c (do_test) [! _POSIX_THREAD_PROCESS_SHARED]:
Don't test anything.
* tst-cond4.c: Likewise.
* tst-cond6.c: Likewise.
* tst-flock2.c: Likewise.
* tst-mutex4.c: Likewise.
* tst-rwlock4.c: Likewise.
* tst-signal1.c: Likewise.
* tst-spin2.c: Likewise.
* tst-cond11.c [! _POSIX_CLOCK_SELECTION]: Likewise.
* tst-mutex4.c: Use test-skeleton.c.
* tst-spin2.c: Likewise.
* tst-sysconf.c: Likewise.
* tst-barrier2.c: Likewise.
* tst-cond4.c: Likewise.
* tst-cond6.c: Likewise.
* tst-rwlock4.c: Likewise.
* tst-unload.c: Likewise.
* tst-flock2.c (do_test): Use return instead of exit.
Diffstat (limited to 'nptl/tst-spin2.c')
-rw-r--r-- | nptl/tst-spin2.c | 44 |
1 files changed, 27 insertions, 17 deletions
diff --git a/nptl/tst-spin2.c b/nptl/tst-spin2.c index c55bc65779..84f0064c17 100644 --- a/nptl/tst-spin2.c +++ b/nptl/tst-spin2.c @@ -1,4 +1,4 @@ -/* Copyright (C) 2002 Free Software Foundation, Inc. +/* Copyright (C) 2002, 2003 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Ulrich Drepper <drepper@redhat.com>, 2002. @@ -28,9 +28,15 @@ #include <sys/wait.h> -int -main (void) +static int +do_test (void) { +#if ! _POSIX_THREAD_PROCESS_SHARED + + puts ("_POSIX_THREAD_PROCESS_SHARED not supported, test skipped"); + +#else + size_t ps = sysconf (_SC_PAGESIZE); char tmpfname[] = "/tmp/tst-spin2.XXXXXX"; char data[ps]; @@ -45,7 +51,7 @@ main (void) if (fd == -1) { printf ("cannot open temporary file: %m\n"); - exit (1); + return 1; } /* Make sure it is always removed. */ @@ -58,14 +64,14 @@ main (void) if (write (fd, data, ps) != ps) { puts ("short write"); - exit (1); + return 1; } mem = mmap (NULL, ps, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); if (mem == MAP_FAILED) { printf ("mmap failed: %m\n"); - exit (1); + return 1; } s = (pthread_spinlock_t *) (((uintptr_t) mem @@ -76,39 +82,39 @@ main (void) if (pthread_spin_init (s, PTHREAD_PROCESS_SHARED) != 0) { puts ("spin_init failed"); - exit (1); + return 1; } if (pthread_spin_lock (s) != 0) { puts ("spin_lock failed"); - exit (1); + return 1; } err = pthread_spin_trylock (s); if (err == 0) { puts ("1st spin_trylock succeeded"); - exit (1); + return 1; } else if (err != EBUSY) { puts ("1st spin_trylock didn't return EBUSY"); - exit (1); + return 1; } err = pthread_spin_unlock (s); if (err != 0) { puts ("parent: spin_unlock failed"); - exit (1); + return 1; } err = pthread_spin_trylock (s); if (err != 0) { puts ("2nd spin_trylock failed"); - exit (1); + return 1; } *p = 0; @@ -118,7 +124,7 @@ main (void) if (pid == -1) { puts ("fork failed"); - exit (1); + return 1; } else if (pid == 0) { @@ -126,13 +132,13 @@ main (void) if ((*p)++ != 0) { puts ("child: *p != 0"); - exit (1); + return 1; } if (pthread_spin_unlock (s) != 0) { puts ("child: 1st spin_unlock failed"); - exit (1); + return 1; } puts ("child done"); @@ -142,7 +148,7 @@ main (void) if (pthread_spin_lock (s) != 0) { puts ("parent: 2nd spin_lock failed"); - exit (1); + return 1; } puts ("waiting for child"); @@ -151,6 +157,10 @@ main (void) puts ("parent done"); } +#endif - exit (0); + return 0; } + +#define TEST_FUNCTION do_test () +#include "../test-skeleton.c" |