4 # fsx (AIO variant, based on 075)
6 #-----------------------------------------------------------------------
7 # Copyright (c) 2005 Silicon Graphics, Inc. All Rights Reserved.
9 # This program is free software; you can redistribute it and/or modify it
10 # under the terms of version 2 of the GNU General Public License as
11 # published by the Free Software Foundation.
13 # This program is distributed in the hope that it would be useful, but
14 # WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
17 # Further, this software is distributed without any warranty that it is
18 # free of the rightful claim of any third person regarding infringement
19 # or the like. Any license provided herein, whether implied or
20 # otherwise, applies only to this software file. Patent licenses, if
21 # any, provided herein do not apply to combinations of this program with
22 # other software, or any other product whatsoever.
24 # You should have received a copy of the GNU General Public License along
25 # with this program; if not, write the Free Software Foundation, Inc., 59
26 # Temple Place - Suite 330, Boston MA 02111-1307, USA.
28 # Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
29 # Mountain View, CA 94043, or:
33 # For further information regarding this notice, see:
35 # http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
36 #-----------------------------------------------------------------------
42 echo "QA output created by $seq"
46 status=0 # success is the default!
47 trap "_cleanup; exit \$status" 0 1 2 3 15
52 rm -rf $testdir/fsx.* $tmp.*
56 # get standard environment, filters and checks
69 echo " failed to mkdir $out"
74 _filter_param=`echo "$_param" | sed\
75 -e 's/-N [0-9][0-9]*/-N numops/' \
76 -e 's/-l [0-9][0-9]*/-l filelen/'`
79 echo "-----------------------------------------------"
80 echo "fsx.$_n : $_filter_param"
81 echo "-----------------------------------------------"
83 # This cd and use of -P gets full debug on $here (not TEST_DEV)
85 if ! $here/ltp/fsx $_param -P $here $seq.$_n >/dev/null
87 echo " fsx ($_param) returned $? - see $seq.$_n.full"
88 mv $seq.$_n.fsxlog $here/$seq.$_n.full
99 echo "$0: [-l filelen] [-n numops1] [-N numops2]"
104 while getopts "l:n:N:?" c $@
110 param_type="$param_type, overidde -l"
114 param_type="$param_type, overidde -N"
118 param_type="$param_type, overidde -n"
129 # real QA test starts here
133 [ -x $here/ltp/aio-stress ] || \
134 _notrun "fsx not built with AIO for this platform"
136 size10=`expr 10 \* 1024 \* 1024` # 10 megabytes
141 # can override the params here
144 echo "Params are for $param_type" >>$seq.full
145 echo "Params: n = $numops1 N = $numops2 l = $filelen" >>$seq.full
149 rm -f $here/$seq.full
150 echo "brevity is wit..."
155 # -d: debug output for all operations
156 # -l flen: the upper bound on file size (default 262144)
157 # -o oplen: the upper bound on operation size
158 # -N numops: total # operations to do (default infinity)
159 # -P: save .fsxlog and .fsxgood files in dirpath (default ./)
160 # -S seed: for random # generator (default 1) 0 gets timestamp
161 # -x: pre-allocate file space, exercising unwritten extents
162 # -A: use the AIO system calls
164 _do_test 0 "-A -d -N $numops1 -S 0"
165 _do_test 1 "-A -d -N $numops1 -S 0 -x"
166 _do_test 2 "-A -d -N $numops2 -l $filelen -S 0"
167 _do_test 3 "-A -d -N $numops2 -l $filelen -S 0 -x"
169 rm -f $seq.*.fsx{good,log}