diff options
author | Marco S Hyman <marc@cvs.openbsd.org> | 2002-01-08 18:55:47 +0000 |
---|---|---|
committer | Marco S Hyman <marc@cvs.openbsd.org> | 2002-01-08 18:55:47 +0000 |
commit | a4c50765d8e419c8282f7ac625d630914db21b43 (patch) | |
tree | c9508182b621f1c06b544151c6fc454ac10bac17 /regress/lib/libpthread | |
parent | 8d08a266cf5f857d030ffb88b11b86471c25ebe0 (diff) |
Better version of pcap regression test. Use mutex and conditions to
sync threads instead of timeouts. Test passes with recent fgs@
patches (not commited yet)
Diffstat (limited to 'regress/lib/libpthread')
-rw-r--r-- | regress/lib/libpthread/pcap/pcap.c | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/regress/lib/libpthread/pcap/pcap.c b/regress/lib/libpthread/pcap/pcap.c index 5c7f865e74f..7bbadf93c6f 100644 --- a/regress/lib/libpthread/pcap/pcap.c +++ b/regress/lib/libpthread/pcap/pcap.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pcap.c,v 1.3 2001/11/11 20:20:53 marc Exp $ */ +/* $OpenBSD: pcap.c,v 1.4 2002/01/08 18:55:46 marc Exp $ */ /* * Placed in the PUBLIC DOMAIN */ @@ -16,6 +16,8 @@ #define PKTCNT 3 volatile int packet_count = 0; +pthread_mutex_t dummy; +pthread_cond_t syncer; void packet_ignore(u_char *tag, const struct pcap_pkthdr *hdr, const u_char *data) @@ -30,9 +32,12 @@ pcap_thread(void *arg) pcap_t *handle; SET_NAME("pcap_thread"); + CHECKr(pthread_mutex_lock(&dummy)); handle = pcap_open_live(LOOPBACK_IF, SNAPLEN, NO_PROMISC, 0, errbuf); if (!handle) PANIC("You may need to run this test as UID 0 (root)"); + CHECKr(pthread_mutex_unlock(&dummy)); + CHECKr(pthread_cond_signal(&syncer)); ASSERT(pcap_loop(handle, PKTCNT, packet_ignore, 0) != -1); return 0; } @@ -41,10 +46,11 @@ void * ping_thread(void *arg) { SET_NAME("ping_thread"); + CHECKr(pthread_mutex_lock(&dummy)); ASSERT(system("ping -c 3 127.0.0.1") == 0); - sleep(2); - ASSERT(packet_count == 3); - SUCCEED; + CHECKr(pthread_mutex_unlock(&dummy)); + CHECKr(pthread_cond_signal(&syncer)); + return 0; } int @@ -53,10 +59,14 @@ main(int argc, char **argv) pthread_t pcap; pthread_t ping; + CHECKr(pthread_mutex_init(&dummy, NULL)); + CHECKr(pthread_cond_init(&syncer, NULL)); + CHECKr(pthread_mutex_lock(&dummy)); CHECKr(pthread_create(&pcap, NULL, pcap_thread, NULL)); - sleep(1); + CHECKr(pthread_cond_wait(&syncer, &dummy)); CHECKr(pthread_create(&ping, NULL, ping_thread, NULL)); - while (1) - ; - PANIC("while"); + CHECKr(pthread_cond_wait(&syncer, &dummy)); + CHECKr(pthread_mutex_unlock(&dummy)); + ASSERT(packet_count == 3); + SUCCEED; } |