Import Upstream version 1.8.5
[hcoop/debian/openafs.git] / src / tests / mmap-and-read.c
1 /*
2 * Copyright (c) 1995 - 2001 Kungliga Tekniska Högskolan
3 * (Royal Institute of Technology, Stockholm, Sweden).
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 *
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 *
17 * 3. Neither the name of the Institute nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
32 */
33
34 #ifdef HAVE_CONFIG_H
35 #include <config.h>
36 #endif
37
38 #include <stdio.h>
39 #include <stdlib.h>
40 #include <sys/types.h>
41 #include <fcntl.h>
42 #include <time.h>
43 #include <unistd.h>
44 #include <string.h>
45 #include <sys/mman.h>
46 #include <sys/stat.h>
47 #include <err.h>
48
49 #ifndef MAP_FAILED
50 #define MAP_FAILED ((void *)-1)
51 #endif
52
53 static char *
54 generate_random_file(const char *filename, unsigned npages, unsigned pagesize,
55 int writep)
56 {
57 int fd;
58 char *buf, *fbuf;
59 int i;
60 int prot;
61 int flags;
62 size_t sz = npages * pagesize;
63
64 buf = malloc(sz);
65 if (buf == NULL)
66 err(1, "malloc %u", (unsigned)sz);
67
68 for (i = 0; i < npages; ++i)
69 memset(buf + pagesize * i, '0' + i, pagesize);
70
71 fd = open(filename, O_RDWR | O_CREAT | O_TRUNC, 0666);
72 if (fd < 0)
73 err(1, "open %s", filename);
74
75 if (ftruncate(fd, sz) < 0)
76 err(1, "ftruncate");
77
78 prot = PROT_READ | PROT_WRITE;
79 flags = MAP_SHARED;
80
81 fbuf = mmap(0, sz, prot, flags, fd, 0);
82 if (fbuf == (void *)MAP_FAILED)
83 err(1, "mmap");
84
85 if (writep) {
86 if (write(fd, "hej\n", 4) != 4)
87 err(1, "write");
88 }
89
90 memcpy(fbuf, buf, sz);
91
92 #if 0
93 if (msync(fbuf, sz, MS_SYNC))
94 err(1, "msync");
95 #endif
96
97 if (munmap(fbuf, sz) != 0)
98 err(1, "munmap");
99
100 if (close(fd))
101 err(1, "close");
102 return buf;
103 }
104
105 static char *
106 read_file(int fd, size_t sz)
107 {
108 char *buf;
109 ssize_t ret;
110
111 buf = malloc(sz);
112 if (buf == NULL)
113 err(1, "malloc %u", (unsigned)sz);
114 ret = read(fd, buf, sz);
115 if (ret < 0)
116 err(1, "read");
117 if (ret != sz)
118 errx(1, "short read %d < %u", (int)ret, (unsigned)sz);
119 return buf;
120 }
121
122 static int
123 test(const char *file, int writep)
124 {
125 const size_t sz = 4 * getpagesize();
126 char *buf;
127 char *malloc_buf;
128 int fd;
129 int ret;
130
131 buf = generate_random_file(file, 4, getpagesize(), writep);
132
133 fd = open(file, O_RDONLY, 0);
134 if (fd < 0)
135 err(1, "open %s", file);
136
137 malloc_buf = read_file(fd, sz);
138 close(fd);
139 ret = memcmp(buf, malloc_buf, sz);
140 free(buf);
141
142 return ret;
143 }
144
145
146 int
147 main(int argc, char **argv)
148 {
149
150
151 srand(time(NULL));
152
153 if (test("foo", 1) != 0)
154 errx(1, "test(1)");
155 if (test("bar", 0) != 0)
156 errx(1, "test(2)");
157
158 return 0;
159 }