#! /bin/bash # SPDX-License-Identifier: GPL-2.0 # Copyright (c) 2017 Intel Corporation. All Rights Reserved. # # FS QA Test No. 470 # # Use dm-log-writes to verify that MAP_SYNC actually syncs metadata during # page faults. # seq=`basename $0` seqres=$RESULT_DIR/$seq echo "QA output created by $seq" tmp=/tmp/$$ here=`pwd` status=1 # failure is the default! trap "_cleanup; exit \$status" 0 1 2 3 15 _cleanup() { cd / _log_writes_cleanup _dmthin_cleanup rm -f $tmp.* } # get standard environment, filters and checks . ./common/rc . ./common/filter . ./common/dmthin . ./common/dmlogwrites # remove previous $seqres.full before test rm -f $seqres.full # real QA test starts here _supported_fs generic _require_scratch_nocheck _require_log_writes_dax_mountopt "dax" _require_dm_target thin-pool _require_xfs_io_command "mmap" "-S" _require_xfs_io_command "log_writes" devsize=$((1024*1024*200 / 512)) # 200m phys/virt size csize=$((1024*64 / 512)) # 64k cluster size lowspace=$((1024*1024 / 512)) # 1m low space threshold # Use a thin device to provide deterministic discard behavior. Discards are used # by the log replay tool for fast zeroing to prevent out-of-order replay issues. _dmthin_init $devsize $devsize $csize $lowspace _log_writes_init $DMTHIN_VOL_DEV _log_writes_mkfs >> $seqres.full 2>&1 _log_writes_mount -o dax LEN=$((1024 * 1024)) # 1 MiB $XFS_IO_PROG -t -c "truncate $LEN" -c "mmap -S 0 $LEN" -c "mwrite 0 $LEN" \ -c "log_writes -d $LOGWRITES_NAME -m preunmap" \ -f $SCRATCH_MNT/test # Unmount the scratch dir and tear down the log writes target _log_writes_unmount _log_writes_remove _dmthin_check_fs # destroy previous filesystem so we can be sure our rebuild works _mkfs_dev $DMTHIN_VOL_DEV >> $seqres.full 2>&1 # check pre-unmap state _log_writes_replay_log preunmap $DMTHIN_VOL_DEV _dmthin_mount # We should see $SCRATCH_MNT/test as having 1 MiB in block allocations du -sh $SCRATCH_MNT/test | _filter_scratch | _filter_spaces status=0 exit