#! /bin/bash # SPDX-License-Identifier: GPL-2.0 # # FSQA Test No. 299 # # AIO/DIO stress test # Run random AIO/DIO activity and fallocate/truncate simultaneously # Test will operate on huge sparsed files so ENOSPC is expected. # seq=`basename $0` seqres=$RESULT_DIR/$seq echo "QA output created by $seq" here=`pwd` tmp=/tmp/$$ fio_config=$tmp.fio fio_out=$tmp.fio.out status=1 # failure is the default! trap "_cleanup; exit \$status" 0 1 2 3 15 _cleanup() { cd / rm -f $tmp.* } # get standard environment, filters and checks . ./common/rc . ./common/filter # real QA test starts here _supported_fs generic _require_test _require_scratch _require_odirect _require_aio _require_block_device $SCRATCH_DEV NUM_JOBS=$((4*LOAD_FACTOR)) BLK_DEV_SIZE=`blockdev --getsz $SCRATCH_DEV` FILE_SIZE=$((BLK_DEV_SIZE * 512)) max_file_size=$(_get_max_file_size) if [ $max_file_size -lt $FILE_SIZE ]; then FILE_SIZE=$max_file_size fi cat >$fio_config <> $seqres.full 2>&1 _scratch_mount echo "" echo "Run fio with random aio-dio pattern" echo "" cat $fio_config >> $seqres.full $FIO_PROG $fio_config --output=$fio_out & pid=$! echo "Start fallocate/truncate loop" for ((i=0; ; i++)); do for ((k=1; k <= NUM_JOBS; k++)); do $XFS_IO_PROG -f -c "falloc 0 $FILE_SIZE" \ $SCRATCH_MNT/direct_aio.$k.0 >> $seqres.full 2>&1 done for ((k=1; k <= NUM_JOBS; k++)); do $XFS_IO_PROG -c "truncate 0" \ $SCRATCH_MNT/direct_aio.$k.0 >> $seqres.full 2>&1 done # Following like will check that pid is still run. # Once fio exit we can stop fallocate/truncate loop pgrep -f "$FIO_PROG" > /dev/null 2>&1 || break done wait $pid cat $fio_out >> $seqres.full status=0 exit