6 #-----------------------------------------------------------------------
7 # Copyright (c) 2000-2002 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 # we might get here with a RO FS
25 mount -o remount,rw $TEST_DEV >/dev/null 2>&1
26 # now remove fsstress directory.
27 # N.B. rm(1) on IRIX can find problems when building up a long pathname
28 # such that what it has is greater the 1024 chars and will
29 # stop and complain - so get rid of complaint
31 rm -rf $testdir/fsstress.$$.* 2>&1 | grep -v 'Path too long'
37 ls -l $1 | $AWK_PROG '{print " filesize = " $5}'
40 # get standard environment, filters and checks
50 out=$testdir/fsstress.$$.$_n
54 echo " failed to mkdir $out"
60 echo "-----------------------------------------------"
61 echo "fsstress.$_n : $_param"
62 echo "-----------------------------------------------"
63 # -m limits number of users/groups so check doesn't fail (malloc) later
65 if ! $here/ltp/fsstress $_param $FSSTRESS_AVOID -v -m 8 -n $_count -d $out >>$dbgoutfile 2>&1
67 echo " fsstress (count=$_count) returned $? - see $seq.full"
69 echo "--------------------------------------" >>$here/$seq.full
70 echo "$_n - output from fsstress:" >>$here/$seq.full
71 echo "--------------------------------------" >>$here/$seq.full
72 echo "<NOT LOGGED>" >>$here/$seq.full
73 #cat $tmp.out >>$here/$seq.full
81 # real QA test starts here
83 _supported_os IRIX Linux
88 echo "brevity is wit..."
97 _do_test 1 "-r" $count
99 # and the default with multiprocess
101 _do_test 2 "-p $procs -r" $count
105 _do_test 3 "-p 4 -z -f rmdir=10 -f link=10 -f creat=10 -f mkdir=10 -f rename=30 -f stat=30 -f unlink=30 -f truncate=20" $count
107 # if all ok by here then probably don't need $seq.full
112 # Test with error injection:
115 # fsstress -n 1000 -d $scratch -p 4 -z -f rmdir=10 -f link=10 -f creat=10 \
116 # -f mkdir=10 -f rename=30 -f stat=30 -f unlink=30 -f truncate=20 \
119 # Error values 1 - 6 test IFLUSH
120 # 1 - corrupt buffer being flushed to di_core.di_magic
121 # 2 - corrupt inode being flushed i_d.di_magic
122 # 3 - corrupt S_IFREG format check
123 # 4 - corrupt S_IFDIR format check
124 # 5 - corrupt i_d.di_nextents
125 # 6 - corrupt i_d.di_forkoff > sb_inodesize