aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorShiyang Ruan <ruansy.fnst@fujitsu.com>2021-12-14 16:18:58 +0800
committerEryu Guan <guaneryu@gmail.com>2021-12-25 20:56:00 +0800
commit924922639321433722deb771ca26d1a9962f38a2 (patch)
treee42baaa677b1b51d31f69e57b93da8a691a0b93d
parent92b9c0dedace427e5b4d176113f13c83499855cd (diff)
downloadxfstests-dev-924922639321433722deb771ca26d1a9962f38a2.tar.gz
generic: add mmap CoW test for ranges of two shared files
Ensuring that copy on write in mmap mode works when the CoW range originally covers multiple extents. (MMAP version of generic/185,183) Signed-off-by: Shiyang Ruan <ruansy.fnst@fujitsu.com> Reviewed-by: Darrick J. Wong <djwong@kernel.org> Signed-off-by: Eryu Guan <guaneryu@gmail.com>
-rwxr-xr-xtests/generic/65769
-rw-r--r--tests/generic/657.out14
2 files changed, 83 insertions, 0 deletions
diff --git a/tests/generic/657 b/tests/generic/657
new file mode 100755
index 0000000000..e0fecd544c
--- /dev/null
+++ b/tests/generic/657
@@ -0,0 +1,69 @@
+#! /bin/bash
+# SPDX-License-Identifier: GPL-2.0
+#
+# FS QA Test No. 657
+#
+# Ensuring that copy on write in mmap mode works when the CoW
+# range originally covers multiple extents. (MMAP version of generic/185,183)
+# - Create two files
+# - Reflink the odd blocks of the first file into a third file.
+# - Reflink the even blocks of the second file into the third file.
+# - mmap CoW across the halfway mark.
+# - Check that the files are now different where we say they're different.
+#
+. ./common/preamble
+_begin_fstest auto quick clone
+
+# Import common functions.
+. ./common/filter
+. ./common/reflink
+
+# real QA test starts here
+_require_scratch_reflink
+
+echo "Format and mount"
+_scratch_mkfs > $seqres.full 2>&1
+_scratch_mount >> $seqres.full 2>&1
+
+testdir=$SCRATCH_MNT/test-$seq
+mkdir $testdir
+
+echo "Create the original files"
+blksz=65536
+nr=64
+filesize=$((blksz * nr))
+_pwrite_byte 0x61 0 $filesize $testdir/file1 >> $seqres.full
+_pwrite_byte 0x62 0 $filesize $testdir/file2 >> $seqres.full
+seq 0 2 $((nr-1)) | while read f; do
+ _reflink_range $testdir/file1 $((blksz * f)) $testdir/file3 $((blksz * f)) $blksz >> $seqres.full
+ _pwrite_byte 0x61 $((blksz * f)) $blksz $testdir/file3.chk >> $seqres.full
+done
+seq 1 2 $((nr-1)) | while read f; do
+ _reflink_range $testdir/file2 $((blksz * f)) $testdir/file3 $((blksz * f)) $blksz >> $seqres.full
+ _pwrite_byte 0x62 $((blksz * f)) $blksz $testdir/file3.chk >> $seqres.full
+done
+_scratch_cycle_mount
+
+echo "Compare files"
+md5sum $testdir/file1 | _filter_scratch
+md5sum $testdir/file2 | _filter_scratch
+md5sum $testdir/file3 | _filter_scratch
+md5sum $testdir/file3.chk | _filter_scratch
+
+echo "mmap CoW across the transition"
+cowoff=$((filesize / 4))
+cowsz=$((filesize / 2))
+mmapsz=$((cowoff + cowsz))
+_mwrite_byte 0x63 $cowoff $cowsz $mmapsz $testdir/file3 >> $seqres.full
+_mwrite_byte 0x63 $cowoff $cowsz $mmapsz $testdir/file3.chk >> $seqres.full
+_scratch_cycle_mount
+
+echo "Compare files"
+md5sum $testdir/file1 | _filter_scratch
+md5sum $testdir/file2 | _filter_scratch
+md5sum $testdir/file3 | _filter_scratch
+md5sum $testdir/file3.chk | _filter_scratch
+
+# success, all done
+status=0
+exit
diff --git a/tests/generic/657.out b/tests/generic/657.out
new file mode 100644
index 0000000000..4534c2625e
--- /dev/null
+++ b/tests/generic/657.out
@@ -0,0 +1,14 @@
+QA output created by 657
+Format and mount
+Create the original files
+Compare files
+bdbcf02ee0aa977795a79d25fcfdccb1 SCRATCH_MNT/test-657/file1
+b83f9394092e15bdcda585cd8e776dc6 SCRATCH_MNT/test-657/file2
+d3959a68638c50af07f0258e032cb554 SCRATCH_MNT/test-657/file3
+d3959a68638c50af07f0258e032cb554 SCRATCH_MNT/test-657/file3.chk
+mmap CoW across the transition
+Compare files
+bdbcf02ee0aa977795a79d25fcfdccb1 SCRATCH_MNT/test-657/file1
+b83f9394092e15bdcda585cd8e776dc6 SCRATCH_MNT/test-657/file2
+55968a95dfc0120df4e8485576514320 SCRATCH_MNT/test-657/file3
+55968a95dfc0120df4e8485576514320 SCRATCH_MNT/test-657/file3.chk