1*d3273b5bSchristos /* $NetBSD: parse_reply-test.c,v 1.2 2017/01/28 21:31:50 christos Exp $ */
2ca1c9b0cSelric
3ca1c9b0cSelric /*
4ca1c9b0cSelric * Copyright (c) 2002 Kungliga Tekniska Högskolan
5ca1c9b0cSelric * (Royal Institute of Technology, Stockholm, Sweden).
6ca1c9b0cSelric * All rights reserved.
7ca1c9b0cSelric *
8ca1c9b0cSelric * Redistribution and use in source and binary forms, with or without
9ca1c9b0cSelric * modification, are permitted provided that the following conditions
10ca1c9b0cSelric * are met:
11ca1c9b0cSelric *
12ca1c9b0cSelric * 1. Redistributions of source code must retain the above copyright
13ca1c9b0cSelric * notice, this list of conditions and the following disclaimer.
14ca1c9b0cSelric *
15ca1c9b0cSelric * 2. Redistributions in binary form must reproduce the above copyright
16ca1c9b0cSelric * notice, this list of conditions and the following disclaimer in the
17ca1c9b0cSelric * documentation and/or other materials provided with the distribution.
18ca1c9b0cSelric *
19ca1c9b0cSelric * 3. Neither the name of the Institute nor the names of its contributors
20ca1c9b0cSelric * may be used to endorse or promote products derived from this software
21ca1c9b0cSelric * without specific prior written permission.
22ca1c9b0cSelric *
23ca1c9b0cSelric * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
24ca1c9b0cSelric * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25ca1c9b0cSelric * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26ca1c9b0cSelric * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
27ca1c9b0cSelric * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28ca1c9b0cSelric * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29ca1c9b0cSelric * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30ca1c9b0cSelric * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31ca1c9b0cSelric * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32ca1c9b0cSelric * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33ca1c9b0cSelric * SUCH DAMAGE.
34ca1c9b0cSelric */
35ca1c9b0cSelric
36ca1c9b0cSelric #include <config.h>
37ca1c9b0cSelric
38ca1c9b0cSelric #include <sys/types.h>
39ca1c9b0cSelric #ifdef HAVE_SYS_MMAN_H
40ca1c9b0cSelric #include <sys/mman.h>
41ca1c9b0cSelric #endif
42ca1c9b0cSelric #include <fcntl.h>
43ca1c9b0cSelric
44ca1c9b0cSelric #include <krb5/roken.h>
45ca1c9b0cSelric #include <krb5/resolve.h>
46ca1c9b0cSelric
47ca1c9b0cSelric struct dns_reply*
48ca1c9b0cSelric parse_reply(const unsigned char *, size_t);
49ca1c9b0cSelric
50ca1c9b0cSelric enum { MAX_BUF = 36};
51ca1c9b0cSelric
52ca1c9b0cSelric static struct testcase {
53ca1c9b0cSelric unsigned char buf[MAX_BUF];
54ca1c9b0cSelric size_t buf_len;
55ca1c9b0cSelric } tests[] = {
56ca1c9b0cSelric {{0x12, 0x67, 0x84, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00,
57ca1c9b0cSelric 0x03, 'f', 'o', 'o', 0x00,
58ca1c9b0cSelric 0x00, 0x10, 0x00, 0x01,
59ca1c9b0cSelric 0x03, 'f', 'o', 'o', 0x00,
60ca1c9b0cSelric 0x00, 0x10, 0x00, 0x01,
61ca1c9b0cSelric 0x00, 0x00, 0x12, 0x67, 0xff, 0xff}, 36}
62ca1c9b0cSelric };
63ca1c9b0cSelric
64ca1c9b0cSelric #ifndef MAP_FAILED
65ca1c9b0cSelric #define MAP_FAILED (-1)
66ca1c9b0cSelric #endif
67ca1c9b0cSelric
68ca1c9b0cSelric static sig_atomic_t val = 0;
69ca1c9b0cSelric
70ca1c9b0cSelric static RETSIGTYPE
segv_handler(int sig)71ca1c9b0cSelric segv_handler(int sig)
72ca1c9b0cSelric {
73ca1c9b0cSelric val = 1;
74ca1c9b0cSelric }
75ca1c9b0cSelric
76ca1c9b0cSelric int
main(int argc,char ** argv)77ca1c9b0cSelric main(int argc, char **argv)
78ca1c9b0cSelric {
79ca1c9b0cSelric #ifndef HAVE_MMAP
80ca1c9b0cSelric return 77; /* signal to automake that this test
81ca1c9b0cSelric cannot be run */
82ca1c9b0cSelric #else /* HAVE_MMAP */
83ca1c9b0cSelric int ret;
84ca1c9b0cSelric int i;
85ca1c9b0cSelric struct sigaction sa;
86ca1c9b0cSelric
87ca1c9b0cSelric sigemptyset (&sa.sa_mask);
88ca1c9b0cSelric sa.sa_flags = 0;
89ca1c9b0cSelric sa.sa_handler = segv_handler;
90ca1c9b0cSelric sigaction (SIGSEGV, &sa, NULL);
91ca1c9b0cSelric
92ca1c9b0cSelric for (i = 0; val == 0 && i < sizeof(tests)/sizeof(tests[0]); ++i) {
93ca1c9b0cSelric const struct testcase *t = &tests[i];
94ca1c9b0cSelric unsigned char *p1, *p2;
95ca1c9b0cSelric int flags;
96ca1c9b0cSelric int fd;
97ca1c9b0cSelric size_t pagesize = getpagesize();
98ca1c9b0cSelric unsigned char *buf;
99ca1c9b0cSelric
100ca1c9b0cSelric #ifdef MAP_ANON
101ca1c9b0cSelric flags = MAP_ANON;
102ca1c9b0cSelric fd = -1;
103ca1c9b0cSelric #else
104ca1c9b0cSelric flags = 0;
105ca1c9b0cSelric fd = open ("/dev/zero", O_RDONLY);
106ca1c9b0cSelric if(fd < 0)
107ca1c9b0cSelric err (1, "open /dev/zero");
108ca1c9b0cSelric #endif
109ca1c9b0cSelric flags |= MAP_PRIVATE;
110ca1c9b0cSelric
111ca1c9b0cSelric p1 = (unsigned char *)mmap(0, 2 * pagesize, PROT_READ | PROT_WRITE,
112ca1c9b0cSelric flags, fd, 0);
113ca1c9b0cSelric if (p1 == (unsigned char *)MAP_FAILED)
114ca1c9b0cSelric err (1, "mmap");
115ca1c9b0cSelric p2 = p1 + pagesize;
116ca1c9b0cSelric ret = mprotect ((void *)p2, pagesize, 0);
117ca1c9b0cSelric if (ret < 0)
118ca1c9b0cSelric err (1, "mprotect");
119ca1c9b0cSelric buf = p2 - t->buf_len;
120ca1c9b0cSelric memcpy (buf, t->buf, t->buf_len);
121ca1c9b0cSelric parse_reply (buf, t->buf_len);
122ca1c9b0cSelric ret = munmap ((void *)p1, 2 * pagesize);
123ca1c9b0cSelric if (ret < 0)
124ca1c9b0cSelric err (1, "munmap");
125ca1c9b0cSelric }
126ca1c9b0cSelric return val;
127ca1c9b0cSelric #endif /* HAVE_MMAP */
128ca1c9b0cSelric }
129