From patchwork Fri Nov 5 03:41:58 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shiyang Ruan X-Patchwork-Id: 12604169 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 60525C433EF for ; Fri, 5 Nov 2021 03:42:27 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 3CA966112D for ; Fri, 5 Nov 2021 03:42:27 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230395AbhKEDpF (ORCPT ); Thu, 4 Nov 2021 23:45:05 -0400 Received: from mail.cn.fujitsu.com ([183.91.158.132]:12071 "EHLO heian.cn.fujitsu.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S231201AbhKEDpF (ORCPT ); Thu, 4 Nov 2021 23:45:05 -0400 IronPort-Data: A9a23:EenmT6jD2XBLClIVyMoLcdVDX161fBIKZh0ujC45NGQNrF6WrkVWx2AcCj2AMviOZjGjKo1+b9++9hgHusfczd9rGVE6qXw8FHgiRejtX4rAdhiqV8+xwmwvdGo+toNGLICowPkcFhcwnT/wdOi+xZVA/fvQHOOlUbaZYnkZqTJME0/NtzoywobVvaY42bBVMyvV0T/Di5W31G2NglaYAUpIg063ky6Didyp0N8uUvPSUtgQ1LPWvyF94JvyvshdJVOgKmVfNrbSq+ouUNiEEm3lExcFUrtJk57wdAsEX7zTIROTzHFRXsBOgDAb/mprjPl9b6FaNC+7iB3Q9zx14M9QvJqrWEEnOLbQsOoAURhECDw4NqpDkFPCCSHm753KkRWfKhMAxN0rVinaJ7Yw9P1rDHpS7tQGJz0XKBOOneS7xPS8UOYEuyiJBKEHJ6tG4jc5k26fVq1gHPj+r2zxzYcw9F8NagpmRJ4yv/YkVAc= IronPort-HdrOrdr: A9a23:xHnh2qjTiylEzwfdC4BE/1emFXBQXuYji2hC6mlwRA09TyX4rbHLoB1/73LJYVkqNk3I5urrBEDtexLhHP1OkOws1NWZLWrbUQKTRekM0WKI+UyDJ8SRzI5g/JYlW61/Jfm1NlJikPv9iTPSL/8QhPWB74Ck7N2z80tQ X-IronPort-AV: E=Sophos;i="5.87,210,1631548800"; d="scan'208";a="116916011" Received: from unknown (HELO cn.fujitsu.com) ([10.167.33.5]) by heian.cn.fujitsu.com with ESMTP; 05 Nov 2021 11:42:25 +0800 Received: from G08CNEXMBPEKD04.g08.fujitsu.local (unknown [10.167.33.201]) by cn.fujitsu.com (Postfix) with ESMTP id 5B6BE4D10102 for ; Fri, 5 Nov 2021 11:42:22 +0800 (CST) Received: from G08CNEXCHPEKD09.g08.fujitsu.local (10.167.33.85) by G08CNEXMBPEKD04.g08.fujitsu.local (10.167.33.201) with Microsoft SMTP Server (TLS) id 15.0.1497.23; Fri, 5 Nov 2021 11:42:17 +0800 Received: from irides.mr.mr.mr (10.167.225.141) by G08CNEXCHPEKD09.g08.fujitsu.local (10.167.33.209) with Microsoft SMTP Server id 15.0.1497.23 via Frontend Transport; Fri, 5 Nov 2021 11:42:15 +0800 From: Shiyang Ruan To: Subject: [PATCH 3/5] generic/xxx: Add MMAP CoW test for 'hole' case Date: Fri, 5 Nov 2021 11:41:58 +0800 Message-ID: <20211105034200.143626-4-ruansy.fnst@fujitsu.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20211105034200.143626-1-ruansy.fnst@fujitsu.com> References: <20211105034200.143626-1-ruansy.fnst@fujitsu.com> MIME-Version: 1.0 X-yoursite-MailScanner-ID: 5B6BE4D10102.AE393 X-yoursite-MailScanner: Found to be clean X-yoursite-MailScanner-From: ruansy.fnst@fujitsu.com Precedence: bulk List-ID: X-Mailing-List: fstests@vger.kernel.org Check what happens if we MMAP CoW blocks 2-4 of a page's worth of blocks when the second block is a hole. (MMAP version of generic/218,220) Signed-off-by: Shiyang Ruan --- tests/generic/902 | 70 +++++++++++++++++++++++++++++++++++++++++++ tests/generic/902.out | 6 ++++ 2 files changed, 76 insertions(+) create mode 100755 tests/generic/902 create mode 100644 tests/generic/902.out diff --git a/tests/generic/902 b/tests/generic/902 new file mode 100755 index 00000000..3fbf6143 --- /dev/null +++ b/tests/generic/902 @@ -0,0 +1,70 @@ +#! /bin/bash +# SPDX-License-Identifier: GPL-2.0 +# +# FS QA Test No. xxx +# +# See what happens if we MMAP CoW blocks 2-4 of a page's worth of blocks when +# the second block is a hole. (MMAP version of generic/218,220) +# +# This test is dependent on the system page size, so we cannot use md5 in +# the golden output; we can only compare to a check file. +# +. ./common/preamble +_begin_fstest auto quick clone + +# Override the default cleanup function. +_cleanup() +{ + cd / + rm -rf $tmp.* $testdir +} + +# Import common functions. +. ./common/filter +. ./common/reflink + +# real QA test starts here +_require_scratch_reflink +_require_xfs_io_command "falloc" + +pagesz=$(getconf PAGE_SIZE) +blksz=$((pagesz / 4)) + +echo "Format and mount" +_scratch_mkfs_blocksized $blksz > $seqres.full 2>&1 +_scratch_mount >> $seqres.full 2>&1 + +testdir=$SCRATCH_MNT/test-$seq +mkdir $testdir + +real_blksz=$(_get_file_block_size $testdir) +test $real_blksz != $blksz && _notrun "Failed to format with small blocksize." + +echo "Create the original files" +_pwrite_byte 0x61 0 $pagesz $testdir/file1 >> $seqres.full + +$XFS_IO_PROG -f -c "truncate $pagesz" $testdir/file2 >> $seqres.full +$XFS_IO_PROG -f -c "truncate $pagesz" $testdir/file2.chk >> $seqres.full + +_reflink_range $testdir/file1 $blksz $testdir/file2 $((blksz * 2)) $blksz >> $seqres.full +_pwrite_byte 0x61 $((blksz * 2)) $blksz $testdir/file2.chk >> $seqres.full +_scratch_cycle_mount + +echo "Compare files" +! cmp -s $testdir/file1 $testdir/file2 || _fail "file1 and file2 don't match." +cmp -s $testdir/file2 $testdir/file2.chk || _fail "file2 and file2.chk don't match." + +echo "CoW and unmount" +$XFS_IO_PROG -f -c "mmap 0 $pagesz" \ + -c "mwrite -S 0x63 $((blksz + 17)) $((blksz * 3 - 34))" $testdir/file2 >> $seqres.full +$XFS_IO_PROG -f -c "mmap 0 $pagesz" \ + -c "mwrite -S 0x63 $((blksz + 17)) $((blksz * 3 - 34))" $testdir/file2.chk >> $seqres.full +_scratch_cycle_mount + +echo "Compare files" +! cmp -s $testdir/file1 $testdir/file2 || _fail "file1 and file2 don't match." +cmp -s $testdir/file2 $testdir/file2.chk || _fail "file2 and file2.chk don't match." + +# success, all done +status=0 +exit diff --git a/tests/generic/902.out b/tests/generic/902.out new file mode 100644 index 00000000..4fb8b6cb --- /dev/null +++ b/tests/generic/902.out @@ -0,0 +1,6 @@ +QA output created by 902 +Format and mount +Create the original files +Compare files +CoW and unmount +Compare files