summaryrefslogtreecommitdiff
path: root/regress/lib/libpthread/signal/signal.c
diff options
context:
space:
mode:
authorMarco S Hyman <marc@cvs.openbsd.org>2001-11-03 04:33:49 +0000
committerMarco S Hyman <marc@cvs.openbsd.org>2001-11-03 04:33:49 +0000
commitfda395f82481595d0a1aac47e8dc70cabe17dd7e (patch)
tree7a7035aee71205602f92d1cdc4367eb51cb40417 /regress/lib/libpthread/signal/signal.c
parent8053500a21eafa9902b1f97a6b98a4cd375818bc (diff)
Fix pthread_mutex regression test... undefined behavior does not
mean != EPERM in one test, minor changes to recursive mutex test. remove printf in signal test signal handler, run test long enough to ensure signal hander is called at least twice, reduce output. Note: running these tests over a remote console may indicate bogus falures due to console output latency. Any test that takes longer than 5 seconds to complete may be flagged as a failure.
Diffstat (limited to 'regress/lib/libpthread/signal/signal.c')
-rw-r--r--regress/lib/libpthread/signal/signal.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/regress/lib/libpthread/signal/signal.c b/regress/lib/libpthread/signal/signal.c
index effc36b7087..4955dd86f83 100644
--- a/regress/lib/libpthread/signal/signal.c
+++ b/regress/lib/libpthread/signal/signal.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: signal.c,v 1.1 2001/08/15 14:37:13 fgsch Exp $ */
+/* $OpenBSD: signal.c,v 1.2 2001/11/03 04:33:48 marc Exp $ */
/* David Leonard <d@openbsd.org>, 2001. Public Domain. */
/*
@@ -12,6 +12,8 @@
#include <signal.h>
#include "test.h"
+volatile int alarmed;
+
void *
sleeper(arg)
void *arg;
@@ -21,8 +23,7 @@ sleeper(arg)
/* Ignore all signals in this thread */
sigfillset(&mask);
CHECKe(sigprocmask(SIG_SETMASK, &mask, NULL));
-
- ASSERT(sleep(2) == 0);
+ ASSERT(sleep(3) == 0);
SUCCEED;
}
@@ -30,7 +31,7 @@ void
handler(sig)
int sig;
{
- printf("signal handler %d\n", sig);
+ alarmed = 1;
alarm(1);
signal(SIGALRM, handler);
}
@@ -44,6 +45,10 @@ main()
CHECKe(alarm(1));
CHECKr(pthread_create(&slpr, NULL, sleeper, NULL));
/* ASSERT(sleep(1) == 0); */
- for (;;)
- CHECKe(write(STDOUT_FILENO, ".", 1));
+ for (;;) {
+ if (alarmed) {
+ alarmed = 0;
+ CHECKe(write(STDOUT_FILENO, "!", 1));
+ }
+ }
}