1*00b67f09SDavid van Moolenbroek /* $NetBSD: t_tasks.c,v 1.7 2014/12/10 04:37:54 christos Exp $ */
2*00b67f09SDavid van Moolenbroek
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek * Copyright (C) 2004, 2005, 2007, 2009, 2011, 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: t_tasks.c,v 1.49 2011/07/27 07:45:55 marka 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 #ifdef HAVE_INTTYPES_H
27*00b67f09SDavid van Moolenbroek #include <inttypes.h> /* uintptr_t */
28*00b67f09SDavid van Moolenbroek #endif
29*00b67f09SDavid van Moolenbroek #include <isc/condition.h>
30*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
31*00b67f09SDavid van Moolenbroek #include <isc/platform.h>
32*00b67f09SDavid van Moolenbroek #include <isc/task.h>
33*00b67f09SDavid van Moolenbroek #include <isc/time.h>
34*00b67f09SDavid van Moolenbroek #include <isc/timer.h>
35*00b67f09SDavid van Moolenbroek #include <isc/util.h>
36*00b67f09SDavid van Moolenbroek
37*00b67f09SDavid van Moolenbroek #include <tests/t_api.h>
38*00b67f09SDavid van Moolenbroek
39*00b67f09SDavid van Moolenbroek
40*00b67f09SDavid van Moolenbroek #ifdef ISC_PLATFORM_USETHREADS
41*00b67f09SDavid van Moolenbroek isc_boolean_t threaded = ISC_TRUE;
42*00b67f09SDavid van Moolenbroek #else
43*00b67f09SDavid van Moolenbroek isc_boolean_t threaded = ISC_FALSE;
44*00b67f09SDavid van Moolenbroek #endif
45*00b67f09SDavid van Moolenbroek
46*00b67f09SDavid van Moolenbroek static int senders[4];
47*00b67f09SDavid van Moolenbroek
48*00b67f09SDavid van Moolenbroek static void
require_threads(void)49*00b67f09SDavid van Moolenbroek require_threads(void) {
50*00b67f09SDavid van Moolenbroek t_info("This test requires threads\n");
51*00b67f09SDavid van Moolenbroek t_result(T_THREADONLY);
52*00b67f09SDavid van Moolenbroek return;
53*00b67f09SDavid van Moolenbroek }
54*00b67f09SDavid van Moolenbroek
55*00b67f09SDavid van Moolenbroek static void
t1_callback(isc_task_t * task,isc_event_t * event)56*00b67f09SDavid van Moolenbroek t1_callback(isc_task_t *task, isc_event_t *event) {
57*00b67f09SDavid van Moolenbroek int i;
58*00b67f09SDavid van Moolenbroek int j;
59*00b67f09SDavid van Moolenbroek
60*00b67f09SDavid van Moolenbroek UNUSED(task);
61*00b67f09SDavid van Moolenbroek
62*00b67f09SDavid van Moolenbroek j = 0;
63*00b67f09SDavid van Moolenbroek
64*00b67f09SDavid van Moolenbroek for (i = 0; i < 1000000; i++)
65*00b67f09SDavid van Moolenbroek j += 100;
66*00b67f09SDavid van Moolenbroek
67*00b67f09SDavid van Moolenbroek t_info("task %s\n", (char *)event->ev_arg);
68*00b67f09SDavid van Moolenbroek isc_event_free(&event);
69*00b67f09SDavid van Moolenbroek }
70*00b67f09SDavid van Moolenbroek
71*00b67f09SDavid van Moolenbroek static void
t1_shutdown(isc_task_t * task,isc_event_t * event)72*00b67f09SDavid van Moolenbroek t1_shutdown(isc_task_t *task, isc_event_t *event) {
73*00b67f09SDavid van Moolenbroek
74*00b67f09SDavid van Moolenbroek UNUSED(task);
75*00b67f09SDavid van Moolenbroek
76*00b67f09SDavid van Moolenbroek t_info("shutdown %s\n", (char *)event->ev_arg);
77*00b67f09SDavid van Moolenbroek isc_event_free(&event);
78*00b67f09SDavid van Moolenbroek }
79*00b67f09SDavid van Moolenbroek
80*00b67f09SDavid van Moolenbroek static void
my_tick(isc_task_t * task,isc_event_t * event)81*00b67f09SDavid van Moolenbroek my_tick(isc_task_t *task, isc_event_t *event) {
82*00b67f09SDavid van Moolenbroek
83*00b67f09SDavid van Moolenbroek UNUSED(task);
84*00b67f09SDavid van Moolenbroek
85*00b67f09SDavid van Moolenbroek t_info("%s\n", (char *)event->ev_arg);
86*00b67f09SDavid van Moolenbroek isc_event_free(&event);
87*00b67f09SDavid van Moolenbroek }
88*00b67f09SDavid van Moolenbroek
89*00b67f09SDavid van Moolenbroek /*
90*00b67f09SDavid van Moolenbroek * Adapted from RTH's original task_test program
91*00b67f09SDavid van Moolenbroek */
92*00b67f09SDavid van Moolenbroek
93*00b67f09SDavid van Moolenbroek static char one[] = "1";
94*00b67f09SDavid van Moolenbroek static char two[] = "2";
95*00b67f09SDavid van Moolenbroek static char three[] = "3";
96*00b67f09SDavid van Moolenbroek static char four[] = "4";
97*00b67f09SDavid van Moolenbroek static char tick[] = "tick";
98*00b67f09SDavid van Moolenbroek static char tock[] = "tock";
99*00b67f09SDavid van Moolenbroek
100*00b67f09SDavid van Moolenbroek static int
t_tasks1(void)101*00b67f09SDavid van Moolenbroek t_tasks1(void) {
102*00b67f09SDavid van Moolenbroek char *p;
103*00b67f09SDavid van Moolenbroek isc_mem_t *mctx;
104*00b67f09SDavid van Moolenbroek isc_taskmgr_t *manager;
105*00b67f09SDavid van Moolenbroek isc_task_t *task1;
106*00b67f09SDavid van Moolenbroek isc_task_t *task2;
107*00b67f09SDavid van Moolenbroek isc_task_t *task3;
108*00b67f09SDavid van Moolenbroek isc_task_t *task4;
109*00b67f09SDavid van Moolenbroek isc_event_t *event;
110*00b67f09SDavid van Moolenbroek unsigned int workers;
111*00b67f09SDavid van Moolenbroek isc_timermgr_t *timgr;
112*00b67f09SDavid van Moolenbroek isc_timer_t *ti1;
113*00b67f09SDavid van Moolenbroek isc_timer_t *ti2;
114*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
115*00b67f09SDavid van Moolenbroek isc_time_t absolute;
116*00b67f09SDavid van Moolenbroek isc_interval_t interval;
117*00b67f09SDavid van Moolenbroek
118*00b67f09SDavid van Moolenbroek manager = NULL;
119*00b67f09SDavid van Moolenbroek task1 = NULL;
120*00b67f09SDavid van Moolenbroek task2 = NULL;
121*00b67f09SDavid van Moolenbroek task3 = NULL;
122*00b67f09SDavid van Moolenbroek task4 = NULL;
123*00b67f09SDavid van Moolenbroek mctx = NULL;
124*00b67f09SDavid van Moolenbroek
125*00b67f09SDavid van Moolenbroek workers = 2;
126*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASK_WORKERS");
127*00b67f09SDavid van Moolenbroek if (p != NULL)
128*00b67f09SDavid van Moolenbroek workers = atoi(p);
129*00b67f09SDavid van Moolenbroek if (workers < 1) {
130*00b67f09SDavid van Moolenbroek t_info("Bad config value for ISC_TASK_WORKERS, %d\n", workers);
131*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
132*00b67f09SDavid van Moolenbroek }
133*00b67f09SDavid van Moolenbroek
134*00b67f09SDavid van Moolenbroek isc_result = isc_mem_create(0, 0, &mctx);
135*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
136*00b67f09SDavid van Moolenbroek t_info("isc_mem_create failed %d\n", isc_result);
137*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
138*00b67f09SDavid van Moolenbroek }
139*00b67f09SDavid van Moolenbroek
140*00b67f09SDavid van Moolenbroek isc_result = isc_taskmgr_create(mctx, workers, 0, &manager);
141*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
142*00b67f09SDavid van Moolenbroek t_info("isc_taskmgr_create failed %d\n", isc_result);
143*00b67f09SDavid van Moolenbroek return(T_FAIL);
144*00b67f09SDavid van Moolenbroek }
145*00b67f09SDavid van Moolenbroek
146*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(manager, 0, &task1);
147*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
148*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %d\n", isc_result);
149*00b67f09SDavid van Moolenbroek return(T_FAIL);
150*00b67f09SDavid van Moolenbroek }
151*00b67f09SDavid van Moolenbroek
152*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(manager, 0, &task2);
153*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
154*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %d\n", isc_result);
155*00b67f09SDavid van Moolenbroek return(T_FAIL);
156*00b67f09SDavid van Moolenbroek }
157*00b67f09SDavid van Moolenbroek
158*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(manager, 0, &task3);
159*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
160*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %d\n", isc_result);
161*00b67f09SDavid van Moolenbroek return(T_FAIL);
162*00b67f09SDavid van Moolenbroek }
163*00b67f09SDavid van Moolenbroek
164*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(manager, 0, &task4);
165*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
166*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %d\n", isc_result);
167*00b67f09SDavid van Moolenbroek return(T_FAIL);
168*00b67f09SDavid van Moolenbroek }
169*00b67f09SDavid van Moolenbroek
170*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task1, t1_shutdown, one);
171*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
172*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown failed %d\n", isc_result);
173*00b67f09SDavid van Moolenbroek return(T_FAIL);
174*00b67f09SDavid van Moolenbroek }
175*00b67f09SDavid van Moolenbroek
176*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task2, t1_shutdown, two);
177*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
178*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown failed %d\n", isc_result);
179*00b67f09SDavid van Moolenbroek return(T_FAIL);
180*00b67f09SDavid van Moolenbroek }
181*00b67f09SDavid van Moolenbroek
182*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task3, t1_shutdown, three);
183*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
184*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown failed %d\n", isc_result);
185*00b67f09SDavid van Moolenbroek return(T_FAIL);
186*00b67f09SDavid van Moolenbroek }
187*00b67f09SDavid van Moolenbroek
188*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task4, t1_shutdown, four);
189*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
190*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown failed %d\n", isc_result);
191*00b67f09SDavid van Moolenbroek return(T_FAIL);
192*00b67f09SDavid van Moolenbroek }
193*00b67f09SDavid van Moolenbroek
194*00b67f09SDavid van Moolenbroek timgr = NULL;
195*00b67f09SDavid van Moolenbroek isc_result = isc_timermgr_create(mctx, &timgr);
196*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
197*00b67f09SDavid van Moolenbroek t_info("isc_timermgr_create %d\n", isc_result);
198*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
199*00b67f09SDavid van Moolenbroek }
200*00b67f09SDavid van Moolenbroek
201*00b67f09SDavid van Moolenbroek ti1 = NULL;
202*00b67f09SDavid van Moolenbroek isc_time_settoepoch(&absolute);
203*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 1, 0);
204*00b67f09SDavid van Moolenbroek isc_result = isc_timer_create(timgr, isc_timertype_ticker,
205*00b67f09SDavid van Moolenbroek &absolute, &interval,
206*00b67f09SDavid van Moolenbroek task1, my_tick, tick, &ti1);
207*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
208*00b67f09SDavid van Moolenbroek t_info("isc_timer_create %d\n", isc_result);
209*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
210*00b67f09SDavid van Moolenbroek }
211*00b67f09SDavid van Moolenbroek
212*00b67f09SDavid van Moolenbroek ti2 = NULL;
213*00b67f09SDavid van Moolenbroek isc_time_settoepoch(&absolute);
214*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 1, 0);
215*00b67f09SDavid van Moolenbroek isc_result = isc_timer_create(timgr, isc_timertype_ticker,
216*00b67f09SDavid van Moolenbroek &absolute, &interval,
217*00b67f09SDavid van Moolenbroek task2, my_tick, tock, &ti2);
218*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
219*00b67f09SDavid van Moolenbroek t_info("isc_timer_create %d\n", isc_result);
220*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
221*00b67f09SDavid van Moolenbroek }
222*00b67f09SDavid van Moolenbroek
223*00b67f09SDavid van Moolenbroek
224*00b67f09SDavid van Moolenbroek #ifndef WIN32
225*00b67f09SDavid van Moolenbroek sleep(2);
226*00b67f09SDavid van Moolenbroek #else
227*00b67f09SDavid van Moolenbroek Sleep(2000);
228*00b67f09SDavid van Moolenbroek #endif
229*00b67f09SDavid van Moolenbroek
230*00b67f09SDavid van Moolenbroek /*
231*00b67f09SDavid van Moolenbroek * Note: (void *)1 is used as a sender here, since some compilers
232*00b67f09SDavid van Moolenbroek * don't like casting a function pointer to a (void *).
233*00b67f09SDavid van Moolenbroek *
234*00b67f09SDavid van Moolenbroek * In a real use, it is more likely the sender would be a
235*00b67f09SDavid van Moolenbroek * structure (socket, timer, task, etc) but this is just a test
236*00b67f09SDavid van Moolenbroek * program.
237*00b67f09SDavid van Moolenbroek */
238*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
239*00b67f09SDavid van Moolenbroek sizeof(*event));
240*00b67f09SDavid van Moolenbroek if (event == NULL) {
241*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
242*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
243*00b67f09SDavid van Moolenbroek }
244*00b67f09SDavid van Moolenbroek
245*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
246*00b67f09SDavid van Moolenbroek
247*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
248*00b67f09SDavid van Moolenbroek sizeof(*event));
249*00b67f09SDavid van Moolenbroek if (event == NULL) {
250*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
251*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
252*00b67f09SDavid van Moolenbroek }
253*00b67f09SDavid van Moolenbroek
254*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
255*00b67f09SDavid van Moolenbroek
256*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
257*00b67f09SDavid van Moolenbroek sizeof(*event));
258*00b67f09SDavid van Moolenbroek if (event == NULL) {
259*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
260*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
261*00b67f09SDavid van Moolenbroek }
262*00b67f09SDavid van Moolenbroek
263*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
264*00b67f09SDavid van Moolenbroek
265*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
266*00b67f09SDavid van Moolenbroek sizeof(*event));
267*00b67f09SDavid van Moolenbroek if (event == NULL) {
268*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
269*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
270*00b67f09SDavid van Moolenbroek }
271*00b67f09SDavid van Moolenbroek
272*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
273*00b67f09SDavid van Moolenbroek
274*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
275*00b67f09SDavid van Moolenbroek sizeof(*event));
276*00b67f09SDavid van Moolenbroek if (event == NULL) {
277*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
278*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
279*00b67f09SDavid van Moolenbroek }
280*00b67f09SDavid van Moolenbroek
281*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
282*00b67f09SDavid van Moolenbroek
283*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
284*00b67f09SDavid van Moolenbroek sizeof(*event));
285*00b67f09SDavid van Moolenbroek if (event == NULL) {
286*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
287*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
288*00b67f09SDavid van Moolenbroek }
289*00b67f09SDavid van Moolenbroek
290*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
291*00b67f09SDavid van Moolenbroek
292*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
293*00b67f09SDavid van Moolenbroek sizeof(*event));
294*00b67f09SDavid van Moolenbroek if (event == NULL) {
295*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
296*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
297*00b67f09SDavid van Moolenbroek }
298*00b67f09SDavid van Moolenbroek
299*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
300*00b67f09SDavid van Moolenbroek
301*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
302*00b67f09SDavid van Moolenbroek sizeof(*event));
303*00b67f09SDavid van Moolenbroek if (event == NULL) {
304*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
305*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
306*00b67f09SDavid van Moolenbroek }
307*00b67f09SDavid van Moolenbroek
308*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
309*00b67f09SDavid van Moolenbroek
310*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, one,
311*00b67f09SDavid van Moolenbroek sizeof(*event));
312*00b67f09SDavid van Moolenbroek if (event == NULL) {
313*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
314*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
315*00b67f09SDavid van Moolenbroek }
316*00b67f09SDavid van Moolenbroek
317*00b67f09SDavid van Moolenbroek isc_task_send(task1, &event);
318*00b67f09SDavid van Moolenbroek
319*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, two,
320*00b67f09SDavid van Moolenbroek sizeof(*event));
321*00b67f09SDavid van Moolenbroek if (event == NULL) {
322*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
323*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
324*00b67f09SDavid van Moolenbroek }
325*00b67f09SDavid van Moolenbroek
326*00b67f09SDavid van Moolenbroek isc_task_send(task2, &event);
327*00b67f09SDavid van Moolenbroek
328*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, three,
329*00b67f09SDavid van Moolenbroek sizeof(*event));
330*00b67f09SDavid van Moolenbroek if (event == NULL) {
331*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
332*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
333*00b67f09SDavid van Moolenbroek }
334*00b67f09SDavid van Moolenbroek
335*00b67f09SDavid van Moolenbroek isc_task_send(task3, &event);
336*00b67f09SDavid van Moolenbroek
337*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, four,
338*00b67f09SDavid van Moolenbroek sizeof(*event));
339*00b67f09SDavid van Moolenbroek if (event == NULL) {
340*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
341*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
342*00b67f09SDavid van Moolenbroek }
343*00b67f09SDavid van Moolenbroek
344*00b67f09SDavid van Moolenbroek isc_task_send(task4, &event);
345*00b67f09SDavid van Moolenbroek
346*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, two,
347*00b67f09SDavid van Moolenbroek sizeof(*event));
348*00b67f09SDavid van Moolenbroek if (event == NULL) {
349*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
350*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
351*00b67f09SDavid van Moolenbroek }
352*00b67f09SDavid van Moolenbroek
353*00b67f09SDavid van Moolenbroek isc_task_send(task2, &event);
354*00b67f09SDavid van Moolenbroek
355*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, three,
356*00b67f09SDavid van Moolenbroek sizeof(*event));
357*00b67f09SDavid van Moolenbroek if (event == NULL) {
358*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
359*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
360*00b67f09SDavid van Moolenbroek }
361*00b67f09SDavid van Moolenbroek
362*00b67f09SDavid van Moolenbroek isc_task_send(task3, &event);
363*00b67f09SDavid van Moolenbroek
364*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, 1, t1_callback, four,
365*00b67f09SDavid van Moolenbroek sizeof(*event));
366*00b67f09SDavid van Moolenbroek if (event == NULL) {
367*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
368*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
369*00b67f09SDavid van Moolenbroek }
370*00b67f09SDavid van Moolenbroek
371*00b67f09SDavid van Moolenbroek isc_task_send(task4, &event);
372*00b67f09SDavid van Moolenbroek
373*00b67f09SDavid van Moolenbroek (void)isc_task_purge(task3, NULL, 0, 0);
374*00b67f09SDavid van Moolenbroek
375*00b67f09SDavid van Moolenbroek isc_task_detach(&task1);
376*00b67f09SDavid van Moolenbroek isc_task_detach(&task2);
377*00b67f09SDavid van Moolenbroek isc_task_detach(&task3);
378*00b67f09SDavid van Moolenbroek isc_task_detach(&task4);
379*00b67f09SDavid van Moolenbroek
380*00b67f09SDavid van Moolenbroek #ifndef WIN32
381*00b67f09SDavid van Moolenbroek sleep(10);
382*00b67f09SDavid van Moolenbroek #else
383*00b67f09SDavid van Moolenbroek Sleep(10000);
384*00b67f09SDavid van Moolenbroek #endif
385*00b67f09SDavid van Moolenbroek isc_timer_detach(&ti1);
386*00b67f09SDavid van Moolenbroek isc_timer_detach(&ti2);
387*00b67f09SDavid van Moolenbroek isc_timermgr_destroy(&timgr);
388*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&manager);
389*00b67f09SDavid van Moolenbroek
390*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
391*00b67f09SDavid van Moolenbroek return(T_PASS);
392*00b67f09SDavid van Moolenbroek }
393*00b67f09SDavid van Moolenbroek
394*00b67f09SDavid van Moolenbroek static const char *a1 = "The task subsystem can create and manage tasks";
395*00b67f09SDavid van Moolenbroek
396*00b67f09SDavid van Moolenbroek static void
t1(void)397*00b67f09SDavid van Moolenbroek t1(void) {
398*00b67f09SDavid van Moolenbroek int result;
399*00b67f09SDavid van Moolenbroek
400*00b67f09SDavid van Moolenbroek t_assert("tasks", 1, T_REQUIRED, "%s", a1);
401*00b67f09SDavid van Moolenbroek result = t_tasks1();
402*00b67f09SDavid van Moolenbroek t_result(result);
403*00b67f09SDavid van Moolenbroek }
404*00b67f09SDavid van Moolenbroek
405*00b67f09SDavid van Moolenbroek #define T2_NTASKS 10000
406*00b67f09SDavid van Moolenbroek
407*00b67f09SDavid van Moolenbroek static isc_event_t *T2_event;
408*00b67f09SDavid van Moolenbroek static isc_taskmgr_t *T2_manager;
409*00b67f09SDavid van Moolenbroek static isc_mem_t *T2_mctx;
410*00b67f09SDavid van Moolenbroek static isc_condition_t T2_cv;
411*00b67f09SDavid van Moolenbroek static isc_mutex_t T2_mx;
412*00b67f09SDavid van Moolenbroek static int T2_done;
413*00b67f09SDavid van Moolenbroek static int T2_nprobs;
414*00b67f09SDavid van Moolenbroek static int T2_nfails;
415*00b67f09SDavid van Moolenbroek static int T2_ntasks;
416*00b67f09SDavid van Moolenbroek
417*00b67f09SDavid van Moolenbroek static void
t2_shutdown(isc_task_t * task,isc_event_t * event)418*00b67f09SDavid van Moolenbroek t2_shutdown(isc_task_t *task, isc_event_t *event) {
419*00b67f09SDavid van Moolenbroek
420*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
421*00b67f09SDavid van Moolenbroek
422*00b67f09SDavid van Moolenbroek UNUSED(task);
423*00b67f09SDavid van Moolenbroek
424*00b67f09SDavid van Moolenbroek if (event->ev_arg != NULL) {
425*00b67f09SDavid van Moolenbroek isc_task_destroy((isc_task_t**) &event->ev_arg);
426*00b67f09SDavid van Moolenbroek }
427*00b67f09SDavid van Moolenbroek else {
428*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T2_mx);
429*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
430*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %d\n", isc_result);
431*00b67f09SDavid van Moolenbroek ++T2_nprobs;
432*00b67f09SDavid van Moolenbroek }
433*00b67f09SDavid van Moolenbroek
434*00b67f09SDavid van Moolenbroek T2_done = 1;
435*00b67f09SDavid van Moolenbroek
436*00b67f09SDavid van Moolenbroek isc_result = isc_condition_signal(&T2_cv);
437*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
438*00b67f09SDavid van Moolenbroek t_info("isc_condition_signal failed %d\n", isc_result);
439*00b67f09SDavid van Moolenbroek ++T2_nprobs;
440*00b67f09SDavid van Moolenbroek }
441*00b67f09SDavid van Moolenbroek
442*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T2_mx);
443*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
444*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %d\n", isc_result);
445*00b67f09SDavid van Moolenbroek ++T2_nprobs;
446*00b67f09SDavid van Moolenbroek }
447*00b67f09SDavid van Moolenbroek
448*00b67f09SDavid van Moolenbroek isc_event_free(&T2_event);
449*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&T2_manager);
450*00b67f09SDavid van Moolenbroek isc_mem_destroy(&T2_mctx);
451*00b67f09SDavid van Moolenbroek }
452*00b67f09SDavid van Moolenbroek }
453*00b67f09SDavid van Moolenbroek
454*00b67f09SDavid van Moolenbroek static void
t2_callback(isc_task_t * task,isc_event_t * event)455*00b67f09SDavid van Moolenbroek t2_callback(isc_task_t *task, isc_event_t *event) {
456*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
457*00b67f09SDavid van Moolenbroek isc_task_t *newtask;
458*00b67f09SDavid van Moolenbroek
459*00b67f09SDavid van Moolenbroek ++T2_ntasks;
460*00b67f09SDavid van Moolenbroek
461*00b67f09SDavid van Moolenbroek if (T_debug && ((T2_ntasks % 100) == 0)) {
462*00b67f09SDavid van Moolenbroek t_info("T2_ntasks %d\n", T2_ntasks);
463*00b67f09SDavid van Moolenbroek }
464*00b67f09SDavid van Moolenbroek
465*00b67f09SDavid van Moolenbroek if (event->ev_arg) {
466*00b67f09SDavid van Moolenbroek
467*00b67f09SDavid van Moolenbroek event->ev_arg = (void *)(((uintptr_t) event->ev_arg) - 1);
468*00b67f09SDavid van Moolenbroek
469*00b67f09SDavid van Moolenbroek /*
470*00b67f09SDavid van Moolenbroek * Create a new task and forward the message.
471*00b67f09SDavid van Moolenbroek */
472*00b67f09SDavid van Moolenbroek newtask = NULL;
473*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(T2_manager, 0, &newtask);
474*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
475*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %d\n", isc_result);
476*00b67f09SDavid van Moolenbroek ++T2_nfails;
477*00b67f09SDavid van Moolenbroek return;
478*00b67f09SDavid van Moolenbroek }
479*00b67f09SDavid van Moolenbroek
480*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(newtask, t2_shutdown,
481*00b67f09SDavid van Moolenbroek (void *)task);
482*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
483*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown failed %d\n",
484*00b67f09SDavid van Moolenbroek isc_result);
485*00b67f09SDavid van Moolenbroek ++T2_nfails;
486*00b67f09SDavid van Moolenbroek return;
487*00b67f09SDavid van Moolenbroek }
488*00b67f09SDavid van Moolenbroek
489*00b67f09SDavid van Moolenbroek isc_task_send(newtask, &event);
490*00b67f09SDavid van Moolenbroek } else {
491*00b67f09SDavid van Moolenbroek /*
492*00b67f09SDavid van Moolenbroek * Time to unwind, shutdown should perc back up.
493*00b67f09SDavid van Moolenbroek */
494*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
495*00b67f09SDavid van Moolenbroek }
496*00b67f09SDavid van Moolenbroek }
497*00b67f09SDavid van Moolenbroek
498*00b67f09SDavid van Moolenbroek static int
t_tasks2(void)499*00b67f09SDavid van Moolenbroek t_tasks2(void) {
500*00b67f09SDavid van Moolenbroek uintptr_t ntasks;
501*00b67f09SDavid van Moolenbroek int result;
502*00b67f09SDavid van Moolenbroek char *p;
503*00b67f09SDavid van Moolenbroek isc_event_t *event;
504*00b67f09SDavid van Moolenbroek unsigned int workers;
505*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
506*00b67f09SDavid van Moolenbroek
507*00b67f09SDavid van Moolenbroek T2_manager = NULL;
508*00b67f09SDavid van Moolenbroek T2_done = 0;
509*00b67f09SDavid van Moolenbroek T2_nprobs = 0;
510*00b67f09SDavid van Moolenbroek T2_nfails = 0;
511*00b67f09SDavid van Moolenbroek T2_ntasks = 0;
512*00b67f09SDavid van Moolenbroek
513*00b67f09SDavid van Moolenbroek workers = 2;
514*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASK_WORKERS");
515*00b67f09SDavid van Moolenbroek if (p != NULL)
516*00b67f09SDavid van Moolenbroek workers = atoi(p);
517*00b67f09SDavid van Moolenbroek if (workers < 1) {
518*00b67f09SDavid van Moolenbroek t_info("Bad config value for ISC_TASK_WORKERS, %d\n", workers);
519*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
520*00b67f09SDavid van Moolenbroek }
521*00b67f09SDavid van Moolenbroek
522*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASKS_MIN");
523*00b67f09SDavid van Moolenbroek if (p != NULL)
524*00b67f09SDavid van Moolenbroek ntasks = atoi(p);
525*00b67f09SDavid van Moolenbroek else
526*00b67f09SDavid van Moolenbroek ntasks = T2_NTASKS;
527*00b67f09SDavid van Moolenbroek if (ntasks == 0U) {
528*00b67f09SDavid van Moolenbroek t_info("Bad config value for ISC_TASKS_MIN, %lu\n",
529*00b67f09SDavid van Moolenbroek (unsigned long)ntasks);
530*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
531*00b67f09SDavid van Moolenbroek }
532*00b67f09SDavid van Moolenbroek
533*00b67f09SDavid van Moolenbroek t_info("Testing with %lu tasks\n", (unsigned long)ntasks);
534*00b67f09SDavid van Moolenbroek
535*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_init(&T2_mx);
536*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
537*00b67f09SDavid van Moolenbroek t_info("isc_mutex_init failed %d\n", isc_result);
538*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
539*00b67f09SDavid van Moolenbroek }
540*00b67f09SDavid van Moolenbroek
541*00b67f09SDavid van Moolenbroek isc_result = isc_condition_init(&T2_cv);
542*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
543*00b67f09SDavid van Moolenbroek t_info("isc_condition_init failed %d\n", isc_result);
544*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
545*00b67f09SDavid van Moolenbroek }
546*00b67f09SDavid van Moolenbroek
547*00b67f09SDavid van Moolenbroek isc_result = isc_mem_create(0, 0, &T2_mctx);
548*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
549*00b67f09SDavid van Moolenbroek t_info("isc_mem_create failed %d\n", isc_result);
550*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
551*00b67f09SDavid van Moolenbroek }
552*00b67f09SDavid van Moolenbroek
553*00b67f09SDavid van Moolenbroek isc_result = isc_taskmgr_create(T2_mctx, workers, 0, &T2_manager);
554*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
555*00b67f09SDavid van Moolenbroek t_info("isc_taskmgr_create failed %d\n", isc_result);
556*00b67f09SDavid van Moolenbroek return(T_FAIL);
557*00b67f09SDavid van Moolenbroek }
558*00b67f09SDavid van Moolenbroek
559*00b67f09SDavid van Moolenbroek T2_event = isc_event_allocate(T2_mctx, (void *)1, 1, t2_callback,
560*00b67f09SDavid van Moolenbroek (void *)ntasks, sizeof(*event));
561*00b67f09SDavid van Moolenbroek if (T2_event == NULL) {
562*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
563*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
564*00b67f09SDavid van Moolenbroek }
565*00b67f09SDavid van Moolenbroek
566*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T2_mx);
567*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
568*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %d\n", isc_result);
569*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
570*00b67f09SDavid van Moolenbroek }
571*00b67f09SDavid van Moolenbroek
572*00b67f09SDavid van Moolenbroek t2_callback(NULL, T2_event);
573*00b67f09SDavid van Moolenbroek
574*00b67f09SDavid van Moolenbroek while (T2_done == 0) {
575*00b67f09SDavid van Moolenbroek isc_result = isc_condition_wait(&T2_cv, &T2_mx);
576*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
577*00b67f09SDavid van Moolenbroek t_info("isc_condition_wait failed %d\n", isc_result);
578*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
579*00b67f09SDavid van Moolenbroek }
580*00b67f09SDavid van Moolenbroek }
581*00b67f09SDavid van Moolenbroek
582*00b67f09SDavid van Moolenbroek result = T_UNRESOLVED;
583*00b67f09SDavid van Moolenbroek
584*00b67f09SDavid van Moolenbroek if ((T2_nfails == 0) && (T2_nprobs == 0))
585*00b67f09SDavid van Moolenbroek result = T_PASS;
586*00b67f09SDavid van Moolenbroek else if (T2_nfails != 0)
587*00b67f09SDavid van Moolenbroek result = T_FAIL;
588*00b67f09SDavid van Moolenbroek
589*00b67f09SDavid van Moolenbroek return(result);
590*00b67f09SDavid van Moolenbroek }
591*00b67f09SDavid van Moolenbroek
592*00b67f09SDavid van Moolenbroek static const char *a2 = "The task subsystem can create ISC_TASKS_MIN tasks";
593*00b67f09SDavid van Moolenbroek
594*00b67f09SDavid van Moolenbroek static void
t2(void)595*00b67f09SDavid van Moolenbroek t2(void) {
596*00b67f09SDavid van Moolenbroek t_assert("tasks", 2, T_REQUIRED, "%s", a2);
597*00b67f09SDavid van Moolenbroek
598*00b67f09SDavid van Moolenbroek if (threaded)
599*00b67f09SDavid van Moolenbroek t_result(t_tasks2());
600*00b67f09SDavid van Moolenbroek else
601*00b67f09SDavid van Moolenbroek require_threads();
602*00b67f09SDavid van Moolenbroek }
603*00b67f09SDavid van Moolenbroek
604*00b67f09SDavid van Moolenbroek #define T3_NEVENTS 256
605*00b67f09SDavid van Moolenbroek
606*00b67f09SDavid van Moolenbroek static int T3_flag;
607*00b67f09SDavid van Moolenbroek static int T3_nevents;
608*00b67f09SDavid van Moolenbroek static int T3_nsdevents;
609*00b67f09SDavid van Moolenbroek static isc_mutex_t T3_mx;
610*00b67f09SDavid van Moolenbroek static isc_condition_t T3_cv;
611*00b67f09SDavid van Moolenbroek static int T3_nfails;
612*00b67f09SDavid van Moolenbroek static int T3_nprobs;
613*00b67f09SDavid van Moolenbroek
614*00b67f09SDavid van Moolenbroek static void
t3_sde1(isc_task_t * task,isc_event_t * event)615*00b67f09SDavid van Moolenbroek t3_sde1(isc_task_t *task, isc_event_t *event) {
616*00b67f09SDavid van Moolenbroek
617*00b67f09SDavid van Moolenbroek UNUSED(task);
618*00b67f09SDavid van Moolenbroek
619*00b67f09SDavid van Moolenbroek if (T3_nevents != T3_NEVENTS) {
620*00b67f09SDavid van Moolenbroek t_info("Some events were not processed\n");
621*00b67f09SDavid van Moolenbroek ++T3_nprobs;
622*00b67f09SDavid van Moolenbroek }
623*00b67f09SDavid van Moolenbroek if (T3_nsdevents == 1) {
624*00b67f09SDavid van Moolenbroek ++T3_nsdevents;
625*00b67f09SDavid van Moolenbroek } else {
626*00b67f09SDavid van Moolenbroek t_info("Shutdown events not processed in LIFO order\n");
627*00b67f09SDavid van Moolenbroek ++T3_nfails;
628*00b67f09SDavid van Moolenbroek }
629*00b67f09SDavid van Moolenbroek isc_event_free(&event);
630*00b67f09SDavid van Moolenbroek }
631*00b67f09SDavid van Moolenbroek
632*00b67f09SDavid van Moolenbroek static void
t3_sde2(isc_task_t * task,isc_event_t * event)633*00b67f09SDavid van Moolenbroek t3_sde2(isc_task_t *task, isc_event_t *event) {
634*00b67f09SDavid van Moolenbroek
635*00b67f09SDavid van Moolenbroek UNUSED(task);
636*00b67f09SDavid van Moolenbroek
637*00b67f09SDavid van Moolenbroek if (T3_nevents != T3_NEVENTS) {
638*00b67f09SDavid van Moolenbroek t_info("Some events were not processed\n");
639*00b67f09SDavid van Moolenbroek ++T3_nprobs;
640*00b67f09SDavid van Moolenbroek }
641*00b67f09SDavid van Moolenbroek if (T3_nsdevents == 0) {
642*00b67f09SDavid van Moolenbroek ++T3_nsdevents;
643*00b67f09SDavid van Moolenbroek } else {
644*00b67f09SDavid van Moolenbroek t_info("Shutdown events not processed in LIFO order\n");
645*00b67f09SDavid van Moolenbroek ++T3_nfails;
646*00b67f09SDavid van Moolenbroek }
647*00b67f09SDavid van Moolenbroek isc_event_free(&event);
648*00b67f09SDavid van Moolenbroek }
649*00b67f09SDavid van Moolenbroek
650*00b67f09SDavid van Moolenbroek static void
t3_event1(isc_task_t * task,isc_event_t * event)651*00b67f09SDavid van Moolenbroek t3_event1(isc_task_t *task, isc_event_t *event) {
652*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
653*00b67f09SDavid van Moolenbroek
654*00b67f09SDavid van Moolenbroek UNUSED(task);
655*00b67f09SDavid van Moolenbroek
656*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T3_mx);
657*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
658*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
659*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
660*00b67f09SDavid van Moolenbroek ++T3_nprobs;
661*00b67f09SDavid van Moolenbroek }
662*00b67f09SDavid van Moolenbroek while (T3_flag != 1) {
663*00b67f09SDavid van Moolenbroek (void) isc_condition_wait(&T3_cv, &T3_mx);
664*00b67f09SDavid van Moolenbroek }
665*00b67f09SDavid van Moolenbroek
666*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T3_mx);
667*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
668*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
669*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
670*00b67f09SDavid van Moolenbroek ++T3_nprobs;
671*00b67f09SDavid van Moolenbroek }
672*00b67f09SDavid van Moolenbroek isc_event_free(&event);
673*00b67f09SDavid van Moolenbroek }
674*00b67f09SDavid van Moolenbroek
675*00b67f09SDavid van Moolenbroek static void
t3_event2(isc_task_t * task,isc_event_t * event)676*00b67f09SDavid van Moolenbroek t3_event2(isc_task_t *task, isc_event_t *event) {
677*00b67f09SDavid van Moolenbroek UNUSED(task);
678*00b67f09SDavid van Moolenbroek
679*00b67f09SDavid van Moolenbroek ++T3_nevents;
680*00b67f09SDavid van Moolenbroek isc_event_free(&event);
681*00b67f09SDavid van Moolenbroek }
682*00b67f09SDavid van Moolenbroek
683*00b67f09SDavid van Moolenbroek static int
t_tasks3(void)684*00b67f09SDavid van Moolenbroek t_tasks3(void) {
685*00b67f09SDavid van Moolenbroek int cnt;
686*00b67f09SDavid van Moolenbroek int result;
687*00b67f09SDavid van Moolenbroek char *p;
688*00b67f09SDavid van Moolenbroek isc_mem_t *mctx;
689*00b67f09SDavid van Moolenbroek isc_taskmgr_t *tmgr;
690*00b67f09SDavid van Moolenbroek isc_task_t *task;
691*00b67f09SDavid van Moolenbroek unsigned int workers;
692*00b67f09SDavid van Moolenbroek isc_event_t *event;
693*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
694*00b67f09SDavid van Moolenbroek isc_eventtype_t event_type;
695*00b67f09SDavid van Moolenbroek
696*00b67f09SDavid van Moolenbroek T3_flag = 0;
697*00b67f09SDavid van Moolenbroek T3_nevents = 0;
698*00b67f09SDavid van Moolenbroek T3_nsdevents = 0;
699*00b67f09SDavid van Moolenbroek T3_nfails = 0;
700*00b67f09SDavid van Moolenbroek T3_nprobs = 0;
701*00b67f09SDavid van Moolenbroek
702*00b67f09SDavid van Moolenbroek event_type = 3;
703*00b67f09SDavid van Moolenbroek
704*00b67f09SDavid van Moolenbroek workers = 2;
705*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASK_WORKERS");
706*00b67f09SDavid van Moolenbroek if (p != NULL)
707*00b67f09SDavid van Moolenbroek workers = atoi(p);
708*00b67f09SDavid van Moolenbroek
709*00b67f09SDavid van Moolenbroek mctx = NULL;
710*00b67f09SDavid van Moolenbroek isc_result = isc_mem_create(0, 0, &mctx);
711*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
712*00b67f09SDavid van Moolenbroek t_info("isc_mem_create failed %s\n",
713*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
714*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
715*00b67f09SDavid van Moolenbroek }
716*00b67f09SDavid van Moolenbroek
717*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_init(&T3_mx);
718*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
719*00b67f09SDavid van Moolenbroek t_info("isc_mutex_init failed %s\n",
720*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
721*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
722*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
723*00b67f09SDavid van Moolenbroek }
724*00b67f09SDavid van Moolenbroek
725*00b67f09SDavid van Moolenbroek isc_result = isc_condition_init(&T3_cv);
726*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
727*00b67f09SDavid van Moolenbroek t_info("isc_condition_init failed %s\n",
728*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
729*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
730*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
731*00b67f09SDavid van Moolenbroek }
732*00b67f09SDavid van Moolenbroek
733*00b67f09SDavid van Moolenbroek tmgr = NULL;
734*00b67f09SDavid van Moolenbroek isc_result = isc_taskmgr_create(mctx, workers, 0, &tmgr);
735*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
736*00b67f09SDavid van Moolenbroek t_info("isc_taskmgr_create failed %s\n",
737*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
738*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
739*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
740*00b67f09SDavid van Moolenbroek }
741*00b67f09SDavid van Moolenbroek
742*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T3_mx);
743*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
744*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
745*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
746*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
747*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
748*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
749*00b67f09SDavid van Moolenbroek }
750*00b67f09SDavid van Moolenbroek
751*00b67f09SDavid van Moolenbroek task = NULL;
752*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(tmgr, 0, &task);
753*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
754*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %s\n",
755*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
756*00b67f09SDavid van Moolenbroek (void) isc_mutex_unlock(&T3_mx);
757*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
758*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
759*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
760*00b67f09SDavid van Moolenbroek }
761*00b67f09SDavid van Moolenbroek
762*00b67f09SDavid van Moolenbroek /*
763*00b67f09SDavid van Moolenbroek * This event causes the task to wait on T3_cv.
764*00b67f09SDavid van Moolenbroek */
765*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, &senders[1], event_type, t3_event1,
766*00b67f09SDavid van Moolenbroek NULL, sizeof(*event));
767*00b67f09SDavid van Moolenbroek if (event == NULL) {
768*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
769*00b67f09SDavid van Moolenbroek (void) isc_mutex_unlock(&T3_mx);
770*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
771*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
772*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
773*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
774*00b67f09SDavid van Moolenbroek }
775*00b67f09SDavid van Moolenbroek isc_task_send(task, &event);
776*00b67f09SDavid van Moolenbroek
777*00b67f09SDavid van Moolenbroek /*
778*00b67f09SDavid van Moolenbroek * Now we fill up the task's event queue with some events.
779*00b67f09SDavid van Moolenbroek */
780*00b67f09SDavid van Moolenbroek for (cnt = 0; cnt < T3_NEVENTS; ++cnt) {
781*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, &senders[1], event_type,
782*00b67f09SDavid van Moolenbroek t3_event2, NULL, sizeof(*event));
783*00b67f09SDavid van Moolenbroek if (event == NULL) {
784*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
785*00b67f09SDavid van Moolenbroek (void) isc_mutex_unlock(&T3_mx);
786*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
787*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
788*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
789*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
790*00b67f09SDavid van Moolenbroek }
791*00b67f09SDavid van Moolenbroek isc_task_send(task, &event);
792*00b67f09SDavid van Moolenbroek }
793*00b67f09SDavid van Moolenbroek
794*00b67f09SDavid van Moolenbroek /*
795*00b67f09SDavid van Moolenbroek * Now we register two shutdown events.
796*00b67f09SDavid van Moolenbroek */
797*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task, t3_sde1, NULL);
798*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
799*00b67f09SDavid van Moolenbroek t_info("isc_task_send failed %s\n",
800*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
801*00b67f09SDavid van Moolenbroek (void) isc_mutex_unlock(&T3_mx);
802*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
803*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
804*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
805*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
806*00b67f09SDavid van Moolenbroek }
807*00b67f09SDavid van Moolenbroek
808*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task, t3_sde2, NULL);
809*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
810*00b67f09SDavid van Moolenbroek t_info("isc_task_send failed %s\n",
811*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
812*00b67f09SDavid van Moolenbroek (void) isc_mutex_unlock(&T3_mx);
813*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
814*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
815*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
816*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
817*00b67f09SDavid van Moolenbroek }
818*00b67f09SDavid van Moolenbroek
819*00b67f09SDavid van Moolenbroek isc_task_shutdown(task);
820*00b67f09SDavid van Moolenbroek
821*00b67f09SDavid van Moolenbroek /*
822*00b67f09SDavid van Moolenbroek * Now we free the task by signaling T3_cv.
823*00b67f09SDavid van Moolenbroek */
824*00b67f09SDavid van Moolenbroek T3_flag = 1;
825*00b67f09SDavid van Moolenbroek isc_result = isc_condition_signal(&T3_cv);
826*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
827*00b67f09SDavid van Moolenbroek t_info("isc_condition_signal failed %s\n",
828*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
829*00b67f09SDavid van Moolenbroek ++T3_nprobs;
830*00b67f09SDavid van Moolenbroek }
831*00b67f09SDavid van Moolenbroek
832*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T3_mx);
833*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
834*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
835*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
836*00b67f09SDavid van Moolenbroek ++T3_nprobs;
837*00b67f09SDavid van Moolenbroek }
838*00b67f09SDavid van Moolenbroek
839*00b67f09SDavid van Moolenbroek
840*00b67f09SDavid van Moolenbroek isc_task_detach(&task);
841*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
842*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
843*00b67f09SDavid van Moolenbroek
844*00b67f09SDavid van Moolenbroek if (T3_nsdevents != 2) {
845*00b67f09SDavid van Moolenbroek t_info("T3_nsdevents == %d, expected 2\n", T3_nsdevents);
846*00b67f09SDavid van Moolenbroek ++T3_nfails;
847*00b67f09SDavid van Moolenbroek }
848*00b67f09SDavid van Moolenbroek
849*00b67f09SDavid van Moolenbroek result = T_UNRESOLVED;
850*00b67f09SDavid van Moolenbroek
851*00b67f09SDavid van Moolenbroek if (T3_nfails != 0)
852*00b67f09SDavid van Moolenbroek result = T_FAIL;
853*00b67f09SDavid van Moolenbroek else if ((T3_nfails == 0) && (T3_nprobs == 0))
854*00b67f09SDavid van Moolenbroek result = T_PASS;
855*00b67f09SDavid van Moolenbroek
856*00b67f09SDavid van Moolenbroek return(result);
857*00b67f09SDavid van Moolenbroek }
858*00b67f09SDavid van Moolenbroek
859*00b67f09SDavid van Moolenbroek static const char *a3 = "When isc_task_shutdown() is called, any shutdown "
860*00b67f09SDavid van Moolenbroek "events that have been requested via prior "
861*00b67f09SDavid van Moolenbroek "isc_task_onshutdown() calls are posted in "
862*00b67f09SDavid van Moolenbroek "LIFO order.";
863*00b67f09SDavid van Moolenbroek static void
t3(void)864*00b67f09SDavid van Moolenbroek t3(void) {
865*00b67f09SDavid van Moolenbroek t_assert("tasks", 3, T_REQUIRED, "%s", a3);
866*00b67f09SDavid van Moolenbroek
867*00b67f09SDavid van Moolenbroek if (threaded)
868*00b67f09SDavid van Moolenbroek t_result(t_tasks3());
869*00b67f09SDavid van Moolenbroek else
870*00b67f09SDavid van Moolenbroek require_threads();
871*00b67f09SDavid van Moolenbroek }
872*00b67f09SDavid van Moolenbroek
873*00b67f09SDavid van Moolenbroek static isc_mutex_t T4_mx;
874*00b67f09SDavid van Moolenbroek static isc_condition_t T4_cv;
875*00b67f09SDavid van Moolenbroek static int T4_flag;
876*00b67f09SDavid van Moolenbroek static int T4_nprobs;
877*00b67f09SDavid van Moolenbroek static int T4_nfails;
878*00b67f09SDavid van Moolenbroek
879*00b67f09SDavid van Moolenbroek static void
t4_event1(isc_task_t * task,isc_event_t * event)880*00b67f09SDavid van Moolenbroek t4_event1(isc_task_t *task, isc_event_t *event) {
881*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
882*00b67f09SDavid van Moolenbroek
883*00b67f09SDavid van Moolenbroek UNUSED(task);
884*00b67f09SDavid van Moolenbroek
885*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T4_mx);
886*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
887*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
888*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
889*00b67f09SDavid van Moolenbroek ++T4_nprobs;
890*00b67f09SDavid van Moolenbroek }
891*00b67f09SDavid van Moolenbroek while (T4_flag != 1) {
892*00b67f09SDavid van Moolenbroek (void) isc_condition_wait(&T4_cv, &T4_mx);
893*00b67f09SDavid van Moolenbroek }
894*00b67f09SDavid van Moolenbroek
895*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T4_mx);
896*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
897*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
898*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
899*00b67f09SDavid van Moolenbroek ++T4_nprobs;
900*00b67f09SDavid van Moolenbroek }
901*00b67f09SDavid van Moolenbroek isc_event_free(&event);
902*00b67f09SDavid van Moolenbroek }
903*00b67f09SDavid van Moolenbroek
904*00b67f09SDavid van Moolenbroek static void
t4_sde(isc_task_t * task,isc_event_t * event)905*00b67f09SDavid van Moolenbroek t4_sde(isc_task_t *task, isc_event_t *event) {
906*00b67f09SDavid van Moolenbroek UNUSED(task);
907*00b67f09SDavid van Moolenbroek
908*00b67f09SDavid van Moolenbroek /*
909*00b67f09SDavid van Moolenbroek * No-op.
910*00b67f09SDavid van Moolenbroek */
911*00b67f09SDavid van Moolenbroek
912*00b67f09SDavid van Moolenbroek isc_event_free(&event);
913*00b67f09SDavid van Moolenbroek }
914*00b67f09SDavid van Moolenbroek
915*00b67f09SDavid van Moolenbroek static int
t_tasks4(void)916*00b67f09SDavid van Moolenbroek t_tasks4(void) {
917*00b67f09SDavid van Moolenbroek int result;
918*00b67f09SDavid van Moolenbroek char *p;
919*00b67f09SDavid van Moolenbroek isc_mem_t *mctx;
920*00b67f09SDavid van Moolenbroek isc_taskmgr_t *tmgr;
921*00b67f09SDavid van Moolenbroek isc_task_t *task;
922*00b67f09SDavid van Moolenbroek unsigned int workers;
923*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
924*00b67f09SDavid van Moolenbroek isc_eventtype_t event_type;
925*00b67f09SDavid van Moolenbroek isc_event_t *event;
926*00b67f09SDavid van Moolenbroek
927*00b67f09SDavid van Moolenbroek T4_nprobs = 0;
928*00b67f09SDavid van Moolenbroek T4_nfails = 0;
929*00b67f09SDavid van Moolenbroek T4_flag = 0;
930*00b67f09SDavid van Moolenbroek
931*00b67f09SDavid van Moolenbroek event_type = 4;
932*00b67f09SDavid van Moolenbroek
933*00b67f09SDavid van Moolenbroek workers = 2;
934*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASK_WORKERS");
935*00b67f09SDavid van Moolenbroek if (p != NULL)
936*00b67f09SDavid van Moolenbroek workers = atoi(p);
937*00b67f09SDavid van Moolenbroek
938*00b67f09SDavid van Moolenbroek mctx = NULL;
939*00b67f09SDavid van Moolenbroek isc_result = isc_mem_create(0, 0, &mctx);
940*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
941*00b67f09SDavid van Moolenbroek t_info("isc_mem_create failed %s\n",
942*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
943*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
944*00b67f09SDavid van Moolenbroek }
945*00b67f09SDavid van Moolenbroek
946*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_init(&T4_mx);
947*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
948*00b67f09SDavid van Moolenbroek t_info("isc_mutex_init failed %s\n",
949*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
950*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
951*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
952*00b67f09SDavid van Moolenbroek }
953*00b67f09SDavid van Moolenbroek
954*00b67f09SDavid van Moolenbroek isc_result = isc_condition_init(&T4_cv);
955*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
956*00b67f09SDavid van Moolenbroek t_info("isc_condition_init failed %s\n",
957*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
958*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T4_mx);
959*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
960*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
961*00b67f09SDavid van Moolenbroek }
962*00b67f09SDavid van Moolenbroek
963*00b67f09SDavid van Moolenbroek tmgr = NULL;
964*00b67f09SDavid van Moolenbroek isc_result = isc_taskmgr_create(mctx, workers, 0, &tmgr);
965*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
966*00b67f09SDavid van Moolenbroek t_info("isc_taskmgr_create failed %s\n",
967*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
968*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T4_mx);
969*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T4_cv);
970*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
971*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
972*00b67f09SDavid van Moolenbroek }
973*00b67f09SDavid van Moolenbroek
974*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T4_mx);
975*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
976*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
977*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
978*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T4_mx);
979*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T4_cv);
980*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
981*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
982*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
983*00b67f09SDavid van Moolenbroek }
984*00b67f09SDavid van Moolenbroek
985*00b67f09SDavid van Moolenbroek task = NULL;
986*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(tmgr, 0, &task);
987*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
988*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %s\n",
989*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
990*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T4_mx);
991*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T4_cv);
992*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
993*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
994*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
995*00b67f09SDavid van Moolenbroek }
996*00b67f09SDavid van Moolenbroek
997*00b67f09SDavid van Moolenbroek /*
998*00b67f09SDavid van Moolenbroek * This event causes the task to wait on T4_cv.
999*00b67f09SDavid van Moolenbroek */
1000*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, &senders[1], event_type, t4_event1,
1001*00b67f09SDavid van Moolenbroek NULL, sizeof(*event));
1002*00b67f09SDavid van Moolenbroek if (event == NULL) {
1003*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
1004*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T4_mx);
1005*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1006*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T4_cv);
1007*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1008*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1009*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1010*00b67f09SDavid van Moolenbroek }
1011*00b67f09SDavid van Moolenbroek isc_task_send(task, &event);
1012*00b67f09SDavid van Moolenbroek
1013*00b67f09SDavid van Moolenbroek isc_task_shutdown(task);
1014*00b67f09SDavid van Moolenbroek
1015*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task, t4_sde, NULL);
1016*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SHUTTINGDOWN) {
1017*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown returned %s\n",
1018*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1019*00b67f09SDavid van Moolenbroek ++T4_nfails;
1020*00b67f09SDavid van Moolenbroek }
1021*00b67f09SDavid van Moolenbroek
1022*00b67f09SDavid van Moolenbroek /*
1023*00b67f09SDavid van Moolenbroek * Release the task.
1024*00b67f09SDavid van Moolenbroek */
1025*00b67f09SDavid van Moolenbroek T4_flag = 1;
1026*00b67f09SDavid van Moolenbroek
1027*00b67f09SDavid van Moolenbroek isc_result = isc_condition_signal(&T4_cv);
1028*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1029*00b67f09SDavid van Moolenbroek t_info("isc_condition_signal failed %s\n",
1030*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1031*00b67f09SDavid van Moolenbroek ++T4_nprobs;
1032*00b67f09SDavid van Moolenbroek }
1033*00b67f09SDavid van Moolenbroek
1034*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T4_mx);
1035*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1036*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
1037*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1038*00b67f09SDavid van Moolenbroek ++T4_nprobs;
1039*00b67f09SDavid van Moolenbroek }
1040*00b67f09SDavid van Moolenbroek
1041*00b67f09SDavid van Moolenbroek isc_task_detach(&task);
1042*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1043*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1044*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T4_cv);
1045*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T4_mx);
1046*00b67f09SDavid van Moolenbroek
1047*00b67f09SDavid van Moolenbroek result = T_UNRESOLVED;
1048*00b67f09SDavid van Moolenbroek
1049*00b67f09SDavid van Moolenbroek if (T4_nfails != 0)
1050*00b67f09SDavid van Moolenbroek result = T_FAIL;
1051*00b67f09SDavid van Moolenbroek else if ((T4_nfails == 0) && (T4_nprobs == 0))
1052*00b67f09SDavid van Moolenbroek result = T_PASS;
1053*00b67f09SDavid van Moolenbroek
1054*00b67f09SDavid van Moolenbroek return(result);
1055*00b67f09SDavid van Moolenbroek }
1056*00b67f09SDavid van Moolenbroek
1057*00b67f09SDavid van Moolenbroek static const char *a4 =
1058*00b67f09SDavid van Moolenbroek "After isc_task_shutdown() has been called, any call to "
1059*00b67f09SDavid van Moolenbroek "isc_task_onshutdown() will return ISC_R_SHUTTINGDOWN.";
1060*00b67f09SDavid van Moolenbroek
1061*00b67f09SDavid van Moolenbroek static void
t4(void)1062*00b67f09SDavid van Moolenbroek t4(void) {
1063*00b67f09SDavid van Moolenbroek t_assert("tasks", 4, T_REQUIRED, "%s", a4);
1064*00b67f09SDavid van Moolenbroek
1065*00b67f09SDavid van Moolenbroek if (threaded)
1066*00b67f09SDavid van Moolenbroek t_result(t_tasks4());
1067*00b67f09SDavid van Moolenbroek else
1068*00b67f09SDavid van Moolenbroek require_threads();
1069*00b67f09SDavid van Moolenbroek }
1070*00b67f09SDavid van Moolenbroek
1071*00b67f09SDavid van Moolenbroek static int T7_nprobs;
1072*00b67f09SDavid van Moolenbroek static int T7_eflag;
1073*00b67f09SDavid van Moolenbroek static int T7_sdflag;
1074*00b67f09SDavid van Moolenbroek static isc_mutex_t T7_mx;
1075*00b67f09SDavid van Moolenbroek static isc_condition_t T7_cv;
1076*00b67f09SDavid van Moolenbroek
1077*00b67f09SDavid van Moolenbroek static int T7_nfails;
1078*00b67f09SDavid van Moolenbroek
1079*00b67f09SDavid van Moolenbroek static void
t7_event1(isc_task_t * task,isc_event_t * event)1080*00b67f09SDavid van Moolenbroek t7_event1(isc_task_t *task, isc_event_t *event) {
1081*00b67f09SDavid van Moolenbroek UNUSED(task);
1082*00b67f09SDavid van Moolenbroek
1083*00b67f09SDavid van Moolenbroek ++T7_eflag;
1084*00b67f09SDavid van Moolenbroek
1085*00b67f09SDavid van Moolenbroek isc_event_free(&event);
1086*00b67f09SDavid van Moolenbroek }
1087*00b67f09SDavid van Moolenbroek
1088*00b67f09SDavid van Moolenbroek static void
t7_sde(isc_task_t * task,isc_event_t * event)1089*00b67f09SDavid van Moolenbroek t7_sde(isc_task_t *task, isc_event_t *event) {
1090*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
1091*00b67f09SDavid van Moolenbroek
1092*00b67f09SDavid van Moolenbroek UNUSED(task);
1093*00b67f09SDavid van Moolenbroek
1094*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T7_mx);
1095*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1096*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1097*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1098*00b67f09SDavid van Moolenbroek ++T7_nprobs;
1099*00b67f09SDavid van Moolenbroek }
1100*00b67f09SDavid van Moolenbroek
1101*00b67f09SDavid van Moolenbroek ++T7_sdflag;
1102*00b67f09SDavid van Moolenbroek
1103*00b67f09SDavid van Moolenbroek isc_result = isc_condition_signal(&T7_cv);
1104*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1105*00b67f09SDavid van Moolenbroek t_info("isc_condition_signal failed %s\n",
1106*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1107*00b67f09SDavid van Moolenbroek ++T7_nprobs;
1108*00b67f09SDavid van Moolenbroek }
1109*00b67f09SDavid van Moolenbroek
1110*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T7_mx);
1111*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1112*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
1113*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1114*00b67f09SDavid van Moolenbroek ++T7_nprobs;
1115*00b67f09SDavid van Moolenbroek }
1116*00b67f09SDavid van Moolenbroek
1117*00b67f09SDavid van Moolenbroek isc_event_free(&event);
1118*00b67f09SDavid van Moolenbroek }
1119*00b67f09SDavid van Moolenbroek
1120*00b67f09SDavid van Moolenbroek static int
t_tasks7(void)1121*00b67f09SDavid van Moolenbroek t_tasks7(void) {
1122*00b67f09SDavid van Moolenbroek int result;
1123*00b67f09SDavid van Moolenbroek char *p;
1124*00b67f09SDavid van Moolenbroek isc_mem_t *mctx;
1125*00b67f09SDavid van Moolenbroek isc_taskmgr_t *tmgr;
1126*00b67f09SDavid van Moolenbroek isc_task_t *task;
1127*00b67f09SDavid van Moolenbroek unsigned int workers;
1128*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
1129*00b67f09SDavid van Moolenbroek isc_eventtype_t event_type;
1130*00b67f09SDavid van Moolenbroek isc_event_t *event;
1131*00b67f09SDavid van Moolenbroek isc_time_t now;
1132*00b67f09SDavid van Moolenbroek isc_interval_t interval;
1133*00b67f09SDavid van Moolenbroek
1134*00b67f09SDavid van Moolenbroek T7_nprobs = 0;
1135*00b67f09SDavid van Moolenbroek T7_nfails = 0;
1136*00b67f09SDavid van Moolenbroek T7_sdflag = 0;
1137*00b67f09SDavid van Moolenbroek T7_eflag = 0;
1138*00b67f09SDavid van Moolenbroek
1139*00b67f09SDavid van Moolenbroek event_type = 7;
1140*00b67f09SDavid van Moolenbroek
1141*00b67f09SDavid van Moolenbroek workers = 2;
1142*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASK_WORKERS");
1143*00b67f09SDavid van Moolenbroek if (p != NULL)
1144*00b67f09SDavid van Moolenbroek workers = atoi(p);
1145*00b67f09SDavid van Moolenbroek
1146*00b67f09SDavid van Moolenbroek mctx = NULL;
1147*00b67f09SDavid van Moolenbroek isc_result = isc_mem_create(0, 0, &mctx);
1148*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1149*00b67f09SDavid van Moolenbroek t_info("isc_mem_create failed %s\n",
1150*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1151*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1152*00b67f09SDavid van Moolenbroek }
1153*00b67f09SDavid van Moolenbroek
1154*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_init(&T7_mx);
1155*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1156*00b67f09SDavid van Moolenbroek t_info("isc_mutex_init failed %s\n",
1157*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1158*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1159*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1160*00b67f09SDavid van Moolenbroek }
1161*00b67f09SDavid van Moolenbroek
1162*00b67f09SDavid van Moolenbroek isc_result = isc_condition_init(&T7_cv);
1163*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1164*00b67f09SDavid van Moolenbroek t_info("isc_condition_init failed %s\n",
1165*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1166*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1167*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1168*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1169*00b67f09SDavid van Moolenbroek }
1170*00b67f09SDavid van Moolenbroek
1171*00b67f09SDavid van Moolenbroek tmgr = NULL;
1172*00b67f09SDavid van Moolenbroek isc_result = isc_taskmgr_create(mctx, workers, 0, &tmgr);
1173*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1174*00b67f09SDavid van Moolenbroek t_info("isc_taskmgr_create failed %s\n",
1175*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1176*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1177*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T7_cv);
1178*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1179*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1180*00b67f09SDavid van Moolenbroek }
1181*00b67f09SDavid van Moolenbroek
1182*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T7_mx);
1183*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1184*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1185*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1186*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1187*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T7_cv);
1188*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1189*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1190*00b67f09SDavid van Moolenbroek return(T_FAIL);
1191*00b67f09SDavid van Moolenbroek }
1192*00b67f09SDavid van Moolenbroek
1193*00b67f09SDavid van Moolenbroek task = NULL;
1194*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(tmgr, 0, &task);
1195*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1196*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %s\n",
1197*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1198*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1199*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T7_cv);
1200*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1201*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1202*00b67f09SDavid van Moolenbroek return(T_FAIL);
1203*00b67f09SDavid van Moolenbroek }
1204*00b67f09SDavid van Moolenbroek
1205*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task, t7_sde, NULL);
1206*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1207*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown returned %s\n",
1208*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1209*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1210*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T7_cv);
1211*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1212*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1213*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1214*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1215*00b67f09SDavid van Moolenbroek }
1216*00b67f09SDavid van Moolenbroek
1217*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, &senders[1], event_type, t7_event1,
1218*00b67f09SDavid van Moolenbroek NULL, sizeof(*event));
1219*00b67f09SDavid van Moolenbroek if (event == NULL) {
1220*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
1221*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1222*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T7_cv);
1223*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1224*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1225*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1226*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1227*00b67f09SDavid van Moolenbroek }
1228*00b67f09SDavid van Moolenbroek isc_task_send(task, &event);
1229*00b67f09SDavid van Moolenbroek
1230*00b67f09SDavid van Moolenbroek isc_task_shutdown(task);
1231*00b67f09SDavid van Moolenbroek
1232*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 5, 0);
1233*00b67f09SDavid van Moolenbroek
1234*00b67f09SDavid van Moolenbroek while (T7_sdflag == 0) {
1235*00b67f09SDavid van Moolenbroek isc_result = isc_time_nowplusinterval(&now, &interval);
1236*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1237*00b67f09SDavid van Moolenbroek t_info("isc_time_nowplusinterval failed %s\n",
1238*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1239*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1240*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T7_cv);
1241*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1242*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1243*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1244*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1245*00b67f09SDavid van Moolenbroek }
1246*00b67f09SDavid van Moolenbroek
1247*00b67f09SDavid van Moolenbroek isc_result = isc_condition_waituntil(&T7_cv, &T7_mx, &now);
1248*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1249*00b67f09SDavid van Moolenbroek t_info("isc_condition_waituntil returned %s\n",
1250*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1251*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1252*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T7_cv);
1253*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1254*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1255*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1256*00b67f09SDavid van Moolenbroek return(T_FAIL);
1257*00b67f09SDavid van Moolenbroek }
1258*00b67f09SDavid van Moolenbroek }
1259*00b67f09SDavid van Moolenbroek
1260*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T7_mx);
1261*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1262*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
1263*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1264*00b67f09SDavid van Moolenbroek ++T7_nprobs;
1265*00b67f09SDavid van Moolenbroek }
1266*00b67f09SDavid van Moolenbroek
1267*00b67f09SDavid van Moolenbroek isc_task_detach(&task);
1268*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1269*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1270*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T7_cv);
1271*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T7_mx);
1272*00b67f09SDavid van Moolenbroek
1273*00b67f09SDavid van Moolenbroek result = T_UNRESOLVED;
1274*00b67f09SDavid van Moolenbroek
1275*00b67f09SDavid van Moolenbroek if (T7_eflag == 0)
1276*00b67f09SDavid van Moolenbroek ++T7_nfails;
1277*00b67f09SDavid van Moolenbroek
1278*00b67f09SDavid van Moolenbroek if (T7_nfails != 0)
1279*00b67f09SDavid van Moolenbroek result = T_FAIL;
1280*00b67f09SDavid van Moolenbroek else if ((T7_nfails == 0) && (T7_nprobs == 0))
1281*00b67f09SDavid van Moolenbroek result = T_PASS;
1282*00b67f09SDavid van Moolenbroek
1283*00b67f09SDavid van Moolenbroek return(result);
1284*00b67f09SDavid van Moolenbroek }
1285*00b67f09SDavid van Moolenbroek
1286*00b67f09SDavid van Moolenbroek static const char *a7 = "A call to isc_task_create() creates a task that can "
1287*00b67f09SDavid van Moolenbroek "receive events.";
1288*00b67f09SDavid van Moolenbroek
1289*00b67f09SDavid van Moolenbroek static void
t7(void)1290*00b67f09SDavid van Moolenbroek t7(void) {
1291*00b67f09SDavid van Moolenbroek t_assert("tasks", 7, T_REQUIRED, "%s", a7);
1292*00b67f09SDavid van Moolenbroek
1293*00b67f09SDavid van Moolenbroek if (threaded)
1294*00b67f09SDavid van Moolenbroek t_result(t_tasks7());
1295*00b67f09SDavid van Moolenbroek else
1296*00b67f09SDavid van Moolenbroek require_threads();
1297*00b67f09SDavid van Moolenbroek }
1298*00b67f09SDavid van Moolenbroek
1299*00b67f09SDavid van Moolenbroek #define T10_SENDERCNT 3
1300*00b67f09SDavid van Moolenbroek #define T10_TYPECNT 4
1301*00b67f09SDavid van Moolenbroek #define T10_TAGCNT 5
1302*00b67f09SDavid van Moolenbroek #define T10_NEVENTS (T10_SENDERCNT*T10_TYPECNT*T10_TAGCNT)
1303*00b67f09SDavid van Moolenbroek #define T_CONTROL 99999
1304*00b67f09SDavid van Moolenbroek
1305*00b67f09SDavid van Moolenbroek static int T10_nprobs;
1306*00b67f09SDavid van Moolenbroek static int T10_nfails;
1307*00b67f09SDavid van Moolenbroek static int T10_startflag;
1308*00b67f09SDavid van Moolenbroek static int T10_shutdownflag;
1309*00b67f09SDavid van Moolenbroek static int T10_eventcnt;
1310*00b67f09SDavid van Moolenbroek static isc_mutex_t T10_mx;
1311*00b67f09SDavid van Moolenbroek static isc_condition_t T10_cv;
1312*00b67f09SDavid van Moolenbroek
1313*00b67f09SDavid van Moolenbroek static void *T10_purge_sender;
1314*00b67f09SDavid van Moolenbroek static isc_eventtype_t T10_purge_type_first;
1315*00b67f09SDavid van Moolenbroek static isc_eventtype_t T10_purge_type_last;
1316*00b67f09SDavid van Moolenbroek static void *T10_purge_tag;
1317*00b67f09SDavid van Moolenbroek static int T10_testrange;
1318*00b67f09SDavid van Moolenbroek
1319*00b67f09SDavid van Moolenbroek static void
t10_event1(isc_task_t * task,isc_event_t * event)1320*00b67f09SDavid van Moolenbroek t10_event1(isc_task_t *task, isc_event_t *event) {
1321*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
1322*00b67f09SDavid van Moolenbroek
1323*00b67f09SDavid van Moolenbroek UNUSED(task);
1324*00b67f09SDavid van Moolenbroek
1325*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T10_mx);
1326*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1327*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1328*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1329*00b67f09SDavid van Moolenbroek ++T10_nprobs;
1330*00b67f09SDavid van Moolenbroek }
1331*00b67f09SDavid van Moolenbroek
1332*00b67f09SDavid van Moolenbroek while (T10_startflag == 0) {
1333*00b67f09SDavid van Moolenbroek isc_result = isc_condition_wait(&T10_cv, &T10_mx);
1334*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1335*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1336*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1337*00b67f09SDavid van Moolenbroek ++T10_nprobs;
1338*00b67f09SDavid van Moolenbroek }
1339*00b67f09SDavid van Moolenbroek }
1340*00b67f09SDavid van Moolenbroek
1341*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T10_mx);
1342*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1343*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
1344*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1345*00b67f09SDavid van Moolenbroek ++T10_nprobs;
1346*00b67f09SDavid van Moolenbroek }
1347*00b67f09SDavid van Moolenbroek
1348*00b67f09SDavid van Moolenbroek isc_event_free(&event);
1349*00b67f09SDavid van Moolenbroek }
1350*00b67f09SDavid van Moolenbroek
1351*00b67f09SDavid van Moolenbroek static void
t10_event2(isc_task_t * task,isc_event_t * event)1352*00b67f09SDavid van Moolenbroek t10_event2(isc_task_t *task, isc_event_t *event) {
1353*00b67f09SDavid van Moolenbroek
1354*00b67f09SDavid van Moolenbroek int sender_match;
1355*00b67f09SDavid van Moolenbroek int type_match;
1356*00b67f09SDavid van Moolenbroek int tag_match;
1357*00b67f09SDavid van Moolenbroek
1358*00b67f09SDavid van Moolenbroek UNUSED(task);
1359*00b67f09SDavid van Moolenbroek
1360*00b67f09SDavid van Moolenbroek sender_match = 0;
1361*00b67f09SDavid van Moolenbroek type_match = 0;
1362*00b67f09SDavid van Moolenbroek tag_match = 0;
1363*00b67f09SDavid van Moolenbroek
1364*00b67f09SDavid van Moolenbroek if (T_debug) {
1365*00b67f09SDavid van Moolenbroek t_info("Event %p,%d,%p,%s\n",
1366*00b67f09SDavid van Moolenbroek event->ev_sender,
1367*00b67f09SDavid van Moolenbroek (int)event->ev_type,
1368*00b67f09SDavid van Moolenbroek event->ev_tag,
1369*00b67f09SDavid van Moolenbroek event->ev_attributes & ISC_EVENTATTR_NOPURGE ?
1370*00b67f09SDavid van Moolenbroek "NP" : "P");
1371*00b67f09SDavid van Moolenbroek }
1372*00b67f09SDavid van Moolenbroek
1373*00b67f09SDavid van Moolenbroek if ((T10_purge_sender == NULL) ||
1374*00b67f09SDavid van Moolenbroek (T10_purge_sender == event->ev_sender)) {
1375*00b67f09SDavid van Moolenbroek sender_match = 1;
1376*00b67f09SDavid van Moolenbroek }
1377*00b67f09SDavid van Moolenbroek if (T10_testrange == 0) {
1378*00b67f09SDavid van Moolenbroek if (T10_purge_type_first == event->ev_type) {
1379*00b67f09SDavid van Moolenbroek type_match = 1;
1380*00b67f09SDavid van Moolenbroek }
1381*00b67f09SDavid van Moolenbroek } else {
1382*00b67f09SDavid van Moolenbroek if ((T10_purge_type_first <= event->ev_type) &&
1383*00b67f09SDavid van Moolenbroek (event->ev_type <= T10_purge_type_last)) {
1384*00b67f09SDavid van Moolenbroek type_match = 1;
1385*00b67f09SDavid van Moolenbroek }
1386*00b67f09SDavid van Moolenbroek }
1387*00b67f09SDavid van Moolenbroek if ((T10_purge_tag == NULL) ||
1388*00b67f09SDavid van Moolenbroek (T10_purge_tag == event->ev_tag)) {
1389*00b67f09SDavid van Moolenbroek tag_match = 1;
1390*00b67f09SDavid van Moolenbroek }
1391*00b67f09SDavid van Moolenbroek
1392*00b67f09SDavid van Moolenbroek if (sender_match && type_match && tag_match) {
1393*00b67f09SDavid van Moolenbroek if (event->ev_attributes & ISC_EVENTATTR_NOPURGE) {
1394*00b67f09SDavid van Moolenbroek t_info("event %p,%d,%p matched but was not purgable\n",
1395*00b67f09SDavid van Moolenbroek event->ev_sender, (int)event->ev_type,
1396*00b67f09SDavid van Moolenbroek event->ev_tag);
1397*00b67f09SDavid van Moolenbroek ++T10_eventcnt;
1398*00b67f09SDavid van Moolenbroek } else {
1399*00b67f09SDavid van Moolenbroek t_info("*** event %p,%d,%p not purged\n",
1400*00b67f09SDavid van Moolenbroek event->ev_sender, (int)event->ev_type,
1401*00b67f09SDavid van Moolenbroek event->ev_tag);
1402*00b67f09SDavid van Moolenbroek }
1403*00b67f09SDavid van Moolenbroek } else {
1404*00b67f09SDavid van Moolenbroek ++T10_eventcnt;
1405*00b67f09SDavid van Moolenbroek }
1406*00b67f09SDavid van Moolenbroek isc_event_free(&event);
1407*00b67f09SDavid van Moolenbroek }
1408*00b67f09SDavid van Moolenbroek
1409*00b67f09SDavid van Moolenbroek
1410*00b67f09SDavid van Moolenbroek static void
t10_sde(isc_task_t * task,isc_event_t * event)1411*00b67f09SDavid van Moolenbroek t10_sde(isc_task_t *task, isc_event_t *event) {
1412*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
1413*00b67f09SDavid van Moolenbroek
1414*00b67f09SDavid van Moolenbroek UNUSED(task);
1415*00b67f09SDavid van Moolenbroek
1416*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T10_mx);
1417*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1418*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1419*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1420*00b67f09SDavid van Moolenbroek ++T10_nprobs;
1421*00b67f09SDavid van Moolenbroek }
1422*00b67f09SDavid van Moolenbroek
1423*00b67f09SDavid van Moolenbroek ++T10_shutdownflag;
1424*00b67f09SDavid van Moolenbroek
1425*00b67f09SDavid van Moolenbroek isc_result = isc_condition_signal(&T10_cv);
1426*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1427*00b67f09SDavid van Moolenbroek t_info("isc_condition_signal failed %s\n",
1428*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1429*00b67f09SDavid van Moolenbroek ++T10_nprobs;
1430*00b67f09SDavid van Moolenbroek }
1431*00b67f09SDavid van Moolenbroek
1432*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T10_mx);
1433*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1434*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
1435*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1436*00b67f09SDavid van Moolenbroek ++T10_nprobs;
1437*00b67f09SDavid van Moolenbroek }
1438*00b67f09SDavid van Moolenbroek
1439*00b67f09SDavid van Moolenbroek isc_event_free(&event);
1440*00b67f09SDavid van Moolenbroek }
1441*00b67f09SDavid van Moolenbroek
1442*00b67f09SDavid van Moolenbroek static void
t_taskpurge_x(int sender,int type,int tag,void * purge_sender,int purge_type_first,int purge_type_last,void * purge_tag,int exp_nevents,int * nfails,int * nprobs,int testrange)1443*00b67f09SDavid van Moolenbroek t_taskpurge_x(int sender, int type, int tag, void *purge_sender,
1444*00b67f09SDavid van Moolenbroek int purge_type_first, int purge_type_last, void *purge_tag,
1445*00b67f09SDavid van Moolenbroek int exp_nevents, int *nfails, int *nprobs, int testrange)
1446*00b67f09SDavid van Moolenbroek {
1447*00b67f09SDavid van Moolenbroek char *p;
1448*00b67f09SDavid van Moolenbroek isc_mem_t *mctx;
1449*00b67f09SDavid van Moolenbroek isc_taskmgr_t *tmgr;
1450*00b67f09SDavid van Moolenbroek isc_task_t *task;
1451*00b67f09SDavid van Moolenbroek unsigned int workers;
1452*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
1453*00b67f09SDavid van Moolenbroek isc_event_t *event;
1454*00b67f09SDavid van Moolenbroek isc_time_t now;
1455*00b67f09SDavid van Moolenbroek isc_interval_t interval;
1456*00b67f09SDavid van Moolenbroek int sender_cnt;
1457*00b67f09SDavid van Moolenbroek int type_cnt;
1458*00b67f09SDavid van Moolenbroek int tag_cnt;
1459*00b67f09SDavid van Moolenbroek int event_cnt;
1460*00b67f09SDavid van Moolenbroek int cnt;
1461*00b67f09SDavid van Moolenbroek int nevents;
1462*00b67f09SDavid van Moolenbroek isc_event_t *eventtab[T10_NEVENTS];
1463*00b67f09SDavid van Moolenbroek
1464*00b67f09SDavid van Moolenbroek
1465*00b67f09SDavid van Moolenbroek T10_startflag = 0;
1466*00b67f09SDavid van Moolenbroek T10_shutdownflag = 0;
1467*00b67f09SDavid van Moolenbroek T10_eventcnt = 0;
1468*00b67f09SDavid van Moolenbroek T10_purge_sender = purge_sender;
1469*00b67f09SDavid van Moolenbroek T10_purge_type_first = (isc_eventtype_t) purge_type_first;
1470*00b67f09SDavid van Moolenbroek T10_purge_type_last = (isc_eventtype_t) purge_type_last;
1471*00b67f09SDavid van Moolenbroek T10_purge_tag = purge_tag;
1472*00b67f09SDavid van Moolenbroek T10_testrange = testrange;
1473*00b67f09SDavid van Moolenbroek
1474*00b67f09SDavid van Moolenbroek workers = 2;
1475*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASK_WORKERS");
1476*00b67f09SDavid van Moolenbroek if (p != NULL)
1477*00b67f09SDavid van Moolenbroek workers = atoi(p);
1478*00b67f09SDavid van Moolenbroek
1479*00b67f09SDavid van Moolenbroek mctx = NULL;
1480*00b67f09SDavid van Moolenbroek isc_result = isc_mem_create(0, 0, &mctx);
1481*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1482*00b67f09SDavid van Moolenbroek t_info("isc_mem_create failed %s\n",
1483*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1484*00b67f09SDavid van Moolenbroek ++*nprobs;
1485*00b67f09SDavid van Moolenbroek return;
1486*00b67f09SDavid van Moolenbroek }
1487*00b67f09SDavid van Moolenbroek
1488*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_init(&T10_mx);
1489*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1490*00b67f09SDavid van Moolenbroek t_info("isc_mutex_init failed %s\n",
1491*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1492*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1493*00b67f09SDavid van Moolenbroek ++*nprobs;
1494*00b67f09SDavid van Moolenbroek return;
1495*00b67f09SDavid van Moolenbroek }
1496*00b67f09SDavid van Moolenbroek
1497*00b67f09SDavid van Moolenbroek isc_result = isc_condition_init(&T10_cv);
1498*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1499*00b67f09SDavid van Moolenbroek t_info("isc_condition_init failed %s\n",
1500*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1501*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1502*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1503*00b67f09SDavid van Moolenbroek ++*nprobs;
1504*00b67f09SDavid van Moolenbroek return;
1505*00b67f09SDavid van Moolenbroek }
1506*00b67f09SDavid van Moolenbroek
1507*00b67f09SDavid van Moolenbroek tmgr = NULL;
1508*00b67f09SDavid van Moolenbroek isc_result = isc_taskmgr_create(mctx, workers, 0, &tmgr);
1509*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1510*00b67f09SDavid van Moolenbroek t_info("isc_taskmgr_create failed %s\n",
1511*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1512*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1513*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1514*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1515*00b67f09SDavid van Moolenbroek ++*nprobs;
1516*00b67f09SDavid van Moolenbroek return;
1517*00b67f09SDavid van Moolenbroek }
1518*00b67f09SDavid van Moolenbroek
1519*00b67f09SDavid van Moolenbroek task = NULL;
1520*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(tmgr, 0, &task);
1521*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1522*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %s\n",
1523*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1524*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1525*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1526*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1527*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1528*00b67f09SDavid van Moolenbroek ++*nprobs;
1529*00b67f09SDavid van Moolenbroek return;
1530*00b67f09SDavid van Moolenbroek }
1531*00b67f09SDavid van Moolenbroek
1532*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task, t10_sde, NULL);
1533*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1534*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown returned %s\n",
1535*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1536*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1537*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1538*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1539*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1540*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1541*00b67f09SDavid van Moolenbroek ++*nprobs;
1542*00b67f09SDavid van Moolenbroek return;
1543*00b67f09SDavid van Moolenbroek }
1544*00b67f09SDavid van Moolenbroek
1545*00b67f09SDavid van Moolenbroek /*
1546*00b67f09SDavid van Moolenbroek * Block the task on T10_cv.
1547*00b67f09SDavid van Moolenbroek */
1548*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, (void *)1, (isc_eventtype_t)T_CONTROL,
1549*00b67f09SDavid van Moolenbroek t10_event1, NULL, sizeof(*event));
1550*00b67f09SDavid van Moolenbroek
1551*00b67f09SDavid van Moolenbroek if (event == NULL) {
1552*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
1553*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1554*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1555*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1556*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1557*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1558*00b67f09SDavid van Moolenbroek ++*nprobs;
1559*00b67f09SDavid van Moolenbroek return;
1560*00b67f09SDavid van Moolenbroek }
1561*00b67f09SDavid van Moolenbroek isc_task_send(task, &event);
1562*00b67f09SDavid van Moolenbroek
1563*00b67f09SDavid van Moolenbroek /*
1564*00b67f09SDavid van Moolenbroek * Fill the task's queue with some messages with varying
1565*00b67f09SDavid van Moolenbroek * sender, type, tag, and purgable attribute values.
1566*00b67f09SDavid van Moolenbroek */
1567*00b67f09SDavid van Moolenbroek
1568*00b67f09SDavid van Moolenbroek event_cnt = 0;
1569*00b67f09SDavid van Moolenbroek for (sender_cnt = 0; sender_cnt < T10_SENDERCNT; ++sender_cnt) {
1570*00b67f09SDavid van Moolenbroek for (type_cnt = 0; type_cnt < T10_TYPECNT; ++type_cnt) {
1571*00b67f09SDavid van Moolenbroek for (tag_cnt = 0; tag_cnt < T10_TAGCNT; ++tag_cnt) {
1572*00b67f09SDavid van Moolenbroek eventtab[event_cnt] =
1573*00b67f09SDavid van Moolenbroek isc_event_allocate(mctx,
1574*00b67f09SDavid van Moolenbroek &senders[sender + sender_cnt],
1575*00b67f09SDavid van Moolenbroek (isc_eventtype_t)(type + type_cnt),
1576*00b67f09SDavid van Moolenbroek t10_event2, NULL, sizeof(*event));
1577*00b67f09SDavid van Moolenbroek
1578*00b67f09SDavid van Moolenbroek if (eventtab[event_cnt] == NULL) {
1579*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
1580*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1581*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1582*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1583*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1584*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1585*00b67f09SDavid van Moolenbroek ++*nprobs;
1586*00b67f09SDavid van Moolenbroek return;
1587*00b67f09SDavid van Moolenbroek }
1588*00b67f09SDavid van Moolenbroek
1589*00b67f09SDavid van Moolenbroek eventtab[event_cnt]->ev_tag =
1590*00b67f09SDavid van Moolenbroek (void *)((uintptr_t)tag + tag_cnt);
1591*00b67f09SDavid van Moolenbroek
1592*00b67f09SDavid van Moolenbroek /*
1593*00b67f09SDavid van Moolenbroek * Make all odd message non-purgable.
1594*00b67f09SDavid van Moolenbroek */
1595*00b67f09SDavid van Moolenbroek if ((sender_cnt % 2) && (type_cnt %2) &&
1596*00b67f09SDavid van Moolenbroek (tag_cnt %2))
1597*00b67f09SDavid van Moolenbroek eventtab[event_cnt]->ev_attributes |=
1598*00b67f09SDavid van Moolenbroek ISC_EVENTATTR_NOPURGE;
1599*00b67f09SDavid van Moolenbroek ++event_cnt;
1600*00b67f09SDavid van Moolenbroek }
1601*00b67f09SDavid van Moolenbroek }
1602*00b67f09SDavid van Moolenbroek }
1603*00b67f09SDavid van Moolenbroek
1604*00b67f09SDavid van Moolenbroek for (cnt = 0; cnt < event_cnt; ++cnt)
1605*00b67f09SDavid van Moolenbroek isc_task_send(task, &eventtab[cnt]);
1606*00b67f09SDavid van Moolenbroek
1607*00b67f09SDavid van Moolenbroek if (T_debug)
1608*00b67f09SDavid van Moolenbroek t_info("%d events queued\n", cnt);
1609*00b67f09SDavid van Moolenbroek
1610*00b67f09SDavid van Moolenbroek if (testrange == 0) {
1611*00b67f09SDavid van Moolenbroek /*
1612*00b67f09SDavid van Moolenbroek * We're testing isc_task_purge.
1613*00b67f09SDavid van Moolenbroek */
1614*00b67f09SDavid van Moolenbroek nevents = isc_task_purge(task, purge_sender,
1615*00b67f09SDavid van Moolenbroek (isc_eventtype_t)purge_type_first,
1616*00b67f09SDavid van Moolenbroek purge_tag);
1617*00b67f09SDavid van Moolenbroek if (nevents != exp_nevents) {
1618*00b67f09SDavid van Moolenbroek t_info("*** isc_task_purge returned %d, expected %d\n",
1619*00b67f09SDavid van Moolenbroek nevents, exp_nevents);
1620*00b67f09SDavid van Moolenbroek ++*nfails;
1621*00b67f09SDavid van Moolenbroek } else if (T_debug)
1622*00b67f09SDavid van Moolenbroek t_info("isc_task_purge returned %d\n", nevents);
1623*00b67f09SDavid van Moolenbroek } else {
1624*00b67f09SDavid van Moolenbroek /*
1625*00b67f09SDavid van Moolenbroek * We're testing isc_task_purgerange.
1626*00b67f09SDavid van Moolenbroek */
1627*00b67f09SDavid van Moolenbroek nevents = isc_task_purgerange(task, purge_sender,
1628*00b67f09SDavid van Moolenbroek (isc_eventtype_t)purge_type_first,
1629*00b67f09SDavid van Moolenbroek (isc_eventtype_t)purge_type_last,
1630*00b67f09SDavid van Moolenbroek purge_tag);
1631*00b67f09SDavid van Moolenbroek if (nevents != exp_nevents) {
1632*00b67f09SDavid van Moolenbroek t_info("*** isc_task_purgerange returned %d, "
1633*00b67f09SDavid van Moolenbroek "expected %d\n", nevents, exp_nevents);
1634*00b67f09SDavid van Moolenbroek ++*nfails;
1635*00b67f09SDavid van Moolenbroek } else if (T_debug)
1636*00b67f09SDavid van Moolenbroek t_info("isc_task_purgerange returned %d\n", nevents);
1637*00b67f09SDavid van Moolenbroek }
1638*00b67f09SDavid van Moolenbroek
1639*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T10_mx);
1640*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1641*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1642*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1643*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1644*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1645*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1646*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1647*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1648*00b67f09SDavid van Moolenbroek ++*nprobs;
1649*00b67f09SDavid van Moolenbroek return;
1650*00b67f09SDavid van Moolenbroek }
1651*00b67f09SDavid van Moolenbroek
1652*00b67f09SDavid van Moolenbroek /*
1653*00b67f09SDavid van Moolenbroek * Unblock the task, allowing event processing.
1654*00b67f09SDavid van Moolenbroek */
1655*00b67f09SDavid van Moolenbroek T10_startflag = 1;
1656*00b67f09SDavid van Moolenbroek isc_result = isc_condition_signal(&T10_cv);
1657*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1658*00b67f09SDavid van Moolenbroek t_info("isc_condition_signal failed %s\n",
1659*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1660*00b67f09SDavid van Moolenbroek ++*nprobs;
1661*00b67f09SDavid van Moolenbroek }
1662*00b67f09SDavid van Moolenbroek
1663*00b67f09SDavid van Moolenbroek isc_task_shutdown(task);
1664*00b67f09SDavid van Moolenbroek
1665*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 5, 0);
1666*00b67f09SDavid van Moolenbroek
1667*00b67f09SDavid van Moolenbroek /*
1668*00b67f09SDavid van Moolenbroek * Wait for shutdown processing to complete.
1669*00b67f09SDavid van Moolenbroek */
1670*00b67f09SDavid van Moolenbroek while (T10_shutdownflag == 0) {
1671*00b67f09SDavid van Moolenbroek isc_result = isc_time_nowplusinterval(&now, &interval);
1672*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1673*00b67f09SDavid van Moolenbroek t_info("isc_time_nowplusinterval failed %s\n",
1674*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1675*00b67f09SDavid van Moolenbroek isc_task_detach(&task);
1676*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1677*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1678*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1679*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1680*00b67f09SDavid van Moolenbroek ++*nprobs;
1681*00b67f09SDavid van Moolenbroek return;
1682*00b67f09SDavid van Moolenbroek }
1683*00b67f09SDavid van Moolenbroek
1684*00b67f09SDavid van Moolenbroek isc_result = isc_condition_waituntil(&T10_cv, &T10_mx, &now);
1685*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1686*00b67f09SDavid van Moolenbroek t_info("isc_condition_waituntil returned %s\n",
1687*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1688*00b67f09SDavid van Moolenbroek isc_task_detach(&task);
1689*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1690*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1691*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1692*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1693*00b67f09SDavid van Moolenbroek ++*nfails;
1694*00b67f09SDavid van Moolenbroek return;
1695*00b67f09SDavid van Moolenbroek }
1696*00b67f09SDavid van Moolenbroek }
1697*00b67f09SDavid van Moolenbroek
1698*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T10_mx);
1699*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1700*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
1701*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1702*00b67f09SDavid van Moolenbroek ++*nprobs;
1703*00b67f09SDavid van Moolenbroek }
1704*00b67f09SDavid van Moolenbroek
1705*00b67f09SDavid van Moolenbroek isc_task_detach(&task);
1706*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1707*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1708*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T10_mx);
1709*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T10_cv);
1710*00b67f09SDavid van Moolenbroek
1711*00b67f09SDavid van Moolenbroek if (T_debug)
1712*00b67f09SDavid van Moolenbroek t_info("task processed %d events\n", T10_eventcnt);
1713*00b67f09SDavid van Moolenbroek
1714*00b67f09SDavid van Moolenbroek if ((T10_eventcnt + nevents) != event_cnt) {
1715*00b67f09SDavid van Moolenbroek t_info("*** processed %d, purged %d, total %d\n",
1716*00b67f09SDavid van Moolenbroek T10_eventcnt, nevents, event_cnt);
1717*00b67f09SDavid van Moolenbroek ++*nfails;
1718*00b67f09SDavid van Moolenbroek }
1719*00b67f09SDavid van Moolenbroek }
1720*00b67f09SDavid van Moolenbroek
1721*00b67f09SDavid van Moolenbroek static int
t_tasks10(void)1722*00b67f09SDavid van Moolenbroek t_tasks10(void) {
1723*00b67f09SDavid van Moolenbroek int result;
1724*00b67f09SDavid van Moolenbroek
1725*00b67f09SDavid van Moolenbroek T10_nprobs = 0;
1726*00b67f09SDavid van Moolenbroek T10_nfails = 0;
1727*00b67f09SDavid van Moolenbroek
1728*00b67f09SDavid van Moolenbroek /*
1729*00b67f09SDavid van Moolenbroek * Try purging on a specific sender.
1730*00b67f09SDavid van Moolenbroek */
1731*00b67f09SDavid van Moolenbroek t_info("testing purge on 2,4,8 expecting 1\n");
1732*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, &senders[2], 4, 4, (void *)8, 1, &T10_nfails,
1733*00b67f09SDavid van Moolenbroek &T10_nprobs, 0);
1734*00b67f09SDavid van Moolenbroek
1735*00b67f09SDavid van Moolenbroek /*
1736*00b67f09SDavid van Moolenbroek * Try purging on all senders.
1737*00b67f09SDavid van Moolenbroek */
1738*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,4,8 expecting 3\n");
1739*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 4, 4, (void *)8, 3, &T10_nfails,
1740*00b67f09SDavid van Moolenbroek &T10_nprobs, 0);
1741*00b67f09SDavid van Moolenbroek
1742*00b67f09SDavid van Moolenbroek /*
1743*00b67f09SDavid van Moolenbroek * Try purging on all senders, specified type, all tags.
1744*00b67f09SDavid van Moolenbroek */
1745*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,4,0 expecting 15\n");
1746*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 4, 4, NULL, 15, &T10_nfails,
1747*00b67f09SDavid van Moolenbroek &T10_nprobs, 0);
1748*00b67f09SDavid van Moolenbroek
1749*00b67f09SDavid van Moolenbroek /*
1750*00b67f09SDavid van Moolenbroek * Try purging on a specified tag, no such type.
1751*00b67f09SDavid van Moolenbroek */
1752*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,99,8 expecting 0\n");
1753*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 99, 99, (void *)8, 0, &T10_nfails,
1754*00b67f09SDavid van Moolenbroek &T10_nprobs, 0);
1755*00b67f09SDavid van Moolenbroek
1756*00b67f09SDavid van Moolenbroek /*
1757*00b67f09SDavid van Moolenbroek * Try purging on specified sender, type, all tags.
1758*00b67f09SDavid van Moolenbroek */
1759*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,5,0 expecting 5\n");
1760*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, &senders[3], 5, 5, NULL, 5, &T10_nfails,
1761*00b67f09SDavid van Moolenbroek &T10_nprobs, 0);
1762*00b67f09SDavid van Moolenbroek
1763*00b67f09SDavid van Moolenbroek result = T_UNRESOLVED;
1764*00b67f09SDavid van Moolenbroek
1765*00b67f09SDavid van Moolenbroek if ((T10_nfails == 0) && (T10_nprobs == 0))
1766*00b67f09SDavid van Moolenbroek result = T_PASS;
1767*00b67f09SDavid van Moolenbroek else if (T10_nfails != 0)
1768*00b67f09SDavid van Moolenbroek result = T_FAIL;
1769*00b67f09SDavid van Moolenbroek
1770*00b67f09SDavid van Moolenbroek return(result);
1771*00b67f09SDavid van Moolenbroek }
1772*00b67f09SDavid van Moolenbroek
1773*00b67f09SDavid van Moolenbroek static const char *a10 =
1774*00b67f09SDavid van Moolenbroek "A call to isc_task_purge(task, sender, type, tag) "
1775*00b67f09SDavid van Moolenbroek "purges all events of type 'type' and with tag 'tag' "
1776*00b67f09SDavid van Moolenbroek "not marked as unpurgable from sender from the task's "
1777*00b67f09SDavid van Moolenbroek "queue and returns the number of events purged.";
1778*00b67f09SDavid van Moolenbroek
1779*00b67f09SDavid van Moolenbroek static void
t10(void)1780*00b67f09SDavid van Moolenbroek t10(void) {
1781*00b67f09SDavid van Moolenbroek t_assert("tasks", 10, T_REQUIRED, "%s", a10);
1782*00b67f09SDavid van Moolenbroek
1783*00b67f09SDavid van Moolenbroek if (threaded)
1784*00b67f09SDavid van Moolenbroek t_result(t_tasks10());
1785*00b67f09SDavid van Moolenbroek else
1786*00b67f09SDavid van Moolenbroek require_threads();
1787*00b67f09SDavid van Moolenbroek }
1788*00b67f09SDavid van Moolenbroek
1789*00b67f09SDavid van Moolenbroek static int T11_nprobs;
1790*00b67f09SDavid van Moolenbroek static int T11_nfails;
1791*00b67f09SDavid van Moolenbroek static int T11_startflag;
1792*00b67f09SDavid van Moolenbroek static int T11_shutdownflag;
1793*00b67f09SDavid van Moolenbroek static int T11_eventcnt;
1794*00b67f09SDavid van Moolenbroek static isc_mutex_t T11_mx;
1795*00b67f09SDavid van Moolenbroek static isc_condition_t T11_cv;
1796*00b67f09SDavid van Moolenbroek
1797*00b67f09SDavid van Moolenbroek static void
t11_event1(isc_task_t * task,isc_event_t * event)1798*00b67f09SDavid van Moolenbroek t11_event1(isc_task_t *task, isc_event_t *event) {
1799*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
1800*00b67f09SDavid van Moolenbroek
1801*00b67f09SDavid van Moolenbroek UNUSED(task);
1802*00b67f09SDavid van Moolenbroek
1803*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T11_mx);
1804*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1805*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1806*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1807*00b67f09SDavid van Moolenbroek ++T11_nprobs;
1808*00b67f09SDavid van Moolenbroek }
1809*00b67f09SDavid van Moolenbroek
1810*00b67f09SDavid van Moolenbroek while (T11_startflag == 0) {
1811*00b67f09SDavid van Moolenbroek isc_result = isc_condition_wait(&T11_cv, &T11_mx);
1812*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1813*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1814*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1815*00b67f09SDavid van Moolenbroek ++T11_nprobs;
1816*00b67f09SDavid van Moolenbroek }
1817*00b67f09SDavid van Moolenbroek }
1818*00b67f09SDavid van Moolenbroek
1819*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T11_mx);
1820*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1821*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
1822*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1823*00b67f09SDavid van Moolenbroek ++T11_nprobs;
1824*00b67f09SDavid van Moolenbroek }
1825*00b67f09SDavid van Moolenbroek
1826*00b67f09SDavid van Moolenbroek isc_event_free(&event);
1827*00b67f09SDavid van Moolenbroek }
1828*00b67f09SDavid van Moolenbroek
1829*00b67f09SDavid van Moolenbroek static void
t11_event2(isc_task_t * task,isc_event_t * event)1830*00b67f09SDavid van Moolenbroek t11_event2(isc_task_t *task, isc_event_t *event) {
1831*00b67f09SDavid van Moolenbroek UNUSED(task);
1832*00b67f09SDavid van Moolenbroek
1833*00b67f09SDavid van Moolenbroek ++T11_eventcnt;
1834*00b67f09SDavid van Moolenbroek isc_event_free(&event);
1835*00b67f09SDavid van Moolenbroek }
1836*00b67f09SDavid van Moolenbroek
1837*00b67f09SDavid van Moolenbroek
1838*00b67f09SDavid van Moolenbroek static void
t11_sde(isc_task_t * task,isc_event_t * event)1839*00b67f09SDavid van Moolenbroek t11_sde(isc_task_t *task, isc_event_t *event) {
1840*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
1841*00b67f09SDavid van Moolenbroek
1842*00b67f09SDavid van Moolenbroek UNUSED(task);
1843*00b67f09SDavid van Moolenbroek
1844*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T11_mx);
1845*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1846*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
1847*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1848*00b67f09SDavid van Moolenbroek ++T11_nprobs;
1849*00b67f09SDavid van Moolenbroek }
1850*00b67f09SDavid van Moolenbroek
1851*00b67f09SDavid van Moolenbroek ++T11_shutdownflag;
1852*00b67f09SDavid van Moolenbroek
1853*00b67f09SDavid van Moolenbroek isc_result = isc_condition_signal(&T11_cv);
1854*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1855*00b67f09SDavid van Moolenbroek t_info("isc_condition_signal failed %s\n",
1856*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1857*00b67f09SDavid van Moolenbroek ++T11_nprobs;
1858*00b67f09SDavid van Moolenbroek }
1859*00b67f09SDavid van Moolenbroek
1860*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T11_mx);
1861*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1862*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
1863*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1864*00b67f09SDavid van Moolenbroek ++T11_nprobs;
1865*00b67f09SDavid van Moolenbroek }
1866*00b67f09SDavid van Moolenbroek
1867*00b67f09SDavid van Moolenbroek isc_event_free(&event);
1868*00b67f09SDavid van Moolenbroek }
1869*00b67f09SDavid van Moolenbroek
1870*00b67f09SDavid van Moolenbroek static int
t_tasks11(int purgable)1871*00b67f09SDavid van Moolenbroek t_tasks11(int purgable) {
1872*00b67f09SDavid van Moolenbroek char *p;
1873*00b67f09SDavid van Moolenbroek isc_mem_t *mctx;
1874*00b67f09SDavid van Moolenbroek isc_taskmgr_t *tmgr;
1875*00b67f09SDavid van Moolenbroek isc_task_t *task;
1876*00b67f09SDavid van Moolenbroek isc_boolean_t rval;
1877*00b67f09SDavid van Moolenbroek unsigned int workers;
1878*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
1879*00b67f09SDavid van Moolenbroek isc_event_t *event1;
1880*00b67f09SDavid van Moolenbroek isc_event_t *event2, *event2_clone;
1881*00b67f09SDavid van Moolenbroek isc_time_t now;
1882*00b67f09SDavid van Moolenbroek isc_interval_t interval;
1883*00b67f09SDavid van Moolenbroek int result;
1884*00b67f09SDavid van Moolenbroek
1885*00b67f09SDavid van Moolenbroek T11_startflag = 0;
1886*00b67f09SDavid van Moolenbroek T11_shutdownflag = 0;
1887*00b67f09SDavid van Moolenbroek T11_eventcnt = 0;
1888*00b67f09SDavid van Moolenbroek
1889*00b67f09SDavid van Moolenbroek workers = 2;
1890*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASK_WORKERS");
1891*00b67f09SDavid van Moolenbroek if (p != NULL)
1892*00b67f09SDavid van Moolenbroek workers = atoi(p);
1893*00b67f09SDavid van Moolenbroek
1894*00b67f09SDavid van Moolenbroek mctx = NULL;
1895*00b67f09SDavid van Moolenbroek isc_result = isc_mem_create(0, 0, &mctx);
1896*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1897*00b67f09SDavid van Moolenbroek t_info("isc_mem_create failed %s\n",
1898*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1899*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1900*00b67f09SDavid van Moolenbroek }
1901*00b67f09SDavid van Moolenbroek
1902*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_init(&T11_mx);
1903*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1904*00b67f09SDavid van Moolenbroek t_info("isc_mutex_init failed %s\n",
1905*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1906*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1907*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1908*00b67f09SDavid van Moolenbroek }
1909*00b67f09SDavid van Moolenbroek
1910*00b67f09SDavid van Moolenbroek isc_result = isc_condition_init(&T11_cv);
1911*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1912*00b67f09SDavid van Moolenbroek t_info("isc_condition_init failed %s\n",
1913*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1914*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1915*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T11_mx);
1916*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1917*00b67f09SDavid van Moolenbroek }
1918*00b67f09SDavid van Moolenbroek
1919*00b67f09SDavid van Moolenbroek tmgr = NULL;
1920*00b67f09SDavid van Moolenbroek isc_result = isc_taskmgr_create(mctx, workers, 0, &tmgr);
1921*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1922*00b67f09SDavid van Moolenbroek t_info("isc_taskmgr_create failed %s\n",
1923*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1924*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1925*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T11_mx);
1926*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T11_cv);
1927*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1928*00b67f09SDavid van Moolenbroek }
1929*00b67f09SDavid van Moolenbroek
1930*00b67f09SDavid van Moolenbroek task = NULL;
1931*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(tmgr, 0, &task);
1932*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1933*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %s\n",
1934*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1935*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1936*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1937*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T11_mx);
1938*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T11_cv);
1939*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1940*00b67f09SDavid van Moolenbroek }
1941*00b67f09SDavid van Moolenbroek
1942*00b67f09SDavid van Moolenbroek isc_result = isc_task_onshutdown(task, t11_sde, NULL);
1943*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1944*00b67f09SDavid van Moolenbroek t_info("isc_task_onshutdown returned %s\n",
1945*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
1946*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1947*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1948*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1949*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T11_mx);
1950*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T11_cv);
1951*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1952*00b67f09SDavid van Moolenbroek }
1953*00b67f09SDavid van Moolenbroek
1954*00b67f09SDavid van Moolenbroek /*
1955*00b67f09SDavid van Moolenbroek * Block the task on T11_cv.
1956*00b67f09SDavid van Moolenbroek */
1957*00b67f09SDavid van Moolenbroek event1 = isc_event_allocate(mctx, (void *)1, (isc_eventtype_t)1,
1958*00b67f09SDavid van Moolenbroek t11_event1, NULL, sizeof(*event1));
1959*00b67f09SDavid van Moolenbroek if (event1 == NULL) {
1960*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
1961*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1962*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1963*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1964*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T11_mx);
1965*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T11_cv);
1966*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1967*00b67f09SDavid van Moolenbroek }
1968*00b67f09SDavid van Moolenbroek isc_task_send(task, &event1);
1969*00b67f09SDavid van Moolenbroek
1970*00b67f09SDavid van Moolenbroek event2 = isc_event_allocate(mctx, (void *)1, (isc_eventtype_t)1,
1971*00b67f09SDavid van Moolenbroek t11_event2, NULL, sizeof(*event2));
1972*00b67f09SDavid van Moolenbroek if (event2 == NULL) {
1973*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
1974*00b67f09SDavid van Moolenbroek isc_task_destroy(&task);
1975*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
1976*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
1977*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T11_mx);
1978*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T11_cv);
1979*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
1980*00b67f09SDavid van Moolenbroek }
1981*00b67f09SDavid van Moolenbroek event2_clone = event2;
1982*00b67f09SDavid van Moolenbroek if (purgable)
1983*00b67f09SDavid van Moolenbroek event2->ev_attributes &= ~ISC_EVENTATTR_NOPURGE;
1984*00b67f09SDavid van Moolenbroek else
1985*00b67f09SDavid van Moolenbroek event2->ev_attributes |= ISC_EVENTATTR_NOPURGE;
1986*00b67f09SDavid van Moolenbroek
1987*00b67f09SDavid van Moolenbroek isc_task_send(task, &event2);
1988*00b67f09SDavid van Moolenbroek
1989*00b67f09SDavid van Moolenbroek rval = isc_task_purgeevent(task, event2_clone);
1990*00b67f09SDavid van Moolenbroek if (rval != (purgable ? ISC_TRUE : ISC_FALSE)) {
1991*00b67f09SDavid van Moolenbroek t_info("isc_task_purgeevent returned %s, expected %s\n",
1992*00b67f09SDavid van Moolenbroek (rval ? "ISC_TRUE" : "ISC_FALSE"),
1993*00b67f09SDavid van Moolenbroek (purgable ? "ISC_TRUE" : "ISC_FALSE"));
1994*00b67f09SDavid van Moolenbroek ++T11_nfails;
1995*00b67f09SDavid van Moolenbroek }
1996*00b67f09SDavid van Moolenbroek
1997*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_lock(&T11_mx);
1998*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
1999*00b67f09SDavid van Moolenbroek t_info("isc_mutex_lock failed %s\n",
2000*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
2001*00b67f09SDavid van Moolenbroek ++T11_nprobs;
2002*00b67f09SDavid van Moolenbroek }
2003*00b67f09SDavid van Moolenbroek
2004*00b67f09SDavid van Moolenbroek /*
2005*00b67f09SDavid van Moolenbroek * Unblock the task, allowing event processing.
2006*00b67f09SDavid van Moolenbroek */
2007*00b67f09SDavid van Moolenbroek T11_startflag = 1;
2008*00b67f09SDavid van Moolenbroek isc_result = isc_condition_signal(&T11_cv);
2009*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
2010*00b67f09SDavid van Moolenbroek t_info("isc_condition_signal failed %s\n",
2011*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
2012*00b67f09SDavid van Moolenbroek ++T11_nprobs;
2013*00b67f09SDavid van Moolenbroek }
2014*00b67f09SDavid van Moolenbroek
2015*00b67f09SDavid van Moolenbroek isc_task_shutdown(task);
2016*00b67f09SDavid van Moolenbroek
2017*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 5, 0);
2018*00b67f09SDavid van Moolenbroek
2019*00b67f09SDavid van Moolenbroek /*
2020*00b67f09SDavid van Moolenbroek * Wait for shutdown processing to complete.
2021*00b67f09SDavid van Moolenbroek */
2022*00b67f09SDavid van Moolenbroek while (T11_shutdownflag == 0) {
2023*00b67f09SDavid van Moolenbroek isc_result = isc_time_nowplusinterval(&now, &interval);
2024*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
2025*00b67f09SDavid van Moolenbroek t_info("isc_time_nowplusinterval failed %s\n",
2026*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
2027*00b67f09SDavid van Moolenbroek ++T11_nprobs;
2028*00b67f09SDavid van Moolenbroek }
2029*00b67f09SDavid van Moolenbroek
2030*00b67f09SDavid van Moolenbroek isc_result = isc_condition_waituntil(&T11_cv, &T11_mx, &now);
2031*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
2032*00b67f09SDavid van Moolenbroek t_info("isc_condition_waituntil returned %s\n",
2033*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
2034*00b67f09SDavid van Moolenbroek ++T11_nprobs;
2035*00b67f09SDavid van Moolenbroek }
2036*00b67f09SDavid van Moolenbroek }
2037*00b67f09SDavid van Moolenbroek
2038*00b67f09SDavid van Moolenbroek isc_result = isc_mutex_unlock(&T11_mx);
2039*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
2040*00b67f09SDavid van Moolenbroek t_info("isc_mutex_unlock failed %s\n",
2041*00b67f09SDavid van Moolenbroek isc_result_totext(isc_result));
2042*00b67f09SDavid van Moolenbroek ++T11_nprobs;
2043*00b67f09SDavid van Moolenbroek }
2044*00b67f09SDavid van Moolenbroek
2045*00b67f09SDavid van Moolenbroek isc_task_detach(&task);
2046*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&tmgr);
2047*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
2048*00b67f09SDavid van Moolenbroek DESTROYLOCK(&T11_mx);
2049*00b67f09SDavid van Moolenbroek (void) isc_condition_destroy(&T11_cv);
2050*00b67f09SDavid van Moolenbroek
2051*00b67f09SDavid van Moolenbroek if (T11_eventcnt != (purgable ? 0 : 1)) {
2052*00b67f09SDavid van Moolenbroek t_info("Event was %s purged\n",
2053*00b67f09SDavid van Moolenbroek (purgable ? "not" : "unexpectedly"));
2054*00b67f09SDavid van Moolenbroek ++T11_nfails;
2055*00b67f09SDavid van Moolenbroek }
2056*00b67f09SDavid van Moolenbroek
2057*00b67f09SDavid van Moolenbroek result = T_UNRESOLVED;
2058*00b67f09SDavid van Moolenbroek
2059*00b67f09SDavid van Moolenbroek if ((T11_nfails == 0) && (T11_nprobs == 0))
2060*00b67f09SDavid van Moolenbroek result = T_PASS;
2061*00b67f09SDavid van Moolenbroek else if (T11_nfails)
2062*00b67f09SDavid van Moolenbroek result = T_FAIL;
2063*00b67f09SDavid van Moolenbroek
2064*00b67f09SDavid van Moolenbroek return(result);
2065*00b67f09SDavid van Moolenbroek }
2066*00b67f09SDavid van Moolenbroek
2067*00b67f09SDavid van Moolenbroek static const char *a11 =
2068*00b67f09SDavid van Moolenbroek "When the event is marked as purgable, a call to "
2069*00b67f09SDavid van Moolenbroek "isc_task_purgeevent(task, event) purges the event 'event' "
2070*00b67f09SDavid van Moolenbroek "from the task's queue and returns ISC_TRUE.";
2071*00b67f09SDavid van Moolenbroek
2072*00b67f09SDavid van Moolenbroek static void
t11(void)2073*00b67f09SDavid van Moolenbroek t11(void) {
2074*00b67f09SDavid van Moolenbroek t_assert("tasks", 11, T_REQUIRED, "%s", a11);
2075*00b67f09SDavid van Moolenbroek
2076*00b67f09SDavid van Moolenbroek if (threaded)
2077*00b67f09SDavid van Moolenbroek t_result(t_tasks11(1));
2078*00b67f09SDavid van Moolenbroek else
2079*00b67f09SDavid van Moolenbroek require_threads();
2080*00b67f09SDavid van Moolenbroek }
2081*00b67f09SDavid van Moolenbroek
2082*00b67f09SDavid van Moolenbroek static const char *a12 =
2083*00b67f09SDavid van Moolenbroek "When the event is not marked as purgable, a call to "
2084*00b67f09SDavid van Moolenbroek "isc_task_purgeevent(task, event) does not purge the "
2085*00b67f09SDavid van Moolenbroek "event 'event' from the task's queue and returns "
2086*00b67f09SDavid van Moolenbroek "ISC_FALSE.";
2087*00b67f09SDavid van Moolenbroek
2088*00b67f09SDavid van Moolenbroek static int
t_tasks12(void)2089*00b67f09SDavid van Moolenbroek t_tasks12(void) {
2090*00b67f09SDavid van Moolenbroek return(t_tasks11(0));
2091*00b67f09SDavid van Moolenbroek }
2092*00b67f09SDavid van Moolenbroek
2093*00b67f09SDavid van Moolenbroek static void
t12(void)2094*00b67f09SDavid van Moolenbroek t12(void) {
2095*00b67f09SDavid van Moolenbroek t_assert("tasks", 12, T_REQUIRED, "%s", a12);
2096*00b67f09SDavid van Moolenbroek
2097*00b67f09SDavid van Moolenbroek if (threaded)
2098*00b67f09SDavid van Moolenbroek t_result(t_tasks12());
2099*00b67f09SDavid van Moolenbroek else
2100*00b67f09SDavid van Moolenbroek require_threads();
2101*00b67f09SDavid van Moolenbroek }
2102*00b67f09SDavid van Moolenbroek
2103*00b67f09SDavid van Moolenbroek static int T13_nfails;
2104*00b67f09SDavid van Moolenbroek static int T13_nprobs;
2105*00b67f09SDavid van Moolenbroek
2106*00b67f09SDavid van Moolenbroek static const char *a13 =
2107*00b67f09SDavid van Moolenbroek "A call to "
2108*00b67f09SDavid van Moolenbroek "isc_event_purgerange(task, sender, first, last, tag) "
2109*00b67f09SDavid van Moolenbroek "purges all events not marked unpurgable from "
2110*00b67f09SDavid van Moolenbroek "sender 'sender' and of type within the range 'first' "
2111*00b67f09SDavid van Moolenbroek "to 'last' inclusive from the task's event queue and "
2112*00b67f09SDavid van Moolenbroek "returns the number of tasks purged.";
2113*00b67f09SDavid van Moolenbroek
2114*00b67f09SDavid van Moolenbroek static int
t_tasks13(void)2115*00b67f09SDavid van Moolenbroek t_tasks13(void) {
2116*00b67f09SDavid van Moolenbroek int result;
2117*00b67f09SDavid van Moolenbroek
2118*00b67f09SDavid van Moolenbroek T13_nfails = 0;
2119*00b67f09SDavid van Moolenbroek T13_nprobs = 0;
2120*00b67f09SDavid van Moolenbroek
2121*00b67f09SDavid van Moolenbroek /*
2122*00b67f09SDavid van Moolenbroek * First let's try the same cases we used in t10.
2123*00b67f09SDavid van Moolenbroek */
2124*00b67f09SDavid van Moolenbroek
2125*00b67f09SDavid van Moolenbroek /*
2126*00b67f09SDavid van Moolenbroek * Try purging on a specific sender.
2127*00b67f09SDavid van Moolenbroek */
2128*00b67f09SDavid van Moolenbroek t_info("testing purge on 2,4,8 expecting 1\n");
2129*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, &senders[2], 4, 4, (void *)8, 1,
2130*00b67f09SDavid van Moolenbroek &T13_nfails, &T13_nprobs, 1);
2131*00b67f09SDavid van Moolenbroek
2132*00b67f09SDavid van Moolenbroek /*
2133*00b67f09SDavid van Moolenbroek * Try purging on all senders.
2134*00b67f09SDavid van Moolenbroek */
2135*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,4,8 expecting 3\n");
2136*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 4, 4, (void *)8, 3,
2137*00b67f09SDavid van Moolenbroek &T13_nfails, &T13_nprobs, 1);
2138*00b67f09SDavid van Moolenbroek
2139*00b67f09SDavid van Moolenbroek /*
2140*00b67f09SDavid van Moolenbroek * Try purging on all senders, specified type, all tags.
2141*00b67f09SDavid van Moolenbroek */
2142*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,4,0 expecting 15\n");
2143*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 4, 4, NULL, 15, &T13_nfails, &T13_nprobs, 1);
2144*00b67f09SDavid van Moolenbroek
2145*00b67f09SDavid van Moolenbroek /*
2146*00b67f09SDavid van Moolenbroek * Try purging on a specified tag, no such type.
2147*00b67f09SDavid van Moolenbroek */
2148*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,99,8 expecting 0\n");
2149*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 99, 99, (void *)8, 0,
2150*00b67f09SDavid van Moolenbroek &T13_nfails, &T13_nprobs, 1);
2151*00b67f09SDavid van Moolenbroek
2152*00b67f09SDavid van Moolenbroek /*
2153*00b67f09SDavid van Moolenbroek * Try purging on specified sender, type, all tags.
2154*00b67f09SDavid van Moolenbroek */
2155*00b67f09SDavid van Moolenbroek t_info("testing purge on 3,5,0 expecting 5\n");
2156*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, &senders[3], 5, 5, 0, 5, &T13_nfails, &T13_nprobs, 1);
2157*00b67f09SDavid van Moolenbroek
2158*00b67f09SDavid van Moolenbroek /*
2159*00b67f09SDavid van Moolenbroek * Now let's try some ranges.
2160*00b67f09SDavid van Moolenbroek */
2161*00b67f09SDavid van Moolenbroek
2162*00b67f09SDavid van Moolenbroek t_info("testing purgerange on 2,4-5,8 expecting 2\n");
2163*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, &senders[2], 4, 5, (void *)8, 1,
2164*00b67f09SDavid van Moolenbroek &T13_nfails, &T13_nprobs, 1);
2165*00b67f09SDavid van Moolenbroek
2166*00b67f09SDavid van Moolenbroek /*
2167*00b67f09SDavid van Moolenbroek * Try purging on all senders.
2168*00b67f09SDavid van Moolenbroek */
2169*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,4-5,8 expecting 5\n");
2170*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 4, 5, (void *)8, 5,
2171*00b67f09SDavid van Moolenbroek &T13_nfails, &T13_nprobs, 1);
2172*00b67f09SDavid van Moolenbroek
2173*00b67f09SDavid van Moolenbroek /*
2174*00b67f09SDavid van Moolenbroek * Try purging on all senders, specified type, all tags.
2175*00b67f09SDavid van Moolenbroek */
2176*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,5-6,0 expecting 28\n");
2177*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 5, 6, NULL, 28, &T13_nfails, &T13_nprobs, 1);
2178*00b67f09SDavid van Moolenbroek
2179*00b67f09SDavid van Moolenbroek /*
2180*00b67f09SDavid van Moolenbroek * Try purging on a specified tag, no such type.
2181*00b67f09SDavid van Moolenbroek */
2182*00b67f09SDavid van Moolenbroek t_info("testing purge on 0,99-101,8 expecting 0\n");
2183*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, NULL, 99, 101, (void *)8, 0,
2184*00b67f09SDavid van Moolenbroek &T13_nfails, &T13_nprobs, 1);
2185*00b67f09SDavid van Moolenbroek
2186*00b67f09SDavid van Moolenbroek /*
2187*00b67f09SDavid van Moolenbroek * Try purging on specified sender, type, all tags.
2188*00b67f09SDavid van Moolenbroek */
2189*00b67f09SDavid van Moolenbroek t_info("testing purge on 3,5-6,0 expecting 10\n");
2190*00b67f09SDavid van Moolenbroek t_taskpurge_x(1, 4, 7, &senders[3], 5, 6, NULL, 10, &T13_nfails,
2191*00b67f09SDavid van Moolenbroek &T13_nprobs, 1);
2192*00b67f09SDavid van Moolenbroek
2193*00b67f09SDavid van Moolenbroek result = T_UNRESOLVED;
2194*00b67f09SDavid van Moolenbroek
2195*00b67f09SDavid van Moolenbroek if ((T13_nfails == 0) && (T13_nprobs == 0))
2196*00b67f09SDavid van Moolenbroek result = T_PASS;
2197*00b67f09SDavid van Moolenbroek else if (T13_nfails)
2198*00b67f09SDavid van Moolenbroek result = T_FAIL;
2199*00b67f09SDavid van Moolenbroek
2200*00b67f09SDavid van Moolenbroek return (result);
2201*00b67f09SDavid van Moolenbroek }
2202*00b67f09SDavid van Moolenbroek
2203*00b67f09SDavid van Moolenbroek static void
t13(void)2204*00b67f09SDavid van Moolenbroek t13(void) {
2205*00b67f09SDavid van Moolenbroek t_assert("tasks", 13, T_REQUIRED, "%s", a13);
2206*00b67f09SDavid van Moolenbroek
2207*00b67f09SDavid van Moolenbroek if (threaded)
2208*00b67f09SDavid van Moolenbroek t_result(t_tasks13());
2209*00b67f09SDavid van Moolenbroek else
2210*00b67f09SDavid van Moolenbroek require_threads();
2211*00b67f09SDavid van Moolenbroek }
2212*00b67f09SDavid van Moolenbroek
2213*00b67f09SDavid van Moolenbroek #define T14_NTASKS 10
2214*00b67f09SDavid van Moolenbroek #define T14_EXCLTASK 6
2215*00b67f09SDavid van Moolenbroek
2216*00b67f09SDavid van Moolenbroek int t14_exclusiveerror = ISC_R_SUCCESS;
2217*00b67f09SDavid van Moolenbroek int t14_error = 0;
2218*00b67f09SDavid van Moolenbroek int t14_done = 0;
2219*00b67f09SDavid van Moolenbroek
2220*00b67f09SDavid van Moolenbroek int spin(int n);
2221*00b67f09SDavid van Moolenbroek
2222*00b67f09SDavid van Moolenbroek int t14_active[T14_NTASKS];
2223*00b67f09SDavid van Moolenbroek
2224*00b67f09SDavid van Moolenbroek static void
t14_callback(isc_task_t * task,isc_event_t * event)2225*00b67f09SDavid van Moolenbroek t14_callback(isc_task_t *task, isc_event_t *event) {
2226*00b67f09SDavid van Moolenbroek int taskno = *(int *)(event->ev_arg);
2227*00b67f09SDavid van Moolenbroek
2228*00b67f09SDavid van Moolenbroek
2229*00b67f09SDavid van Moolenbroek t_info("task enter %d\n", taskno);
2230*00b67f09SDavid van Moolenbroek if (taskno == T14_EXCLTASK) {
2231*00b67f09SDavid van Moolenbroek int i;
2232*00b67f09SDavid van Moolenbroek t14_exclusiveerror = isc_task_beginexclusive(task);
2233*00b67f09SDavid van Moolenbroek if (t14_exclusiveerror == ISC_R_SUCCESS)
2234*00b67f09SDavid van Moolenbroek t_info("task %d got exclusive access\n", taskno);
2235*00b67f09SDavid van Moolenbroek else
2236*00b67f09SDavid van Moolenbroek t_info("task %d failed to got exclusive access: %d\n",
2237*00b67f09SDavid van Moolenbroek taskno, t14_exclusiveerror);
2238*00b67f09SDavid van Moolenbroek for (i = 0; i < T14_NTASKS; i++) {
2239*00b67f09SDavid van Moolenbroek t_info("task %d state %d\n", i , t14_active[i]);
2240*00b67f09SDavid van Moolenbroek if (t14_active[i])
2241*00b67f09SDavid van Moolenbroek t14_error++;
2242*00b67f09SDavid van Moolenbroek }
2243*00b67f09SDavid van Moolenbroek isc_task_endexclusive(task);
2244*00b67f09SDavid van Moolenbroek t14_done = 1;
2245*00b67f09SDavid van Moolenbroek } else {
2246*00b67f09SDavid van Moolenbroek t14_active[taskno]++;
2247*00b67f09SDavid van Moolenbroek (void) spin(10000000);
2248*00b67f09SDavid van Moolenbroek t14_active[taskno]--;
2249*00b67f09SDavid van Moolenbroek }
2250*00b67f09SDavid van Moolenbroek t_info("task exit %d\n", taskno);
2251*00b67f09SDavid van Moolenbroek if (t14_done) {
2252*00b67f09SDavid van Moolenbroek isc_mem_put(event->ev_destroy_arg, event->ev_arg, sizeof (int));
2253*00b67f09SDavid van Moolenbroek isc_event_free(&event);
2254*00b67f09SDavid van Moolenbroek } else {
2255*00b67f09SDavid van Moolenbroek isc_task_send(task, &event);
2256*00b67f09SDavid van Moolenbroek }
2257*00b67f09SDavid van Moolenbroek }
2258*00b67f09SDavid van Moolenbroek
spin(int n)2259*00b67f09SDavid van Moolenbroek int spin(int n) {
2260*00b67f09SDavid van Moolenbroek int i;
2261*00b67f09SDavid van Moolenbroek int r = 0;
2262*00b67f09SDavid van Moolenbroek for (i = 0; i < n; i++) {
2263*00b67f09SDavid van Moolenbroek r += i;
2264*00b67f09SDavid van Moolenbroek if (r > 1000000)
2265*00b67f09SDavid van Moolenbroek r = 0;
2266*00b67f09SDavid van Moolenbroek }
2267*00b67f09SDavid van Moolenbroek return (r);
2268*00b67f09SDavid van Moolenbroek }
2269*00b67f09SDavid van Moolenbroek
2270*00b67f09SDavid van Moolenbroek static int
t_tasks14(void)2271*00b67f09SDavid van Moolenbroek t_tasks14(void) {
2272*00b67f09SDavid van Moolenbroek char *p;
2273*00b67f09SDavid van Moolenbroek isc_mem_t *mctx;
2274*00b67f09SDavid van Moolenbroek isc_taskmgr_t *manager;
2275*00b67f09SDavid van Moolenbroek isc_task_t *tasks[T14_NTASKS];
2276*00b67f09SDavid van Moolenbroek unsigned int workers;
2277*00b67f09SDavid van Moolenbroek isc_result_t isc_result;
2278*00b67f09SDavid van Moolenbroek int i;
2279*00b67f09SDavid van Moolenbroek
2280*00b67f09SDavid van Moolenbroek manager = NULL;
2281*00b67f09SDavid van Moolenbroek mctx = NULL;
2282*00b67f09SDavid van Moolenbroek
2283*00b67f09SDavid van Moolenbroek for (i = 0; i < T14_NTASKS; i++)
2284*00b67f09SDavid van Moolenbroek tasks[i] = NULL;
2285*00b67f09SDavid van Moolenbroek
2286*00b67f09SDavid van Moolenbroek workers = 4;
2287*00b67f09SDavid van Moolenbroek p = t_getenv("ISC_TASK_WORKERS");
2288*00b67f09SDavid van Moolenbroek if (p != NULL)
2289*00b67f09SDavid van Moolenbroek workers = atoi(p);
2290*00b67f09SDavid van Moolenbroek if (workers < 1) {
2291*00b67f09SDavid van Moolenbroek t_info("Bad config value for ISC_TASK_WORKERS, %d\n", workers);
2292*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
2293*00b67f09SDavid van Moolenbroek }
2294*00b67f09SDavid van Moolenbroek
2295*00b67f09SDavid van Moolenbroek isc_result = isc_mem_create(0, 0, &mctx);
2296*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
2297*00b67f09SDavid van Moolenbroek t_info("isc_mem_create failed %d\n", isc_result);
2298*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
2299*00b67f09SDavid van Moolenbroek }
2300*00b67f09SDavid van Moolenbroek
2301*00b67f09SDavid van Moolenbroek isc_result = isc_taskmgr_create(mctx, workers, 0, &manager);
2302*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
2303*00b67f09SDavid van Moolenbroek t_info("isc_taskmgr_create failed %d\n", isc_result);
2304*00b67f09SDavid van Moolenbroek return(T_FAIL);
2305*00b67f09SDavid van Moolenbroek }
2306*00b67f09SDavid van Moolenbroek
2307*00b67f09SDavid van Moolenbroek for (i = 0; i < T14_NTASKS; i++) {
2308*00b67f09SDavid van Moolenbroek isc_event_t *event;
2309*00b67f09SDavid van Moolenbroek int *v;
2310*00b67f09SDavid van Moolenbroek
2311*00b67f09SDavid van Moolenbroek isc_result = isc_task_create(manager, 0, &tasks[i]);
2312*00b67f09SDavid van Moolenbroek if (isc_result != ISC_R_SUCCESS) {
2313*00b67f09SDavid van Moolenbroek t_info("isc_task_create failed %d\n", isc_result);
2314*00b67f09SDavid van Moolenbroek return(T_FAIL);
2315*00b67f09SDavid van Moolenbroek }
2316*00b67f09SDavid van Moolenbroek
2317*00b67f09SDavid van Moolenbroek v = isc_mem_get(mctx, sizeof *v);
2318*00b67f09SDavid van Moolenbroek if (v == NULL) {
2319*00b67f09SDavid van Moolenbroek isc_task_detach(&tasks[i]);
2320*00b67f09SDavid van Moolenbroek t_info("isc_mem_get failed\n");
2321*00b67f09SDavid van Moolenbroek return(T_FAIL);
2322*00b67f09SDavid van Moolenbroek }
2323*00b67f09SDavid van Moolenbroek *v = i;
2324*00b67f09SDavid van Moolenbroek
2325*00b67f09SDavid van Moolenbroek event = isc_event_allocate(mctx, NULL, 1, t14_callback,
2326*00b67f09SDavid van Moolenbroek v, sizeof(*event));
2327*00b67f09SDavid van Moolenbroek if (event == NULL) {
2328*00b67f09SDavid van Moolenbroek isc_mem_put(mctx, v, sizeof *v);
2329*00b67f09SDavid van Moolenbroek t_info("isc_event_allocate failed\n");
2330*00b67f09SDavid van Moolenbroek return(T_UNRESOLVED);
2331*00b67f09SDavid van Moolenbroek }
2332*00b67f09SDavid van Moolenbroek isc_task_send(tasks[i], &event);
2333*00b67f09SDavid van Moolenbroek }
2334*00b67f09SDavid van Moolenbroek
2335*00b67f09SDavid van Moolenbroek for (i = 0; i < T14_NTASKS; i++) {
2336*00b67f09SDavid van Moolenbroek isc_task_detach(&tasks[i]);
2337*00b67f09SDavid van Moolenbroek }
2338*00b67f09SDavid van Moolenbroek
2339*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&manager);
2340*00b67f09SDavid van Moolenbroek
2341*00b67f09SDavid van Moolenbroek if (t14_exclusiveerror != ISC_R_SUCCESS || t14_error) {
2342*00b67f09SDavid van Moolenbroek if (t14_exclusiveerror != ISC_R_SUCCESS)
2343*00b67f09SDavid van Moolenbroek t_info("isc_task_beginexclusive() failed\n");
2344*00b67f09SDavid van Moolenbroek if (t14_error)
2345*00b67f09SDavid van Moolenbroek t_info("mutual access occurred\n");
2346*00b67f09SDavid van Moolenbroek return(T_FAIL);
2347*00b67f09SDavid van Moolenbroek }
2348*00b67f09SDavid van Moolenbroek
2349*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
2350*00b67f09SDavid van Moolenbroek return(T_PASS);
2351*00b67f09SDavid van Moolenbroek }
2352*00b67f09SDavid van Moolenbroek
2353*00b67f09SDavid van Moolenbroek static void
t14(void)2354*00b67f09SDavid van Moolenbroek t14(void) {
2355*00b67f09SDavid van Moolenbroek int result;
2356*00b67f09SDavid van Moolenbroek
2357*00b67f09SDavid van Moolenbroek t_assert("tasks", 14, T_REQUIRED, "%s",
2358*00b67f09SDavid van Moolenbroek "isc_task_beginexclusive() gets exclusive access");
2359*00b67f09SDavid van Moolenbroek result = t_tasks14();
2360*00b67f09SDavid van Moolenbroek t_result(result);
2361*00b67f09SDavid van Moolenbroek }
2362*00b67f09SDavid van Moolenbroek
2363*00b67f09SDavid van Moolenbroek testspec_t T_testlist[] = {
2364*00b67f09SDavid van Moolenbroek { (PFV) t1, "basic task subsystem" },
2365*00b67f09SDavid van Moolenbroek { (PFV) t2, "maxtasks" },
2366*00b67f09SDavid van Moolenbroek { (PFV) t3, "isc_task_shutdown" },
2367*00b67f09SDavid van Moolenbroek { (PFV) t4, "isc_task_shutdown" },
2368*00b67f09SDavid van Moolenbroek { (PFV) t7, "isc_task_create" },
2369*00b67f09SDavid van Moolenbroek { (PFV) t10, "isc_task_purge" },
2370*00b67f09SDavid van Moolenbroek { (PFV) t11, "isc_task_purgeevent" },
2371*00b67f09SDavid van Moolenbroek { (PFV) t12, "isc_task_purgeevent" },
2372*00b67f09SDavid van Moolenbroek { (PFV) t13, "isc_task_purgerange" },
2373*00b67f09SDavid van Moolenbroek { (PFV) t14, "isc_task_beginexclusive" },
2374*00b67f09SDavid van Moolenbroek { (PFV) 0, NULL }
2375*00b67f09SDavid van Moolenbroek };
2376*00b67f09SDavid van Moolenbroek
2377*00b67f09SDavid van Moolenbroek #ifdef WIN32
2378*00b67f09SDavid van Moolenbroek int
main(int argc,char ** argv)2379*00b67f09SDavid van Moolenbroek main(int argc, char **argv) {
2380*00b67f09SDavid van Moolenbroek t_settests(T_testlist);
2381*00b67f09SDavid van Moolenbroek return (t_main(argc, argv));
2382*00b67f09SDavid van Moolenbroek }
2383*00b67f09SDavid van Moolenbroek #endif
2384