xref: /openbsd-src/regress/lib/libpthread/pthread_specific/pthread_specific.c (revision dc28894af77824ad9c7a083d3753ec9b58ef8631)
1*dc28894aSguenther /*	$OpenBSD: pthread_specific.c,v 1.4 2012/02/20 02:19:15 guenther Exp $	*/
22d0554b9Swcobb 
32d0554b9Swcobb /*
42d0554b9Swcobb  * Copyright (c) 2002 CubeSoft Communications, Inc.
52d0554b9Swcobb  * All rights reserved.
62d0554b9Swcobb  *
72d0554b9Swcobb  * Redistribution and use in source and binary forms, with or without
82d0554b9Swcobb  * modification, are permitted provided that the following conditions
92d0554b9Swcobb  * are met:
102d0554b9Swcobb  * 1. Redistribution of source code must retain the above copyright
112d0554b9Swcobb  *    notice, this list of conditions and the following disclaimer.
122d0554b9Swcobb  * 2. Neither the name of CubeSoft Communications, nor the names of its
132d0554b9Swcobb  *    contributors may be used to endorse or promote products derived from
142d0554b9Swcobb  *    this software without specific prior written permission.
152d0554b9Swcobb  *
162d0554b9Swcobb  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
172d0554b9Swcobb  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
182d0554b9Swcobb  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
192d0554b9Swcobb  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
202d0554b9Swcobb  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
212d0554b9Swcobb  * DAMAGES (INCLUDING BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
222d0554b9Swcobb  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
232d0554b9Swcobb  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
242d0554b9Swcobb  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
252d0554b9Swcobb  * USE OF THIS SOFTWARE EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
262d0554b9Swcobb  */
272d0554b9Swcobb 
28*dc28894aSguenther #include <sys/types.h>
29*dc28894aSguenther #include <sys/resource.h>
302d0554b9Swcobb #include <pthread.h>
312d0554b9Swcobb #include <pthread_np.h>
322d0554b9Swcobb #include <stdio.h>
332d0554b9Swcobb #include <stdlib.h>
342d0554b9Swcobb #include <unistd.h>
352d0554b9Swcobb #include "test.h"
362d0554b9Swcobb 
372d0554b9Swcobb #define NTHREADS	128
382d0554b9Swcobb 
392d0554b9Swcobb pthread_key_t key;
402d0554b9Swcobb int destroy_run = 0;
412d0554b9Swcobb 
42db3296cfSderaadt static void *
run_thread(void * arg)432d0554b9Swcobb run_thread(void *arg)
442d0554b9Swcobb {
452d0554b9Swcobb 	int i;
462d0554b9Swcobb 
47f21051b8Smarc 	CHECKe(write(STDOUT_FILENO, ".", 1));
482d0554b9Swcobb 	for (i = 0; i < 32767; i++) {
492d0554b9Swcobb 		void *p;
502d0554b9Swcobb 
512d0554b9Swcobb 		p = pthread_getspecific(key);
522d0554b9Swcobb 		if (p == NULL) {
532d0554b9Swcobb 			CHECKr(pthread_setspecific(key, pthread_self()));
542d0554b9Swcobb 		} else {
552d0554b9Swcobb 			ASSERT(p == pthread_self());
562d0554b9Swcobb 		}
572d0554b9Swcobb 		fflush(stderr);
582d0554b9Swcobb 	}
592d0554b9Swcobb 
602d0554b9Swcobb 	return (NULL);
612d0554b9Swcobb }
622d0554b9Swcobb 
63db3296cfSderaadt static void
destroy_key(void * keyp)642d0554b9Swcobb destroy_key(void *keyp)
652d0554b9Swcobb {
662d0554b9Swcobb 	destroy_run++;
672d0554b9Swcobb }
682d0554b9Swcobb 
692d0554b9Swcobb int
main(int argc,char * argv[])70db3296cfSderaadt main(int argc, char *argv[])
712d0554b9Swcobb {
722d0554b9Swcobb 	pthread_t threads[NTHREADS];
73*dc28894aSguenther 	struct rlimit nproc;
742d0554b9Swcobb 	int i;
752d0554b9Swcobb 
76*dc28894aSguenther 	CHECKe(getrlimit(RLIMIT_NPROC, &nproc));
77*dc28894aSguenther 	nproc.rlim_cur = nproc.rlim_max;
78*dc28894aSguenther 	CHECKe(setrlimit(RLIMIT_NPROC, &nproc));
79*dc28894aSguenther 
802d0554b9Swcobb 	CHECKr(pthread_key_create(&key, destroy_key));
812d0554b9Swcobb 	for (i = 0; i < NTHREADS; i++) {
822d0554b9Swcobb 		CHECKr(pthread_create(&threads[i], NULL, run_thread, NULL));
832d0554b9Swcobb 	}
842d0554b9Swcobb 	for (i = 0; i < NTHREADS; i++) {
852d0554b9Swcobb 		CHECKr(pthread_join(threads[i], NULL));
862d0554b9Swcobb 	}
87f21051b8Smarc 	CHECKe(write(STDOUT_FILENO, "\n", 1));
882d0554b9Swcobb 
892d0554b9Swcobb 	CHECKr(pthread_key_delete(key));
902d0554b9Swcobb 
912d0554b9Swcobb 	ASSERT(destroy_run > 0);
922d0554b9Swcobb 
932d0554b9Swcobb 	SUCCEED;
942d0554b9Swcobb }
95