xref: /minix3/external/bsd/bind/dist/bin/tests/task_test.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: task_test.c,v 1.8 2014/12/10 04:37:53 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * Copyright (C) 2004, 2007, 2013, 2014  Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek  * Copyright (C) 1998-2001  Internet Software Consortium.
6*00b67f09SDavid van Moolenbroek  *
7*00b67f09SDavid van Moolenbroek  * Permission to use, copy, modify, and/or distribute this software for any
8*00b67f09SDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
9*00b67f09SDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
10*00b67f09SDavid van Moolenbroek  *
11*00b67f09SDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
12*00b67f09SDavid van Moolenbroek  * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
13*00b67f09SDavid van Moolenbroek  * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
14*00b67f09SDavid van Moolenbroek  * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
15*00b67f09SDavid van Moolenbroek  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
16*00b67f09SDavid van Moolenbroek  * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*00b67f09SDavid van Moolenbroek  * PERFORMANCE OF THIS SOFTWARE.
18*00b67f09SDavid van Moolenbroek  */
19*00b67f09SDavid van Moolenbroek 
20*00b67f09SDavid van Moolenbroek /* Id: task_test.c,v 1.51 2007/06/19 23:46:59 tbox Exp  */
21*00b67f09SDavid van Moolenbroek 
22*00b67f09SDavid van Moolenbroek #include <config.h>
23*00b67f09SDavid van Moolenbroek 
24*00b67f09SDavid van Moolenbroek #include <stdlib.h>
25*00b67f09SDavid van Moolenbroek #include <unistd.h>
26*00b67f09SDavid van Moolenbroek 
27*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
28*00b67f09SDavid van Moolenbroek #include <isc/task.h>
29*00b67f09SDavid van Moolenbroek #include <isc/time.h>
30*00b67f09SDavid van Moolenbroek #include <isc/timer.h>
31*00b67f09SDavid van Moolenbroek #include <isc/util.h>
32*00b67f09SDavid van Moolenbroek 
33*00b67f09SDavid van Moolenbroek isc_mem_t *mctx = NULL;
34*00b67f09SDavid van Moolenbroek 
35*00b67f09SDavid van Moolenbroek static void
my_callback(isc_task_t * task,isc_event_t * event)36*00b67f09SDavid van Moolenbroek my_callback(isc_task_t *task, isc_event_t *event) {
37*00b67f09SDavid van Moolenbroek 	int i, j;
38*00b67f09SDavid van Moolenbroek 	char *name = event->ev_arg;
39*00b67f09SDavid van Moolenbroek 
40*00b67f09SDavid van Moolenbroek 	j = 0;
41*00b67f09SDavid van Moolenbroek 	for (i = 0; i < 1000000; i++)
42*00b67f09SDavid van Moolenbroek 		j += 100;
43*00b67f09SDavid van Moolenbroek 	printf("task %s (%p): %d\n", name, task, j);
44*00b67f09SDavid van Moolenbroek 	isc_event_free(&event);
45*00b67f09SDavid van Moolenbroek }
46*00b67f09SDavid van Moolenbroek 
47*00b67f09SDavid van Moolenbroek static void
my_shutdown(isc_task_t * task,isc_event_t * event)48*00b67f09SDavid van Moolenbroek my_shutdown(isc_task_t *task, isc_event_t *event) {
49*00b67f09SDavid van Moolenbroek 	char *name = event->ev_arg;
50*00b67f09SDavid van Moolenbroek 
51*00b67f09SDavid van Moolenbroek 	printf("shutdown %s (%p)\n", name, task);
52*00b67f09SDavid van Moolenbroek 	isc_event_free(&event);
53*00b67f09SDavid van Moolenbroek }
54*00b67f09SDavid van Moolenbroek 
55*00b67f09SDavid van Moolenbroek static void
my_tick(isc_task_t * task,isc_event_t * event)56*00b67f09SDavid van Moolenbroek my_tick(isc_task_t *task, isc_event_t *event) {
57*00b67f09SDavid van Moolenbroek 	char *name = event->ev_arg;
58*00b67f09SDavid van Moolenbroek 
59*00b67f09SDavid van Moolenbroek 	printf("task %p tick %s\n", task, name);
60*00b67f09SDavid van Moolenbroek 	isc_event_free(&event);
61*00b67f09SDavid van Moolenbroek }
62*00b67f09SDavid van Moolenbroek 
63*00b67f09SDavid van Moolenbroek static char one[] = "1";
64*00b67f09SDavid van Moolenbroek static char two[] = "2";
65*00b67f09SDavid van Moolenbroek static char three[] = "3";
66*00b67f09SDavid van Moolenbroek static char four[] = "4";
67*00b67f09SDavid van Moolenbroek static char foo[] = "foo";
68*00b67f09SDavid van Moolenbroek static char bar[] = "bar";
69*00b67f09SDavid van Moolenbroek 
70*00b67f09SDavid van Moolenbroek int
main(int argc,char * argv[])71*00b67f09SDavid van Moolenbroek main(int argc, char *argv[]) {
72*00b67f09SDavid van Moolenbroek 	isc_taskmgr_t *manager = NULL;
73*00b67f09SDavid van Moolenbroek 	isc_task_t *t1 = NULL, *t2 = NULL;
74*00b67f09SDavid van Moolenbroek 	isc_task_t *t3 = NULL, *t4 = NULL;
75*00b67f09SDavid van Moolenbroek 	isc_event_t *event;
76*00b67f09SDavid van Moolenbroek 	unsigned int workers;
77*00b67f09SDavid van Moolenbroek 	isc_timermgr_t *timgr;
78*00b67f09SDavid van Moolenbroek 	isc_timer_t *ti1, *ti2;
79*00b67f09SDavid van Moolenbroek 	struct isc_interval interval;
80*00b67f09SDavid van Moolenbroek 
81*00b67f09SDavid van Moolenbroek 	if (argc > 1) {
82*00b67f09SDavid van Moolenbroek 		workers = atoi(argv[1]);
83*00b67f09SDavid van Moolenbroek 		if (workers < 1)
84*00b67f09SDavid van Moolenbroek 			workers = 1;
85*00b67f09SDavid van Moolenbroek 		if (workers > 8192)
86*00b67f09SDavid van Moolenbroek 			workers = 8192;
87*00b67f09SDavid van Moolenbroek 	} else
88*00b67f09SDavid van Moolenbroek 		workers = 2;
89*00b67f09SDavid van Moolenbroek 	printf("%d workers\n", workers);
90*00b67f09SDavid van Moolenbroek 
91*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_mem_create(0, 0, &mctx) == ISC_R_SUCCESS);
92*00b67f09SDavid van Moolenbroek 
93*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_taskmgr_create(mctx, workers, 0, &manager) ==
94*00b67f09SDavid van Moolenbroek 		      ISC_R_SUCCESS);
95*00b67f09SDavid van Moolenbroek 
96*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_task_create(manager, 0, &t1) == ISC_R_SUCCESS);
97*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_task_create(manager, 0, &t2) == ISC_R_SUCCESS);
98*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_task_create(manager, 0, &t3) == ISC_R_SUCCESS);
99*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_task_create(manager, 0, &t4) == ISC_R_SUCCESS);
100*00b67f09SDavid van Moolenbroek 
101*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_task_onshutdown(t1, my_shutdown, one) ==
102*00b67f09SDavid van Moolenbroek 		      ISC_R_SUCCESS);
103*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_task_onshutdown(t2, my_shutdown, two) ==
104*00b67f09SDavid van Moolenbroek 		      ISC_R_SUCCESS);
105*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_task_onshutdown(t3, my_shutdown, three) ==
106*00b67f09SDavid van Moolenbroek 		      ISC_R_SUCCESS);
107*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_task_onshutdown(t4, my_shutdown, four) ==
108*00b67f09SDavid van Moolenbroek 		      ISC_R_SUCCESS);
109*00b67f09SDavid van Moolenbroek 
110*00b67f09SDavid van Moolenbroek 	timgr = NULL;
111*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_timermgr_create(mctx, &timgr) == ISC_R_SUCCESS);
112*00b67f09SDavid van Moolenbroek 	ti1 = NULL;
113*00b67f09SDavid van Moolenbroek 
114*00b67f09SDavid van Moolenbroek 	isc_interval_set(&interval, 1, 0);
115*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_timer_create(timgr, isc_timertype_ticker, NULL,
116*00b67f09SDavid van Moolenbroek 				       &interval, t1, my_tick, foo, &ti1) ==
117*00b67f09SDavid van Moolenbroek 		      ISC_R_SUCCESS);
118*00b67f09SDavid van Moolenbroek 
119*00b67f09SDavid van Moolenbroek 	ti2 = NULL;
120*00b67f09SDavid van Moolenbroek 	isc_interval_set(&interval, 1, 0);
121*00b67f09SDavid van Moolenbroek 	RUNTIME_CHECK(isc_timer_create(timgr, isc_timertype_ticker, NULL,
122*00b67f09SDavid van Moolenbroek 				       &interval, t2, my_tick, bar, &ti2) ==
123*00b67f09SDavid van Moolenbroek 		      ISC_R_SUCCESS);
124*00b67f09SDavid van Moolenbroek 
125*00b67f09SDavid van Moolenbroek 	printf("task 1 = %p\n", t1);
126*00b67f09SDavid van Moolenbroek 	printf("task 2 = %p\n", t2);
127*00b67f09SDavid van Moolenbroek #ifndef WIN32
128*00b67f09SDavid van Moolenbroek 	sleep(2);
129*00b67f09SDavid van Moolenbroek #else
130*00b67f09SDavid van Moolenbroek 	Sleep(2000);
131*00b67f09SDavid van Moolenbroek #endif
132*00b67f09SDavid van Moolenbroek 
133*00b67f09SDavid van Moolenbroek 	/*
134*00b67f09SDavid van Moolenbroek 	 * Note:  (void *)1 is used as a sender here, since some compilers
135*00b67f09SDavid van Moolenbroek 	 * don't like casting a function pointer to a (void *).
136*00b67f09SDavid van Moolenbroek 	 *
137*00b67f09SDavid van Moolenbroek 	 * In a real use, it is more likely the sender would be a
138*00b67f09SDavid van Moolenbroek 	 * structure (socket, timer, task, etc) but this is just a test
139*00b67f09SDavid van Moolenbroek 	 * program.
140*00b67f09SDavid van Moolenbroek 	 */
141*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
142*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
143*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
144*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
145*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
146*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
147*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
148*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
149*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
150*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
151*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
152*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
153*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
154*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
155*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
156*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
157*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
158*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
159*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
160*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
161*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
162*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
163*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
164*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
165*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, one,
166*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
167*00b67f09SDavid van Moolenbroek 	isc_task_send(t1, &event);
168*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, two,
169*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
170*00b67f09SDavid van Moolenbroek 	isc_task_send(t2, &event);
171*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, three,
172*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
173*00b67f09SDavid van Moolenbroek 	isc_task_send(t3, &event);
174*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, four,
175*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
176*00b67f09SDavid van Moolenbroek 	isc_task_send(t4, &event);
177*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, two,
178*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
179*00b67f09SDavid van Moolenbroek 	isc_task_send(t2, &event);
180*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, three,
181*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
182*00b67f09SDavid van Moolenbroek 	isc_task_send(t3, &event);
183*00b67f09SDavid van Moolenbroek 	event = isc_event_allocate(mctx, (void *)1, 1, my_callback, four,
184*00b67f09SDavid van Moolenbroek 				   sizeof(*event));
185*00b67f09SDavid van Moolenbroek 	isc_task_send(t4, &event);
186*00b67f09SDavid van Moolenbroek 	isc_task_purgerange(t3,
187*00b67f09SDavid van Moolenbroek 			    NULL,
188*00b67f09SDavid van Moolenbroek 			    ISC_EVENTTYPE_FIRSTEVENT,
189*00b67f09SDavid van Moolenbroek 			    ISC_EVENTTYPE_LASTEVENT, NULL);
190*00b67f09SDavid van Moolenbroek 
191*00b67f09SDavid van Moolenbroek 	isc_task_detach(&t1);
192*00b67f09SDavid van Moolenbroek 	isc_task_detach(&t2);
193*00b67f09SDavid van Moolenbroek 	isc_task_detach(&t3);
194*00b67f09SDavid van Moolenbroek 	isc_task_detach(&t4);
195*00b67f09SDavid van Moolenbroek 
196*00b67f09SDavid van Moolenbroek #ifndef WIN32
197*00b67f09SDavid van Moolenbroek 	sleep(10);
198*00b67f09SDavid van Moolenbroek #else
199*00b67f09SDavid van Moolenbroek 	Sleep(10000);
200*00b67f09SDavid van Moolenbroek #endif
201*00b67f09SDavid van Moolenbroek 	printf("destroy\n");
202*00b67f09SDavid van Moolenbroek 	isc_timer_detach(&ti1);
203*00b67f09SDavid van Moolenbroek 	isc_timer_detach(&ti2);
204*00b67f09SDavid van Moolenbroek 	isc_timermgr_destroy(&timgr);
205*00b67f09SDavid van Moolenbroek 	isc_taskmgr_destroy(&manager);
206*00b67f09SDavid van Moolenbroek 	printf("destroyed\n");
207*00b67f09SDavid van Moolenbroek 
208*00b67f09SDavid van Moolenbroek 	isc_mem_stats(mctx, stdout);
209*00b67f09SDavid van Moolenbroek 	isc_mem_destroy(&mctx);
210*00b67f09SDavid van Moolenbroek 
211*00b67f09SDavid van Moolenbroek 	return (0);
212*00b67f09SDavid van Moolenbroek }
213