xref: /openbsd-src/regress/lib/libpthread/switch/switch.c (revision a28daedfc357b214be5c701aa8ba8adb29a7f1c2)
1 /*	$OpenBSD: switch.c,v 1.5 2003/12/23 20:09:42 miod 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 ch, count = 4;
90 	long i;
91 
92 	/* Getopt variables. */
93 	extern int optind, opterr;
94 	extern char *optarg;
95 
96 	while ((ch = getopt(argc, argv, "c:?")) != -1)
97 	  switch (ch)
98 	    {
99 	    case 'c':
100 	      count = atoi(optarg);
101 	      if ((count > 26) || (count < 2)) {
102 			  count = 2;
103 	      }
104 	      break;
105 	    case '?':
106 	      usage();
107 	      return(OK);
108 	    default:
109 	      usage();
110 	      return(NOTOK);
111 	    }
112 
113 	/* create the threads */
114 	for (i = 0; i < count; i++)
115 		CHECKr(pthread_create(&thread, NULL, new_thread,
116 		    (void*)(buf+i)));
117 
118 	/* give all threads a chance to run */
119 	sleep (2);
120 
121 	ending = 1;
122 	for (i = 0; i < count; i++)
123 		ASSERT(x[i]);	/* make sure each thread ran */
124 
125 	CHECKe(write(STDOUT_FILENO, "\n", 1));
126 	SUCCEED;
127 }
128