1*00b67f09SDavid van Moolenbroek /* $NetBSD: sig0_test.c,v 1.8 2015/07/08 17:28:55 christos Exp $ */
2*00b67f09SDavid van Moolenbroek
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek * Copyright (C) 2004, 2005, 2007-2009, 2012, 2015 Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek * Copyright (C) 2000, 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: sig0_test.c,v 1.19 2009/09/02 23:48:01 tbox Exp */
21*00b67f09SDavid van Moolenbroek
22*00b67f09SDavid van Moolenbroek #include <config.h>
23*00b67f09SDavid van Moolenbroek
24*00b67f09SDavid van Moolenbroek #include <stddef.h>
25*00b67f09SDavid van Moolenbroek #include <stdlib.h>
26*00b67f09SDavid van Moolenbroek #include <string.h>
27*00b67f09SDavid van Moolenbroek
28*00b67f09SDavid van Moolenbroek #include <isc/app.h>
29*00b67f09SDavid van Moolenbroek #include <isc/boolean.h>
30*00b67f09SDavid van Moolenbroek #include <isc/assertions.h>
31*00b67f09SDavid van Moolenbroek #include <isc/commandline.h>
32*00b67f09SDavid van Moolenbroek #include <isc/entropy.h>
33*00b67f09SDavid van Moolenbroek #include <isc/error.h>
34*00b67f09SDavid van Moolenbroek #include <isc/log.h>
35*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
36*00b67f09SDavid van Moolenbroek #include <isc/mutex.h>
37*00b67f09SDavid van Moolenbroek #include <isc/net.h>
38*00b67f09SDavid van Moolenbroek #include <isc/task.h>
39*00b67f09SDavid van Moolenbroek #include <isc/timer.h>
40*00b67f09SDavid van Moolenbroek #include <isc/socket.h>
41*00b67f09SDavid van Moolenbroek #include <isc/util.h>
42*00b67f09SDavid van Moolenbroek
43*00b67f09SDavid van Moolenbroek #include <dns/dnssec.h>
44*00b67f09SDavid van Moolenbroek #include <dns/events.h>
45*00b67f09SDavid van Moolenbroek #include <dns/fixedname.h>
46*00b67f09SDavid van Moolenbroek #include <dns/keyvalues.h>
47*00b67f09SDavid van Moolenbroek #include <dns/masterdump.h>
48*00b67f09SDavid van Moolenbroek #include <dns/message.h>
49*00b67f09SDavid van Moolenbroek #include <dns/name.h>
50*00b67f09SDavid van Moolenbroek #include <dns/rdataset.h>
51*00b67f09SDavid van Moolenbroek #include <dns/resolver.h>
52*00b67f09SDavid van Moolenbroek #include <dns/result.h>
53*00b67f09SDavid van Moolenbroek #include <dns/types.h>
54*00b67f09SDavid van Moolenbroek
55*00b67f09SDavid van Moolenbroek #include <dst/result.h>
56*00b67f09SDavid van Moolenbroek #include <dst/dst.h>
57*00b67f09SDavid van Moolenbroek
58*00b67f09SDavid van Moolenbroek #define CHECK(str, x) { \
59*00b67f09SDavid van Moolenbroek if ((x) != ISC_R_SUCCESS) { \
60*00b67f09SDavid van Moolenbroek printf("%s: %s\n", (str), isc_result_totext(x)); \
61*00b67f09SDavid van Moolenbroek exit(-1); \
62*00b67f09SDavid van Moolenbroek } \
63*00b67f09SDavid van Moolenbroek }
64*00b67f09SDavid van Moolenbroek
65*00b67f09SDavid van Moolenbroek isc_mutex_t lock;
66*00b67f09SDavid van Moolenbroek dst_key_t *key;
67*00b67f09SDavid van Moolenbroek isc_mem_t *mctx;
68*00b67f09SDavid van Moolenbroek unsigned char qdata[1024], rdata[1024];
69*00b67f09SDavid van Moolenbroek isc_buffer_t qbuffer, rbuffer;
70*00b67f09SDavid van Moolenbroek isc_taskmgr_t *taskmgr;
71*00b67f09SDavid van Moolenbroek isc_entropy_t *ent = NULL;
72*00b67f09SDavid van Moolenbroek isc_task_t *task1;
73*00b67f09SDavid van Moolenbroek isc_log_t *lctx = NULL;
74*00b67f09SDavid van Moolenbroek isc_logconfig_t *logconfig = NULL;
75*00b67f09SDavid van Moolenbroek isc_socket_t *s;
76*00b67f09SDavid van Moolenbroek isc_sockaddr_t address;
77*00b67f09SDavid van Moolenbroek char output[10 * 1024];
78*00b67f09SDavid van Moolenbroek isc_buffer_t outbuf;
79*00b67f09SDavid van Moolenbroek static const dns_master_style_t *style = &dns_master_style_debug;
80*00b67f09SDavid van Moolenbroek
81*00b67f09SDavid van Moolenbroek static void
senddone(isc_task_t * task,isc_event_t * event)82*00b67f09SDavid van Moolenbroek senddone(isc_task_t *task, isc_event_t *event) {
83*00b67f09SDavid van Moolenbroek isc_socketevent_t *sevent = (isc_socketevent_t *)event;
84*00b67f09SDavid van Moolenbroek
85*00b67f09SDavid van Moolenbroek REQUIRE(sevent != NULL);
86*00b67f09SDavid van Moolenbroek REQUIRE(sevent->ev_type == ISC_SOCKEVENT_SENDDONE);
87*00b67f09SDavid van Moolenbroek REQUIRE(task == task1);
88*00b67f09SDavid van Moolenbroek
89*00b67f09SDavid van Moolenbroek printf("senddone\n");
90*00b67f09SDavid van Moolenbroek
91*00b67f09SDavid van Moolenbroek isc_event_free(&event);
92*00b67f09SDavid van Moolenbroek }
93*00b67f09SDavid van Moolenbroek
94*00b67f09SDavid van Moolenbroek static void
recvdone(isc_task_t * task,isc_event_t * event)95*00b67f09SDavid van Moolenbroek recvdone(isc_task_t *task, isc_event_t *event) {
96*00b67f09SDavid van Moolenbroek isc_socketevent_t *sevent = (isc_socketevent_t *)event;
97*00b67f09SDavid van Moolenbroek isc_buffer_t source;
98*00b67f09SDavid van Moolenbroek isc_result_t result;
99*00b67f09SDavid van Moolenbroek dns_message_t *response;
100*00b67f09SDavid van Moolenbroek
101*00b67f09SDavid van Moolenbroek REQUIRE(sevent != NULL);
102*00b67f09SDavid van Moolenbroek REQUIRE(sevent->ev_type == ISC_SOCKEVENT_RECVDONE);
103*00b67f09SDavid van Moolenbroek REQUIRE(task == task1);
104*00b67f09SDavid van Moolenbroek
105*00b67f09SDavid van Moolenbroek printf("recvdone\n");
106*00b67f09SDavid van Moolenbroek if (sevent->result != ISC_R_SUCCESS) {
107*00b67f09SDavid van Moolenbroek printf("failed\n");
108*00b67f09SDavid van Moolenbroek exit(-1);
109*00b67f09SDavid van Moolenbroek }
110*00b67f09SDavid van Moolenbroek
111*00b67f09SDavid van Moolenbroek isc_buffer_init(&source, sevent->region.base, sevent->region.length);
112*00b67f09SDavid van Moolenbroek isc_buffer_add(&source, sevent->n);
113*00b67f09SDavid van Moolenbroek
114*00b67f09SDavid van Moolenbroek response = NULL;
115*00b67f09SDavid van Moolenbroek result = dns_message_create(mctx, DNS_MESSAGE_INTENTPARSE, &response);
116*00b67f09SDavid van Moolenbroek CHECK("dns_message_create", result);
117*00b67f09SDavid van Moolenbroek result = dns_message_parse(response, &source, 0);
118*00b67f09SDavid van Moolenbroek CHECK("dns_message_parse", result);
119*00b67f09SDavid van Moolenbroek
120*00b67f09SDavid van Moolenbroek isc_buffer_init(&outbuf, output, sizeof(output));
121*00b67f09SDavid van Moolenbroek result = dns_message_totext(response, style, 0, &outbuf);
122*00b67f09SDavid van Moolenbroek CHECK("dns_message_totext", result);
123*00b67f09SDavid van Moolenbroek printf("%.*s\n", (int)isc_buffer_usedlength(&outbuf),
124*00b67f09SDavid van Moolenbroek (char *)isc_buffer_base(&outbuf));
125*00b67f09SDavid van Moolenbroek
126*00b67f09SDavid van Moolenbroek dns_message_destroy(&response);
127*00b67f09SDavid van Moolenbroek isc_event_free(&event);
128*00b67f09SDavid van Moolenbroek
129*00b67f09SDavid van Moolenbroek isc_app_shutdown();
130*00b67f09SDavid van Moolenbroek }
131*00b67f09SDavid van Moolenbroek
132*00b67f09SDavid van Moolenbroek static void
buildquery(void)133*00b67f09SDavid van Moolenbroek buildquery(void) {
134*00b67f09SDavid van Moolenbroek isc_result_t result;
135*00b67f09SDavid van Moolenbroek dns_rdataset_t *question = NULL;
136*00b67f09SDavid van Moolenbroek dns_name_t *qname = NULL;
137*00b67f09SDavid van Moolenbroek isc_region_t r, inr;
138*00b67f09SDavid van Moolenbroek dns_message_t *query;
139*00b67f09SDavid van Moolenbroek char nametext[] = "host.example";
140*00b67f09SDavid van Moolenbroek isc_buffer_t namesrc, namedst;
141*00b67f09SDavid van Moolenbroek unsigned char namedata[256];
142*00b67f09SDavid van Moolenbroek isc_sockaddr_t sa;
143*00b67f09SDavid van Moolenbroek dns_compress_t cctx;
144*00b67f09SDavid van Moolenbroek
145*00b67f09SDavid van Moolenbroek query = NULL;
146*00b67f09SDavid van Moolenbroek result = dns_message_create(mctx, DNS_MESSAGE_INTENTRENDER, &query);
147*00b67f09SDavid van Moolenbroek CHECK("dns_message_create", result);
148*00b67f09SDavid van Moolenbroek result = dns_message_setsig0key(query, key);
149*00b67f09SDavid van Moolenbroek CHECK("dns_message_setsig0key", result);
150*00b67f09SDavid van Moolenbroek
151*00b67f09SDavid van Moolenbroek result = dns_message_gettemprdataset(query, &question);
152*00b67f09SDavid van Moolenbroek CHECK("dns_message_gettemprdataset", result);
153*00b67f09SDavid van Moolenbroek dns_rdataset_makequestion(question, dns_rdataclass_in,
154*00b67f09SDavid van Moolenbroek dns_rdatatype_a);
155*00b67f09SDavid van Moolenbroek result = dns_message_gettempname(query, &qname);
156*00b67f09SDavid van Moolenbroek CHECK("dns_message_gettempname", result);
157*00b67f09SDavid van Moolenbroek isc_buffer_init(&namesrc, nametext, strlen(nametext));
158*00b67f09SDavid van Moolenbroek isc_buffer_add(&namesrc, strlen(nametext));
159*00b67f09SDavid van Moolenbroek isc_buffer_init(&namedst, namedata, sizeof(namedata));
160*00b67f09SDavid van Moolenbroek dns_name_init(qname, NULL);
161*00b67f09SDavid van Moolenbroek result = dns_name_fromtext(qname, &namesrc, dns_rootname, 0, &namedst);
162*00b67f09SDavid van Moolenbroek CHECK("dns_name_fromtext", result);
163*00b67f09SDavid van Moolenbroek ISC_LIST_APPEND(qname->list, question, link);
164*00b67f09SDavid van Moolenbroek dns_message_addname(query, qname, DNS_SECTION_QUESTION);
165*00b67f09SDavid van Moolenbroek
166*00b67f09SDavid van Moolenbroek isc_buffer_init(&qbuffer, qdata, sizeof(qdata));
167*00b67f09SDavid van Moolenbroek
168*00b67f09SDavid van Moolenbroek result = dns_compress_init(&cctx, -1, mctx);
169*00b67f09SDavid van Moolenbroek CHECK("dns_compress_init", result);
170*00b67f09SDavid van Moolenbroek result = dns_message_renderbegin(query, &cctx, &qbuffer);
171*00b67f09SDavid van Moolenbroek CHECK("dns_message_renderbegin", result);
172*00b67f09SDavid van Moolenbroek result = dns_message_rendersection(query, DNS_SECTION_QUESTION, 0);
173*00b67f09SDavid van Moolenbroek CHECK("dns_message_rendersection(question)", result);
174*00b67f09SDavid van Moolenbroek result = dns_message_rendersection(query, DNS_SECTION_ANSWER, 0);
175*00b67f09SDavid van Moolenbroek CHECK("dns_message_rendersection(answer)", result);
176*00b67f09SDavid van Moolenbroek result = dns_message_rendersection(query, DNS_SECTION_AUTHORITY, 0);
177*00b67f09SDavid van Moolenbroek CHECK("dns_message_rendersection(auth)", result);
178*00b67f09SDavid van Moolenbroek result = dns_message_rendersection(query, DNS_SECTION_ADDITIONAL, 0);
179*00b67f09SDavid van Moolenbroek CHECK("dns_message_rendersection(add)", result);
180*00b67f09SDavid van Moolenbroek result = dns_message_renderend(query);
181*00b67f09SDavid van Moolenbroek CHECK("dns_message_renderend", result);
182*00b67f09SDavid van Moolenbroek dns_compress_invalidate(&cctx);
183*00b67f09SDavid van Moolenbroek
184*00b67f09SDavid van Moolenbroek isc_buffer_init(&outbuf, output, sizeof(output));
185*00b67f09SDavid van Moolenbroek result = dns_message_totext(query, style, 0, &outbuf);
186*00b67f09SDavid van Moolenbroek CHECK("dns_message_totext", result);
187*00b67f09SDavid van Moolenbroek printf("%.*s\n", (int)isc_buffer_usedlength(&outbuf),
188*00b67f09SDavid van Moolenbroek (char *)isc_buffer_base(&outbuf));
189*00b67f09SDavid van Moolenbroek
190*00b67f09SDavid van Moolenbroek isc_buffer_usedregion(&qbuffer, &r);
191*00b67f09SDavid van Moolenbroek isc_sockaddr_any(&sa);
192*00b67f09SDavid van Moolenbroek result = isc_socket_bind(s, &sa, 0);
193*00b67f09SDavid van Moolenbroek CHECK("isc_socket_bind", result);
194*00b67f09SDavid van Moolenbroek result = isc_socket_sendto(s, &r, task1, senddone, NULL, &address,
195*00b67f09SDavid van Moolenbroek NULL);
196*00b67f09SDavid van Moolenbroek CHECK("isc_socket_sendto", result);
197*00b67f09SDavid van Moolenbroek
198*00b67f09SDavid van Moolenbroek inr.base = rdata;
199*00b67f09SDavid van Moolenbroek inr.length = sizeof(rdata);
200*00b67f09SDavid van Moolenbroek result = isc_socket_recv(s, &inr, 1, task1, recvdone, NULL);
201*00b67f09SDavid van Moolenbroek CHECK("isc_socket_recv", result);
202*00b67f09SDavid van Moolenbroek dns_message_destroy(&query);
203*00b67f09SDavid van Moolenbroek }
204*00b67f09SDavid van Moolenbroek
205*00b67f09SDavid van Moolenbroek int
main(int argc,char * argv[])206*00b67f09SDavid van Moolenbroek main(int argc, char *argv[]) {
207*00b67f09SDavid van Moolenbroek isc_boolean_t verbose = ISC_FALSE;
208*00b67f09SDavid van Moolenbroek isc_socketmgr_t *socketmgr;
209*00b67f09SDavid van Moolenbroek isc_timermgr_t *timermgr;
210*00b67f09SDavid van Moolenbroek struct in_addr inaddr;
211*00b67f09SDavid van Moolenbroek dns_fixedname_t fname;
212*00b67f09SDavid van Moolenbroek dns_name_t *name;
213*00b67f09SDavid van Moolenbroek isc_buffer_t b;
214*00b67f09SDavid van Moolenbroek int ch;
215*00b67f09SDavid van Moolenbroek isc_result_t result;
216*00b67f09SDavid van Moolenbroek in_port_t port = 53;
217*00b67f09SDavid van Moolenbroek
218*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_app_start() == ISC_R_SUCCESS);
219*00b67f09SDavid van Moolenbroek
220*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_mutex_init(&lock) == ISC_R_SUCCESS);
221*00b67f09SDavid van Moolenbroek
222*00b67f09SDavid van Moolenbroek mctx = NULL;
223*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_mem_create(0, 0, &mctx) == ISC_R_SUCCESS);
224*00b67f09SDavid van Moolenbroek
225*00b67f09SDavid van Moolenbroek while ((ch = isc_commandline_parse(argc, argv, "vp:")) != -1) {
226*00b67f09SDavid van Moolenbroek switch (ch) {
227*00b67f09SDavid van Moolenbroek case 'v':
228*00b67f09SDavid van Moolenbroek verbose = ISC_TRUE;
229*00b67f09SDavid van Moolenbroek break;
230*00b67f09SDavid van Moolenbroek case 'p':
231*00b67f09SDavid van Moolenbroek port = (unsigned int)atoi(isc_commandline_argument);
232*00b67f09SDavid van Moolenbroek break;
233*00b67f09SDavid van Moolenbroek }
234*00b67f09SDavid van Moolenbroek }
235*00b67f09SDavid van Moolenbroek
236*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_entropy_create(mctx, &ent) == ISC_R_SUCCESS);
237*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(dst_lib_init(mctx, ent, 0) == ISC_R_SUCCESS);
238*00b67f09SDavid van Moolenbroek
239*00b67f09SDavid van Moolenbroek dns_result_register();
240*00b67f09SDavid van Moolenbroek dst_result_register();
241*00b67f09SDavid van Moolenbroek
242*00b67f09SDavid van Moolenbroek taskmgr = NULL;
243*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_taskmgr_create(mctx, 2, 0, &taskmgr) ==
244*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
245*00b67f09SDavid van Moolenbroek task1 = NULL;
246*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_task_create(taskmgr, 0, &task1) == ISC_R_SUCCESS);
247*00b67f09SDavid van Moolenbroek
248*00b67f09SDavid van Moolenbroek timermgr = NULL;
249*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_timermgr_create(mctx, &timermgr) == ISC_R_SUCCESS);
250*00b67f09SDavid van Moolenbroek socketmgr = NULL;
251*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_socketmgr_create(mctx, &socketmgr) == ISC_R_SUCCESS);
252*00b67f09SDavid van Moolenbroek
253*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_log_create(mctx, &lctx, &logconfig) == ISC_R_SUCCESS);
254*00b67f09SDavid van Moolenbroek
255*00b67f09SDavid van Moolenbroek s = NULL;
256*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_socket_create(socketmgr, PF_INET,
257*00b67f09SDavid van Moolenbroek isc_sockettype_udp, &s) ==
258*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS);
259*00b67f09SDavid van Moolenbroek
260*00b67f09SDavid van Moolenbroek inaddr.s_addr = htonl(INADDR_LOOPBACK);
261*00b67f09SDavid van Moolenbroek isc_sockaddr_fromin(&address, &inaddr, port);
262*00b67f09SDavid van Moolenbroek
263*00b67f09SDavid van Moolenbroek dns_fixedname_init(&fname);
264*00b67f09SDavid van Moolenbroek name = dns_fixedname_name(&fname);
265*00b67f09SDavid van Moolenbroek isc_buffer_constinit(&b, "child.example.", strlen("child.example."));
266*00b67f09SDavid van Moolenbroek isc_buffer_add(&b, strlen("child.example."));
267*00b67f09SDavid van Moolenbroek result = dns_name_fromtext(name, &b, dns_rootname, 0, NULL);
268*00b67f09SDavid van Moolenbroek CHECK("dns_name_fromtext", result);
269*00b67f09SDavid van Moolenbroek
270*00b67f09SDavid van Moolenbroek key = NULL;
271*00b67f09SDavid van Moolenbroek result = dst_key_fromfile(name, 4017, DNS_KEYALG_DSA,
272*00b67f09SDavid van Moolenbroek DST_TYPE_PUBLIC | DST_TYPE_PRIVATE,
273*00b67f09SDavid van Moolenbroek NULL, mctx, &key);
274*00b67f09SDavid van Moolenbroek CHECK("dst_key_fromfile", result);
275*00b67f09SDavid van Moolenbroek
276*00b67f09SDavid van Moolenbroek buildquery();
277*00b67f09SDavid van Moolenbroek
278*00b67f09SDavid van Moolenbroek (void)isc_app_run();
279*00b67f09SDavid van Moolenbroek
280*00b67f09SDavid van Moolenbroek isc_task_shutdown(task1);
281*00b67f09SDavid van Moolenbroek isc_task_detach(&task1);
282*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&taskmgr);
283*00b67f09SDavid van Moolenbroek
284*00b67f09SDavid van Moolenbroek isc_socket_detach(&s);
285*00b67f09SDavid van Moolenbroek isc_socketmgr_destroy(&socketmgr);
286*00b67f09SDavid van Moolenbroek isc_timermgr_destroy(&timermgr);
287*00b67f09SDavid van Moolenbroek
288*00b67f09SDavid van Moolenbroek dst_key_free(&key);
289*00b67f09SDavid van Moolenbroek
290*00b67f09SDavid van Moolenbroek dst_lib_destroy();
291*00b67f09SDavid van Moolenbroek
292*00b67f09SDavid van Moolenbroek isc_entropy_detach(&ent);
293*00b67f09SDavid van Moolenbroek
294*00b67f09SDavid van Moolenbroek isc_log_destroy(&lctx);
295*00b67f09SDavid van Moolenbroek
296*00b67f09SDavid van Moolenbroek if (verbose)
297*00b67f09SDavid van Moolenbroek isc_mem_stats(mctx, stdout);
298*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
299*00b67f09SDavid van Moolenbroek
300*00b67f09SDavid van Moolenbroek DESTROYLOCK(&lock);
301*00b67f09SDavid van Moolenbroek
302*00b67f09SDavid van Moolenbroek isc_app_finish();
303*00b67f09SDavid van Moolenbroek
304*00b67f09SDavid van Moolenbroek return (0);
305*00b67f09SDavid van Moolenbroek }
306