if test -x $DEBUGFS_EXE; then FSCK_OPT=-fy OUT=$test_name.log if [ -f $test_dir/expect.gz ]; then EXP=$test_name.tmp gunzip < $test_dir/expect.gz > $EXP1 else EXP=$test_dir/expect fi cp /dev/null $OUT cat > $TMPFILE.conf << ENDL [fs_types] ext4 = { base_features = sparse_super,filetype,resize_inode,dir_index,ext_attr,^has_journal,^extent,huge_file,flex_bg,uninit_bg,dir_nlink,extra_isize,^64bit blocksize = 1024 inode_size = 256 inode_ratio = 16384 } ENDL MKE2FS_CONFIG=$TMPFILE.conf $MKE2FS -F -o Linux -b 1024 -O ^bigalloc -T ext4 $TMPFILE 65536 2>&1 | sed -f $cmd_dir/filter.sed >> $OUT 2>&1 rm -rf $TMPFILE.conf $FSCK -fy -N test_filesys $TMPFILE > $OUT.new 2>&1 status=$? echo Exit status is $status >> $OUT.new sed -f $cmd_dir/filter.sed -e "s;$TMPFILE;test.img;" $OUT.new >> $OUT rm -f $OUT.new echo "debugfs write files" >> $OUT #Files we create: # a: fallocate a 40k file # k: one big file base=5000 cat > $TMPFILE.cmd << ENDL write /dev/null a sif /a bmap[2] 8000 sif /a size 40960 sif /a i_blocks 2 setb 8000 fallocate /a 0 39 write /dev/null b sif /b size 10240000 sif /b bmap[0] 10000 sif /b i_blocks 2 setb 10000 fallocate /b 0 9999 ENDL echo "stat /a" >> $TMPFILE.cmd2 echo "stat /b" >> $TMPFILE.cmd2 $DEBUGFS_EXE -w -f $TMPFILE.cmd $TMPFILE > /dev/null 2>&1 $DEBUGFS_EXE -f $TMPFILE.cmd2 $TMPFILE >> $OUT.new 2>&1 sed -f $cmd_dir/filter.sed -e '/^.*time:.*$/d' < $OUT.new >> $OUT rm -rf $OUT.new $TMPFILE.cmd $TMPFILE.cmd2 $FSCK -fy -N test_filesys $TMPFILE > $OUT.new 2>&1 status=$? echo Exit status is $status >> $OUT.new sed -f $cmd_dir/filter.sed -e "s;$TMPFILE;test.img;" $OUT.new >> $OUT rm -f $OUT.new rm -f $TMPFILE cmp -s $OUT $EXP status=$? if [ "$status" = 0 ] ; then echo "$test_name: $test_description: ok" touch $test_name.ok else echo "$test_name: $test_description: failed" diff $DIFF_OPTS $EXP $OUT > $test_name.failed rm -f $test_name.tmp fi unset IMAGE FSCK_OPT OUT EXP else #if test -x $DEBUGFS_EXE; then echo "$test_name: $test_description: skipped" fi