t_io.c revision 1.8 1 1.8 njoly /* $NetBSD: t_io.c,v 1.8 2011/02/27 15:16:31 njoly Exp $ */
2 1.1 pooka
3 1.1 pooka /*-
4 1.1 pooka * Copyright (c) 2010 The NetBSD Foundation, Inc.
5 1.1 pooka * All rights reserved.
6 1.1 pooka *
7 1.1 pooka * Redistribution and use in source and binary forms, with or without
8 1.1 pooka * modification, are permitted provided that the following conditions
9 1.1 pooka * are met:
10 1.1 pooka * 1. Redistributions of source code must retain the above copyright
11 1.1 pooka * notice, this list of conditions and the following disclaimer.
12 1.1 pooka * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 pooka * notice, this list of conditions and the following disclaimer in the
14 1.1 pooka * documentation and/or other materials provided with the distribution.
15 1.1 pooka *
16 1.1 pooka * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
17 1.1 pooka * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18 1.1 pooka * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 1.1 pooka * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20 1.1 pooka * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 1.1 pooka * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 1.1 pooka * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 1.1 pooka * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 1.1 pooka * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 1.1 pooka * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 1.1 pooka * POSSIBILITY OF SUCH DAMAGE.
27 1.1 pooka */
28 1.1 pooka
29 1.1 pooka #include <sys/stat.h>
30 1.1 pooka #include <sys/statvfs.h>
31 1.1 pooka
32 1.1 pooka #include <atf-c.h>
33 1.1 pooka #include <fcntl.h>
34 1.1 pooka #include <libgen.h>
35 1.1 pooka #include <stdlib.h>
36 1.1 pooka #include <unistd.h>
37 1.1 pooka
38 1.1 pooka #include <rump/rump_syscalls.h>
39 1.1 pooka #include <rump/rump.h>
40 1.1 pooka
41 1.1 pooka #include "../common/h_fsmacros.h"
42 1.1 pooka #include "../../h_macros.h"
43 1.1 pooka
44 1.3 pooka #define TESTSTR "this is a string. collect enough and you'll have Em"
45 1.3 pooka #define TESTSZ sizeof(TESTSTR)
46 1.3 pooka
47 1.1 pooka static void
48 1.1 pooka holywrite(const atf_tc_t *tc, const char *mp)
49 1.1 pooka {
50 1.1 pooka char buf[1024];
51 1.1 pooka char *b2, *b3;
52 1.1 pooka size_t therange = getpagesize()+1;
53 1.1 pooka int fd;
54 1.1 pooka
55 1.3 pooka FSTEST_ENTER();
56 1.1 pooka
57 1.1 pooka RL(fd = rump_sys_open("file", O_RDWR|O_CREAT|O_TRUNC, 0666));
58 1.1 pooka
59 1.1 pooka memset(buf, 'A', sizeof(buf));
60 1.1 pooka RL(rump_sys_pwrite(fd, buf, 1, getpagesize()));
61 1.1 pooka
62 1.1 pooka memset(buf, 'B', sizeof(buf));
63 1.6 pooka RL(rump_sys_pwrite(fd, buf, 2, getpagesize()-1));
64 1.1 pooka
65 1.1 pooka REQUIRE_LIBC(b2 = malloc(2 * getpagesize()), NULL);
66 1.1 pooka REQUIRE_LIBC(b3 = malloc(2 * getpagesize()), NULL);
67 1.1 pooka
68 1.1 pooka RL(rump_sys_pread(fd, b2, therange, 0));
69 1.1 pooka
70 1.1 pooka memset(b3, 0, therange);
71 1.1 pooka memset(b3 + getpagesize() - 1, 'B', 2);
72 1.1 pooka
73 1.2 pooka ATF_REQUIRE_EQ(memcmp(b2, b3, therange), 0);
74 1.1 pooka
75 1.1 pooka rump_sys_close(fd);
76 1.3 pooka FSTEST_EXIT();
77 1.3 pooka }
78 1.3 pooka
79 1.3 pooka static void
80 1.3 pooka extendbody(const atf_tc_t *tc, off_t seekcnt)
81 1.3 pooka {
82 1.3 pooka char buf[TESTSZ+1];
83 1.3 pooka struct stat sb;
84 1.3 pooka int fd;
85 1.3 pooka
86 1.3 pooka FSTEST_ENTER();
87 1.3 pooka RL(fd = rump_sys_open("testfile",
88 1.3 pooka O_CREAT | O_RDWR | (seekcnt ? O_APPEND : 0)));
89 1.3 pooka RL(rump_sys_ftruncate(fd, seekcnt));
90 1.3 pooka RL(rump_sys_fstat(fd, &sb));
91 1.3 pooka if (FSTYPE_SYSVBFS(tc) && seekcnt)
92 1.4 pooka atf_tc_expect_fail("PR kern/44307");
93 1.3 pooka ATF_REQUIRE_EQ(sb.st_size, seekcnt);
94 1.3 pooka atf_tc_expect_pass();
95 1.3 pooka
96 1.3 pooka ATF_REQUIRE_EQ(rump_sys_write(fd, TESTSTR, TESTSZ), TESTSZ);
97 1.3 pooka ATF_REQUIRE_EQ(rump_sys_pread(fd, buf, TESTSZ, seekcnt), TESTSZ);
98 1.3 pooka ATF_REQUIRE_STREQ(buf, TESTSTR);
99 1.3 pooka
100 1.3 pooka RL(rump_sys_fstat(fd, &sb));
101 1.5 pooka ATF_REQUIRE_EQ(sb.st_size, (off_t)TESTSZ + seekcnt);
102 1.3 pooka RL(rump_sys_close(fd));
103 1.3 pooka FSTEST_EXIT();
104 1.3 pooka }
105 1.3 pooka
106 1.3 pooka static void
107 1.3 pooka extendfile(const atf_tc_t *tc, const char *mp)
108 1.3 pooka {
109 1.3 pooka
110 1.3 pooka extendbody(tc, 0);
111 1.3 pooka }
112 1.3 pooka
113 1.3 pooka static void
114 1.3 pooka extendfile_append(const atf_tc_t *tc, const char *mp)
115 1.3 pooka {
116 1.3 pooka
117 1.3 pooka extendbody(tc, 37);
118 1.1 pooka }
119 1.1 pooka
120 1.7 pooka static void
121 1.7 pooka overwritebody(const atf_tc_t *tc, off_t count, bool dotrunc)
122 1.7 pooka {
123 1.7 pooka char *buf;
124 1.7 pooka int fd;
125 1.7 pooka
126 1.7 pooka REQUIRE_LIBC(buf = malloc(count), NULL);
127 1.7 pooka FSTEST_ENTER();
128 1.7 pooka RL(fd = rump_sys_open("testi", O_CREAT | O_RDWR));
129 1.7 pooka ATF_REQUIRE_EQ(rump_sys_write(fd, buf, count), count);
130 1.7 pooka RL(rump_sys_close(fd));
131 1.7 pooka
132 1.7 pooka RL(fd = rump_sys_open("testi", O_CREAT | O_RDWR));
133 1.7 pooka if (dotrunc)
134 1.7 pooka RL(rump_sys_ftruncate(fd, 0));
135 1.7 pooka ATF_REQUIRE_EQ(rump_sys_write(fd, buf, count), count);
136 1.7 pooka RL(rump_sys_close(fd));
137 1.7 pooka FSTEST_EXIT();
138 1.7 pooka }
139 1.7 pooka
140 1.7 pooka static void
141 1.7 pooka overwrite512(const atf_tc_t *tc, const char *mp)
142 1.7 pooka {
143 1.7 pooka
144 1.7 pooka overwritebody(tc, 512, false);
145 1.7 pooka }
146 1.7 pooka
147 1.7 pooka static void
148 1.7 pooka overwrite64k(const atf_tc_t *tc, const char *mp)
149 1.7 pooka {
150 1.7 pooka
151 1.7 pooka overwritebody(tc, 1<<16, false);
152 1.7 pooka }
153 1.7 pooka
154 1.7 pooka static void
155 1.7 pooka overwrite_trunc(const atf_tc_t *tc, const char *mp)
156 1.7 pooka {
157 1.7 pooka
158 1.7 pooka overwritebody(tc, 1<<16, true);
159 1.7 pooka }
160 1.7 pooka
161 1.8 njoly static void
162 1.8 njoly shrinkfile(const atf_tc_t *tc, const char *mp)
163 1.8 njoly {
164 1.8 njoly int fd;
165 1.8 njoly
166 1.8 njoly FSTEST_ENTER();
167 1.8 njoly RL(fd = rump_sys_open("file", O_RDWR|O_CREAT|O_TRUNC, 0666));
168 1.8 njoly RL(rump_sys_ftruncate(fd, 2));
169 1.8 njoly RL(rump_sys_ftruncate(fd, 1));
170 1.8 njoly rump_sys_close(fd);
171 1.8 njoly FSTEST_EXIT();
172 1.8 njoly }
173 1.8 njoly
174 1.1 pooka ATF_TC_FSAPPLY(holywrite, "create a sparse file and fill hole");
175 1.3 pooka ATF_TC_FSAPPLY(extendfile, "check that extending a file works");
176 1.3 pooka ATF_TC_FSAPPLY(extendfile_append, "check that extending a file works "
177 1.3 pooka "with a append-only fd");
178 1.7 pooka ATF_TC_FSAPPLY(overwrite512, "write a 512 byte file twice");
179 1.7 pooka ATF_TC_FSAPPLY(overwrite64k, "write a 64k byte file twice");
180 1.7 pooka ATF_TC_FSAPPLY(overwrite_trunc, "write 64k + truncate + rewrite");
181 1.8 njoly ATF_TC_FSAPPLY(shrinkfile, "shrink file");
182 1.1 pooka
183 1.1 pooka ATF_TP_ADD_TCS(tp)
184 1.1 pooka {
185 1.1 pooka
186 1.1 pooka ATF_TP_FSAPPLY(holywrite);
187 1.3 pooka ATF_TP_FSAPPLY(extendfile);
188 1.3 pooka ATF_TP_FSAPPLY(extendfile_append);
189 1.7 pooka ATF_TP_FSAPPLY(overwrite512);
190 1.7 pooka ATF_TP_FSAPPLY(overwrite64k);
191 1.7 pooka ATF_TP_FSAPPLY(overwrite_trunc);
192 1.8 njoly ATF_TP_FSAPPLY(shrinkfile);
193 1.1 pooka
194 1.1 pooka return atf_no_error();
195 1.1 pooka }
196