4 # fsx (AIO variant, based on 075)
6 #-----------------------------------------------------------------------
7 # Copyright (c) 2005 Silicon Graphics, Inc. All Rights Reserved.
8 #-----------------------------------------------------------------------
14 echo "QA output created by $seq"
18 status=0 # success is the default!
19 trap "_cleanup; exit \$status" 0 1 2 3 15
24 rm -rf $testdir/fsx.* $tmp.*
28 # get standard environment, filters and checks
41 echo " failed to mkdir $out"
46 _filter_param=`echo "$_param" | sed\
47 -e 's/-N [0-9][0-9]*/-N numops/' \
48 -e 's/-l [0-9][0-9]*/-l filelen/'`
51 echo "-----------------------------------------------"
52 echo "fsx.$_n : $_filter_param"
53 echo "-----------------------------------------------"
55 # This cd and use of -P gets full debug on $here (not TEST_DEV)
57 if ! $here/ltp/fsx $_param -P $here $seq.$_n >/dev/null
59 echo " fsx ($_param) returned $? - see $seq.$_n.full"
60 mv $seq.$_n.fsxlog $here/$seq.$_n.full
71 echo "$0: [-l filelen] [-n numops1] [-N numops2]"
76 while getopts "l:n:N:?" c $@
82 param_type="$param_type, overidde -l"
86 param_type="$param_type, overidde -N"
90 param_type="$param_type, overidde -n"
101 # real QA test starts here
105 [ -x $here/ltp/aio-stress ] || \
106 _notrun "fsx not built with AIO for this platform"
108 size10=`expr 10 \* 1024 \* 1024` # 10 megabytes
113 # can override the params here
116 echo "Params are for $param_type" >>$seq.full
117 echo "Params: n = $numops1 N = $numops2 l = $filelen" >>$seq.full
121 rm -f $here/$seq.full
122 echo "brevity is wit..."
127 # -d: debug output for all operations
128 # -l flen: the upper bound on file size (default 262144)
129 # -o oplen: the upper bound on operation size
130 # -N numops: total # operations to do (default infinity)
131 # -P: save .fsxlog and .fsxgood files in dirpath (default ./)
132 # -S seed: for random # generator (default 1) 0 gets timestamp
133 # -x: pre-allocate file space, exercising unwritten extents
134 # -A: use the AIO system calls
136 _do_test 0 "-A -d -N $numops1 -S 0"
137 _do_test 1 "-A -d -N $numops1 -S 0 -x"
138 _do_test 2 "-A -d -N $numops2 -l $filelen -S 0"
139 _do_test 3 "-A -d -N $numops2 -l $filelen -S 0 -x"
141 rm -f $seq.*.fsx{good,log}