xref: /openbsd/regress/lib/libpthread/switch/switch.c (revision db3296cf)
1 /*	$OpenBSD: switch.c,v 1.4 2003/07/31 21:48:07 deraadt Exp $	*/
2 /*
3  * Copyright (c) 1993, 1994, 1995, 1996 by Chris Provenzano and contributors,
4  * proven@mit.edu All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  * 3. All advertising materials mentioning features or use of this software
15  *    must display the following acknowledgement:
16  *	This product includes software developed by Chris Provenzano,
17  *	the University of California, Berkeley, and contributors.
18  * 4. Neither the name of Chris Provenzano, the University, nor the names of
19  *   contributors may be used to endorse or promote products derived
20  *   from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY CHRIS PROVENZANO AND CONTRIBUTORS ``AS IS'' AND
23  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25  * ARE DISCLAIMED.  IN NO EVENT SHALL CHRIS PROVENZANO, THE REGENTS OR
26  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
27  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
28  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
29  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
30  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
31  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
32  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33  */
34 
35 /* ==== test_switch.c ========================================================
36  * Copyright (c) 1993 by Chris Provenzano, proven@athena.mit.edu
37  *
38  * Description : Test context switch functionality.
39  *
40  *  1.00 93/08/04 proven
41  *      -Started coding this file.
42  */
43 
44 #include <pthread.h>
45 #include <stdio.h>
46 #include <errno.h>
47 #include <unistd.h>
48 #include <stdlib.h>
49 
50 #include "test.h"
51 
52 const char buf[] = "abcdefghijklmnopqrstuvwxyz";
53 char x[sizeof(buf)];
54 int fd = 1;
55 
56 volatile int ending = 0;
57 
58 /* ==========================================================================
59  * usage();
60  */
61 static void
62 usage(void)
63 {
64     extern char *__progname;
65     printf("usage: %s [-?] [-c count]\n", __progname);
66 	printf("count must be between 2 and 26\n");
67     errno = 0;
68 }
69 
70 static void *
71 new_thread(void *arg)
72 {
73 	int i;
74 
75 	SET_NAME("writer");
76 	while (!ending) {
77 		CHECKe(write (fd, (char *) arg, 1));
78 		x[(char *)arg - buf] = 1;
79 		for (i = 0; i < 999999; i += 1)
80 			;
81 	}
82 	return NULL;
83 }
84 
85 int
86 main(int argc, char *argv[])
87 {
88 	pthread_t thread;
89 	int count = 4;
90 	int eof = 0;
91 	long i;
92 
93 	/* Getopt variables. */
94 	extern int optind, opterr;
95 	extern char *optarg;
96 
97 	while (!eof)
98 	  switch (getopt (argc, argv, "c:d?"))
99 	    {
100 	    case EOF:
101 	      eof = 1;
102 	      break;
103 	    case 'c':
104 	      count = atoi(optarg);
105 	      if ((count > 26) || (count < 2)) {
106 			  count = 2;
107 	      }
108 	      break;
109 	    case '?':
110 	      usage();
111 	      return(OK);
112 	    default:
113 	      usage();
114 	      return(NOTOK);
115 	    }
116 
117 	/* create the threads */
118 	for (i = 0; i < count; i++)
119 		CHECKr(pthread_create(&thread, NULL, new_thread,
120 		    (void*)(buf+i)));
121 
122 	/* give all threads a chance to run */
123 	sleep (2);
124 
125 	ending = 1;
126 	for (i = 0; i < count; i++)
127 		ASSERT(x[i]);	/* make sure each thread ran */
128 
129 	CHECKe(write(STDOUT_FILENO, "\n", 1));
130 	SUCCEED;
131 }
132