1*00b67f09SDavid van Moolenbroek /* $NetBSD: timer_test.c,v 1.8 2014/12/10 04:37:53 christos Exp $ */
2*00b67f09SDavid van Moolenbroek
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek * Copyright (C) 2004, 2007, 2013, 2014 Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek * Copyright (C) 1998-2001 Internet Software Consortium.
6*00b67f09SDavid van Moolenbroek *
7*00b67f09SDavid van Moolenbroek * Permission to use, copy, modify, and/or distribute this software for any
8*00b67f09SDavid van Moolenbroek * purpose with or without fee is hereby granted, provided that the above
9*00b67f09SDavid van Moolenbroek * copyright notice and this permission notice appear in all copies.
10*00b67f09SDavid van Moolenbroek *
11*00b67f09SDavid van Moolenbroek * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
12*00b67f09SDavid van Moolenbroek * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
13*00b67f09SDavid van Moolenbroek * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
14*00b67f09SDavid van Moolenbroek * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
15*00b67f09SDavid van Moolenbroek * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
16*00b67f09SDavid van Moolenbroek * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*00b67f09SDavid van Moolenbroek * PERFORMANCE OF THIS SOFTWARE.
18*00b67f09SDavid van Moolenbroek */
19*00b67f09SDavid van Moolenbroek
20*00b67f09SDavid van Moolenbroek /* Id: timer_test.c,v 1.40 2007/06/19 23:46:59 tbox Exp */
21*00b67f09SDavid van Moolenbroek
22*00b67f09SDavid van Moolenbroek #include <config.h>
23*00b67f09SDavid van Moolenbroek
24*00b67f09SDavid van Moolenbroek #include <stdlib.h>
25*00b67f09SDavid van Moolenbroek #include <string.h>
26*00b67f09SDavid van Moolenbroek #include <unistd.h>
27*00b67f09SDavid van Moolenbroek
28*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
29*00b67f09SDavid van Moolenbroek #include <isc/task.h>
30*00b67f09SDavid van Moolenbroek #include <isc/time.h>
31*00b67f09SDavid van Moolenbroek #include <isc/timer.h>
32*00b67f09SDavid van Moolenbroek #include <isc/util.h>
33*00b67f09SDavid van Moolenbroek
34*00b67f09SDavid van Moolenbroek isc_mem_t *mctx1, *mctx2, *mctx3;
35*00b67f09SDavid van Moolenbroek isc_task_t *t1, *t2, *t3;
36*00b67f09SDavid van Moolenbroek isc_timer_t *ti1, *ti2, *ti3;
37*00b67f09SDavid van Moolenbroek int tick_count = 0;
38*00b67f09SDavid van Moolenbroek
39*00b67f09SDavid van Moolenbroek static void
shutdown_task(isc_task_t * task,isc_event_t * event)40*00b67f09SDavid van Moolenbroek shutdown_task(isc_task_t *task, isc_event_t *event) {
41*00b67f09SDavid van Moolenbroek char *name = event->ev_arg;
42*00b67f09SDavid van Moolenbroek
43*00b67f09SDavid van Moolenbroek printf("task %p shutdown %s\n", task, name);
44*00b67f09SDavid van Moolenbroek isc_event_free(&event);
45*00b67f09SDavid van Moolenbroek }
46*00b67f09SDavid van Moolenbroek
47*00b67f09SDavid van Moolenbroek static void
tick(isc_task_t * task,isc_event_t * event)48*00b67f09SDavid van Moolenbroek tick(isc_task_t *task, isc_event_t *event) {
49*00b67f09SDavid van Moolenbroek char *name = event->ev_arg;
50*00b67f09SDavid van Moolenbroek
51*00b67f09SDavid van Moolenbroek INSIST(event->ev_type == ISC_TIMEREVENT_TICK);
52*00b67f09SDavid van Moolenbroek
53*00b67f09SDavid van Moolenbroek printf("task %s (%p) tick\n", name, task);
54*00b67f09SDavid van Moolenbroek
55*00b67f09SDavid van Moolenbroek tick_count++;
56*00b67f09SDavid van Moolenbroek if (ti3 != NULL && tick_count % 3 == 0)
57*00b67f09SDavid van Moolenbroek isc_timer_touch(ti3);
58*00b67f09SDavid van Moolenbroek
59*00b67f09SDavid van Moolenbroek if (ti3 != NULL && tick_count == 7) {
60*00b67f09SDavid van Moolenbroek isc_time_t expires;
61*00b67f09SDavid van Moolenbroek isc_interval_t interval;
62*00b67f09SDavid van Moolenbroek
63*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 5, 0);
64*00b67f09SDavid van Moolenbroek (void)isc_time_nowplusinterval(&expires, &interval);
65*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 4, 0);
66*00b67f09SDavid van Moolenbroek printf("*** resetting ti3 ***\n");
67*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_timer_reset(ti3, isc_timertype_once,
68*00b67f09SDavid van Moolenbroek &expires, &interval, ISC_TRUE) ==
69*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
70*00b67f09SDavid van Moolenbroek }
71*00b67f09SDavid van Moolenbroek
72*00b67f09SDavid van Moolenbroek isc_event_free(&event);
73*00b67f09SDavid van Moolenbroek }
74*00b67f09SDavid van Moolenbroek
75*00b67f09SDavid van Moolenbroek static void
timeout(isc_task_t * task,isc_event_t * event)76*00b67f09SDavid van Moolenbroek timeout(isc_task_t *task, isc_event_t *event) {
77*00b67f09SDavid van Moolenbroek char *name = event->ev_arg;
78*00b67f09SDavid van Moolenbroek const char *type;
79*00b67f09SDavid van Moolenbroek
80*00b67f09SDavid van Moolenbroek INSIST(event->ev_type == ISC_TIMEREVENT_IDLE ||
81*00b67f09SDavid van Moolenbroek event->ev_type == ISC_TIMEREVENT_LIFE);
82*00b67f09SDavid van Moolenbroek
83*00b67f09SDavid van Moolenbroek if (event->ev_type == ISC_TIMEREVENT_IDLE)
84*00b67f09SDavid van Moolenbroek type = "idle";
85*00b67f09SDavid van Moolenbroek else
86*00b67f09SDavid van Moolenbroek type = "life";
87*00b67f09SDavid van Moolenbroek printf("task %s (%p) %s timeout\n", name, task, type);
88*00b67f09SDavid van Moolenbroek
89*00b67f09SDavid van Moolenbroek if (strcmp(name, "3") == 0) {
90*00b67f09SDavid van Moolenbroek printf("*** saving task 3 ***\n");
91*00b67f09SDavid van Moolenbroek isc_event_free(&event);
92*00b67f09SDavid van Moolenbroek return;
93*00b67f09SDavid van Moolenbroek }
94*00b67f09SDavid van Moolenbroek
95*00b67f09SDavid van Moolenbroek isc_event_free(&event);
96*00b67f09SDavid van Moolenbroek isc_task_shutdown(task);
97*00b67f09SDavid van Moolenbroek }
98*00b67f09SDavid van Moolenbroek
99*00b67f09SDavid van Moolenbroek static char one[] = "1";
100*00b67f09SDavid van Moolenbroek static char two[] = "2";
101*00b67f09SDavid van Moolenbroek static char three[] = "3";
102*00b67f09SDavid van Moolenbroek
103*00b67f09SDavid van Moolenbroek int
main(int argc,char * argv[])104*00b67f09SDavid van Moolenbroek main(int argc, char *argv[]) {
105*00b67f09SDavid van Moolenbroek isc_taskmgr_t *manager = NULL;
106*00b67f09SDavid van Moolenbroek isc_timermgr_t *timgr = NULL;
107*00b67f09SDavid van Moolenbroek unsigned int workers;
108*00b67f09SDavid van Moolenbroek isc_time_t expires, now;
109*00b67f09SDavid van Moolenbroek isc_interval_t interval;
110*00b67f09SDavid van Moolenbroek
111*00b67f09SDavid van Moolenbroek if (argc > 1) {
112*00b67f09SDavid van Moolenbroek workers = atoi(argv[1]);
113*00b67f09SDavid van Moolenbroek if (workers < 1)
114*00b67f09SDavid van Moolenbroek workers = 1;
115*00b67f09SDavid van Moolenbroek if (workers > 8192)
116*00b67f09SDavid van Moolenbroek workers = 8192;
117*00b67f09SDavid van Moolenbroek } else
118*00b67f09SDavid van Moolenbroek workers = 2;
119*00b67f09SDavid van Moolenbroek printf("%d workers\n", workers);
120*00b67f09SDavid van Moolenbroek
121*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_mem_create(0, 0, &mctx1) == ISC_R_SUCCESS);
122*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_taskmgr_create(mctx1, workers, 0, &manager) ==
123*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
124*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_timermgr_create(mctx1, &timgr) == ISC_R_SUCCESS);
125*00b67f09SDavid van Moolenbroek
126*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_task_create(manager, 0, &t1) ==
127*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
128*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_task_create(manager, 0, &t2) ==
129*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
130*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_task_create(manager, 0, &t3) ==
131*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
132*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_task_onshutdown(t1, shutdown_task, one) ==
133*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
134*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_task_onshutdown(t2, shutdown_task, two) ==
135*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
136*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_task_onshutdown(t3, shutdown_task, three) ==
137*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
138*00b67f09SDavid van Moolenbroek
139*00b67f09SDavid van Moolenbroek printf("task 1: %p\n", t1);
140*00b67f09SDavid van Moolenbroek printf("task 2: %p\n", t2);
141*00b67f09SDavid van Moolenbroek printf("task 3: %p\n", t3);
142*00b67f09SDavid van Moolenbroek
143*00b67f09SDavid van Moolenbroek TIME_NOW(&now);
144*00b67f09SDavid van Moolenbroek
145*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 2, 0);
146*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_timer_create(timgr, isc_timertype_once, NULL,
147*00b67f09SDavid van Moolenbroek &interval, t2, timeout, two, &ti2) ==
148*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
149*00b67f09SDavid van Moolenbroek
150*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 1, 0);
151*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_timer_create(timgr, isc_timertype_ticker, NULL,
152*00b67f09SDavid van Moolenbroek &interval, t1, tick, one, &ti1) ==
153*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
154*00b67f09SDavid van Moolenbroek
155*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 10, 0);
156*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_time_add(&now, &interval, &expires) ==
157*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
158*00b67f09SDavid van Moolenbroek isc_interval_set(&interval, 2, 0);
159*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_timer_create(timgr, isc_timertype_once, &expires,
160*00b67f09SDavid van Moolenbroek &interval, t3, timeout, three, &ti3) ==
161*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
162*00b67f09SDavid van Moolenbroek
163*00b67f09SDavid van Moolenbroek isc_task_detach(&t1);
164*00b67f09SDavid van Moolenbroek isc_task_detach(&t2);
165*00b67f09SDavid van Moolenbroek isc_task_detach(&t3);
166*00b67f09SDavid van Moolenbroek
167*00b67f09SDavid van Moolenbroek #ifndef WIN32
168*00b67f09SDavid van Moolenbroek sleep(15);
169*00b67f09SDavid van Moolenbroek #else
170*00b67f09SDavid van Moolenbroek Sleep(15000);
171*00b67f09SDavid van Moolenbroek #endif
172*00b67f09SDavid van Moolenbroek printf("destroy\n");
173*00b67f09SDavid van Moolenbroek isc_timer_detach(&ti1);
174*00b67f09SDavid van Moolenbroek isc_timer_detach(&ti2);
175*00b67f09SDavid van Moolenbroek isc_timer_detach(&ti3);
176*00b67f09SDavid van Moolenbroek #ifndef WIN32
177*00b67f09SDavid van Moolenbroek sleep(2);
178*00b67f09SDavid van Moolenbroek #else
179*00b67f09SDavid van Moolenbroek Sleep(2000);
180*00b67f09SDavid van Moolenbroek #endif
181*00b67f09SDavid van Moolenbroek isc_timermgr_destroy(&timgr);
182*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&manager);
183*00b67f09SDavid van Moolenbroek printf("destroyed\n");
184*00b67f09SDavid van Moolenbroek
185*00b67f09SDavid van Moolenbroek printf("Statistics for mctx1:\n");
186*00b67f09SDavid van Moolenbroek isc_mem_stats(mctx1, stdout);
187*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx1);
188*00b67f09SDavid van Moolenbroek
189*00b67f09SDavid van Moolenbroek return (0);
190*00b67f09SDavid van Moolenbroek }
191