functionality-test-suite-20020114
[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 #ifdef RCSID
50 RCSID("$Id$");
51 #endif
52
53 #ifndef MAP_FAILED
54 #define MAP_FAILED ((void *)-1)
55 #endif
56
57 static char *
58 generate_random_file (const char *filename,
59                       unsigned npages,
60                       unsigned pagesize,
61                       int writep)
62 {
63     int fd;
64     char *buf, *fbuf;
65     int i;
66     int prot;
67     int flags;
68     size_t sz = npages * pagesize;
69
70     buf = malloc (sz);
71     if (buf == NULL)
72         err (1, "malloc %u", (unsigned)sz);
73
74     for (i = 0; i < npages; ++i)
75         memset (buf + pagesize * i, '0' + i, pagesize);
76
77     fd = open (filename, O_RDWR | O_CREAT | O_TRUNC, 0666);
78     if (fd < 0)
79         err (1, "open %s", filename);
80
81     if (ftruncate (fd, sz) < 0)
82         err (1, "ftruncate");
83
84     prot = PROT_READ | PROT_WRITE;
85     flags = MAP_SHARED;
86
87     fbuf = mmap (0, sz, prot, flags, fd, 0);
88     if (fbuf == (void *)MAP_FAILED)
89         err (1, "mmap");
90
91     if (writep) {
92         if(write(fd, "hej\n", 4) != 4)
93             err(1, "write");
94     }
95
96     memcpy (fbuf, buf, sz);
97
98 #if 0
99     if (msync (fbuf, sz, MS_SYNC))
100         err(1, "msync");
101 #endif
102
103     if (munmap (fbuf, sz) != 0)
104         err (1, "munmap");
105
106     if (close (fd))
107         err (1, "close");
108     return buf;
109 }
110
111 static char *
112 read_file (int fd, size_t sz)
113 {
114     char *buf;
115     ssize_t ret;
116
117     buf = malloc (sz);
118     if (buf == NULL)
119         err (1, "malloc %u", (unsigned)sz);
120     ret = read (fd, buf, sz);
121     if (ret < 0)
122         err (1, "read");
123     if (ret != sz)
124         errx(1, "short read %d < %u", (int)ret, (unsigned)sz);
125     return buf;
126 }
127
128 static int
129 test (const char *file, int writep)
130 {
131     const size_t sz  = 4 * getpagesize();
132     char *buf;
133     char *malloc_buf;
134     int fd;
135     int ret;
136
137     buf = generate_random_file (file, 4, getpagesize(), writep);
138
139     fd = open (file, O_RDONLY, 0);
140     if (fd < 0)
141         err (1, "open %s", file);
142
143     malloc_buf = read_file (fd, sz);
144     close (fd);
145     ret = memcmp (buf, malloc_buf, sz);
146     free (buf);
147     
148     return ret;
149 }
150
151
152 int
153 main (int argc, char **argv)
154 {
155
156
157     srand (time(NULL));
158
159     if (test ("foo", 1) != 0)
160         errx (1, "test(1)");
161     if (test ("bar", 0) != 0)
162         errx (1, "test(2)");
163
164     return 0;
165 }