Update xfsprogs to latest kernel headers and functions
[xfstests-dev.git] / 130
1 #! /bin/sh
2 # FSQA Test No. 130
3 #
4 # xfs_io vector read/write and trunc tests. modified from cxfsqa tests
5 # - unixfile_basic_block_hole
6 # - unixfile_buffer_direct_coherency
7 # - unixfile_direct_rw
8 # - unixfile_eof_direct
9 # - unixfile_fsb_edge
10 # - unixfile_open_append
11 # - unixfile_open_trunc
12 # - unixfile_small_vector_async_rw
13 # - unixfile_small_vector_sync_rw
14 #
15 #-----------------------------------------------------------------------
16 #  Copyright (c) 2006 Silicon Graphics, Inc.  All Rights Reserved.
17 #-----------------------------------------------------------------------
18 #
19 # creator
20 owner=allanr@sgi.com
21
22 seq=`basename $0`
23 echo "QA output created by $seq"
24
25 here=`pwd`
26 tmp=/tmp/$$
27 status=1    # failure is the default!
28 trap "_cleanup; exit \$status" 0 1 2 3 15
29
30 _cleanup()
31 {
32     cd /
33     _cleanup_testdir
34 }
35
36 # get standard environment, filters and checks
37 . ./common.rc
38 . ./common.filter
39
40 common_line_filter()
41 {
42     perl -ne 'if (/.*:(.*)/) {
43         if ( "$last_line" ne "$1" ) { print "$_"; $first_match=1; }
44         elsif ( $first_match==1 ) { print "*\n"; $first_match=0; }
45         $last_line="$1";
46     }
47     else {
48         print $_; $last_line=$_;
49     }'
50 }
51
52 _filter_xfs_io()
53 {
54     common_line_filter | sed -e "s/[0-9/.]* [GMKiBbytes]*, [0-9]* ops\; [0-9/:. sec]* ([0-9/.]* [GMKiBbytes]*\/sec and [0-9/.]* ops\/sec)/XXX Bytes, X ops\; XX:XX:XX.X (XXX YYY\/sec and XXX ops\/sec)/"
55 }
56
57 # real QA test starts here
58 _supported_fs xfs
59 _supported_os Linux IRIX
60
61 _setup_testdir
62 _require_scratch
63
64 _scratch_mkfs >/dev/null 2>&1
65 _scratch_mount
66
67 echo "End-of-file zeroing with direct I/O"
68 xfs_io -f -d -t -c "pwrite -S 0x63 0 65536" \
69     -c "truncate 1" \
70     -c "pwrite -S 0x41 65536 65536" \
71     -c "pread -v 0 131072" \
72     $SCRATCH_MNT/eof-zeroing_direct | _filter_xfs_io
73
74 echo
75 echo "Basic Block Hole test"
76 xfs_io -f -t -c "truncate 8192" \
77     -c "pread -v 5000 3000" \
78     $SCRATCH_MNT/blackhole | _filter_xfs_io
79
80 echo
81 echo "Test buffered and direct IO coherency"
82 xfs_io -f -t -c "pwrite -S 0x41 8000 1000" \
83     -c "pwrite -S 0x57 4000 1000" \
84     $SCRATCH_MNT/buff_direct_coherency | _filter_xfs_io
85
86 xfs_io -d -c "pwrite -S 0x78 20480 4096"\
87     -c "pwrite -S 0x79 4096 4096"\
88     $SCRATCH_MNT/buff_direct_coherency | _filter_xfs_io
89
90 xfs_io -c "pread -v 0 9000"\
91     $SCRATCH_MNT/buff_direct_coherency | _filter_xfs_io
92
93 echo
94 echo "Test direct read and write"
95 xfs_io -f -d -t -c "pwrite -S 0x78 0 65536"\
96     -c "pread -v 0 65536"\
97     -c "pwrite -S 0x46 65536 6553600"\
98     -c "pread -v 0 6619136"\
99     $SCRATCH_MNT/direct_io | _filter_xfs_io
100
101 xfs_io -d -c "pread -v 0 6619136"\
102     $SCRATCH_MNT/direct_io | _filter_xfs_io
103
104 xfs_io -f -d -t -c "pwrite -S 0x61 0 65536"\
105     -c "pread -v 0 65536"\
106     -c "pwrite -S 0x62 65536 131072"\
107     -c "pread -v 0 131072"\
108     $SCRATCH_MNT/async_direct_io | _filter_xfs_io
109
110 xfs_io -d -c "pread -v 0 131072"\
111     $SCRATCH_MNT/async_direct_io | _filter_xfs_io
112
113 echo
114 echo "FSB Edge test"
115 xfs_io -f -t -c "truncate 131072"\
116     -c "pwrite -S 0x5F 0 131072"\
117     -c "truncate 0"\
118     -c "truncate 131072"\
119     -c "pwrite -S 0x61 65535 2"\
120     -c "pread -v 0 131072"\
121     $SCRATCH_MNT/fsb_edge_test | _filter_xfs_io
122
123 echo
124 echo "Open Trunk test (O_TRUNC)"
125 for n in 0 1 2 3 4
126 do
127     xfs_io -f -t -c "pread -v 0 100" $SCRATCH_MNT/$n | _filter_xfs_io
128
129     echo "Test" > $SCRATCH_MNT/$n
130     xfs_io -f -t -c "pread -v 0 100" $SCRATCH_MNT/$n | _filter_xfs_io
131     cat $SCRATCH_MNT/$n
132 done
133 echo "DONE"
134
135 echo
136 echo "Append test"
137 echo "append to me" > $SCRATCH_MNT/append
138 xfs_io -a -c "pwrite -S 0x61 0 10" \
139     -c "pread -v 0 24"\
140     $SCRATCH_MNT/append | _filter_xfs_io
141
142 echo
143 echo "Small Vector Async"
144 echo "abcdefghijklmnopqrstuvwxyz" > $SCRATCH_MNT/small_vector_async
145 xfs_io -f -c "pread -v 0 1"\
146     -c "pread -v 1 1"\
147     -c "pread -v 2 1"\
148     -c "pread -v 3 1"\
149     -c "pread -v 4 1"\
150     -c "pread -v 5 1"\
151     -c "pread -v 6 1"\
152     -c "pread -v 7 1"\
153     -c "pread -v 8 1"\
154     -c "pread -v 9 1"\
155     -c "pread -v 10 1"\
156     -c "pread -v 11 1"\
157     -c "pread -v 12 1"\
158     -c "pread -v 13 13"\
159     -c "pwrite -S 0x61 4090 1"\
160     -c "pwrite -S 0x62 4091 1"\
161     -c "pwrite -S 0x63 4092 1"\
162     -c "pwrite -S 0x64 4093 1"\
163     -c "pwrite -S 0x65 4094 1"\
164     -c "pwrite -S 0x66 4095 1"\
165     -c "pwrite -S 0x67 4096 1"\
166     -c "pwrite -S 0x68 4097 1"\
167     -c "pwrite -S 0x69 4098 1"\
168     -c "pwrite -S 0x6A 4099 1"\
169     -c "pwrite -S 0x6B 4100 1"\
170     -c "pwrite -S 0x6C 4101 1"\
171     -c "pwrite -S 0x6D 4102 1"\
172     -c "pwrite -S 0x6E 4103 1"\
173     -c "pwrite -S 0x6F 4104 1"\
174     -c "pwrite -S 0x70 4105 1"\
175     -c "pread -v 4090 4"\
176     -c "pread -v 4094 4"\
177     -c "pread -v 4098 4"\
178     -c "pread -v 4102 4"\
179     -c "pwrite -S 0x61 10000000000 1"\
180     -c "pwrite -S 0x62 10000000001 1"\
181     -c "pwrite -S 0x63 10000000002 1"\
182     -c "pwrite -S 0x64 10000000003 1"\
183     -c "pwrite -S 0x65 10000000004 1"\
184     -c "pwrite -S 0x66 10000000005 1"\
185     -c "pwrite -S 0x67 10000000006 1"\
186     -c "pwrite -S 0x68 10000000007 1"\
187     -c "pwrite -S 0x69 10000000008 1"\
188     -c "pwrite -S 0x6A 10000000009 1"\
189     -c "pwrite -S 0x6B 10000000010 1"\
190     -c "pwrite -S 0x6C 10000000011 1"\
191     -c "pwrite -S 0x6D 10000000012 1"\
192     -c "pwrite -S 0x6E 10000000013 1"\
193     -c "pwrite -S 0x6F 10000000014 1"\
194     -c "pwrite -S 0x70 10000000015 1"\
195     -c "pread -v 10000000000 4"\
196     -c "pread -v 10000000004 4"\
197     -c "pread -v 10000000008 4"\
198     -c "pread -v 10000000012 4"\
199     $SCRATCH_MNT/small_vector_async | _filter_xfs_io
200
201 echo
202 echo "Small Vector Sync"
203 echo "abcdefghijklmnopqrstuvwxyz" > $SCRATCH_MNT/small_vector_async
204 xfs_io -f -s -c "pread -v 0 1"\
205     -c "pread -v 1 1"\
206     -c "pread -v 2 1"\
207     -c "pread -v 3 1"\
208     -c "pread -v 4 1"\
209     -c "pread -v 5 1"\
210     -c "pread -v 6 1"\
211     -c "pread -v 7 1"\
212     -c "pread -v 8 1"\
213     -c "pread -v 9 1"\
214     -c "pread -v 10 1"\
215     -c "pread -v 11 1"\
216     -c "pread -v 12 1"\
217     -c "pread -v 13 13"\
218     -c "pwrite -S 0x61 4090 1"\
219     -c "pwrite -S 0x62 4091 1"\
220     -c "pwrite -S 0x63 4092 1"\
221     -c "pwrite -S 0x64 4093 1"\
222     -c "pwrite -S 0x65 4094 1"\
223     -c "pwrite -S 0x66 4095 1"\
224     -c "pwrite -S 0x67 4096 1"\
225     -c "pwrite -S 0x68 4097 1"\
226     -c "pwrite -S 0x69 4098 1"\
227     -c "pwrite -S 0x6A 4099 1"\
228     -c "pwrite -S 0x6B 4100 1"\
229     -c "pwrite -S 0x6C 4101 1"\
230     -c "pwrite -S 0x6D 4102 1"\
231     -c "pwrite -S 0x6E 4103 1"\
232     -c "pwrite -S 0x6F 4104 1"\
233     -c "pwrite -S 0x70 4105 1"\
234     -c "pread -v 4090 4"\
235     -c "pread -v 4094 4"\
236     -c "pread -v 4098 4"\
237     -c "pread -v 4102 4"\
238     -c "pwrite -S 0x61 10000000000 1"\
239     -c "pwrite -S 0x62 10000000001 1"\
240     -c "pwrite -S 0x63 10000000002 1"\
241     -c "pwrite -S 0x64 10000000003 1"\
242     -c "pwrite -S 0x65 10000000004 1"\
243     -c "pwrite -S 0x66 10000000005 1"\
244     -c "pwrite -S 0x67 10000000006 1"\
245     -c "pwrite -S 0x68 10000000007 1"\
246     -c "pwrite -S 0x69 10000000008 1"\
247     -c "pwrite -S 0x6A 10000000009 1"\
248     -c "pwrite -S 0x6B 10000000010 1"\
249     -c "pwrite -S 0x6C 10000000011 1"\
250     -c "pwrite -S 0x6D 10000000012 1"\
251     -c "pwrite -S 0x6E 10000000013 1"\
252     -c "pwrite -S 0x6F 10000000014 1"\
253     -c "pwrite -S 0x70 10000000015 1"\
254     -c "pread -v 10000000000 4"\
255     -c "pread -v 10000000004 4"\
256     -c "pread -v 10000000008 4"\
257     -c "pread -v 10000000012 4"\
258     $SCRATCH_MNT/small_vector_async | _filter_xfs_io
259
260 status=0
261 exit