On Wed, Mar 26, 2025 at 08:03:41PM +0800, Chao Yu wrote: > This is a regression testcase to check whether we will handle > out-of-space case correctly during fallocate() on pinned file > once we disable checkpoint. > > Testcase: > 1. mount f2fs w/ checkpoint=disable option > 2. create fragmented file data > 3. set flag w/ pinned flag > 4. fallocate space for pinned file, expects panic due to running > out of space. > > We should apply commit 48ea8b200414 ("f2fs: fix to avoid panic > once fallocation fails for pinfile") to avoid system panic. > Note that it only fix the issue for regular block device, problem > still exist for zoned block device. > > Cc: Jaegeuk Kim <jaeg...@kernel.org> > Signed-off-by: Chao Yu <c...@kernel.org> > --- > tests/f2fs/011 | 58 ++++++++++++++++++++++++++++++++++++++++++++++ > tests/f2fs/011.out | 2 ++ > 2 files changed, 60 insertions(+) > create mode 100755 tests/f2fs/011 > create mode 100644 tests/f2fs/011.out > > diff --git a/tests/f2fs/011 b/tests/f2fs/011 > new file mode 100755 > index 00000000..1ece8fd0 > --- /dev/null > +++ b/tests/f2fs/011 > @@ -0,0 +1,58 @@ > +#! /bin/bash > +# SPDX-License-Identifier: GPL-2.0 > +# Copyright (c) 2025 Chao Yu. All Rights Reserved. > +# > +# FS QA Test No. f2fs/012 > +# > +# This is a regression testcase to check whether we will handle > +# out-of-space case correctly during fallocate() on pinned file > +# once we disable checkpoint. > +# 1. mount f2fs w/ checkpoint=disable option > +# 2. create fragmented file data > +# 3. set flag w/ pinned flag > +# 4. fallocate space for pinned file, expects panic due to running > +# out of space > +# We should apply commit 48ea8b200414 ("f2fs: fix to avoid panic > +# once fallocation fails for pinfile") to avoid system panic. > +# Note that it only fix the issue for regular block device, problem > +# still exist for zoned block device. > +# > +. ./common/preamble > +_begin_fstest auto quick > + > +_cleanup() > +{ > + cd / > + rm -r -f $tmp.* > +}
Default _cleanup does the same things, so above _cleanup can be removed. > + > +_fixed_by_kernel_commit 48ea8b200414 \ > + "f2fs: fix to avoid panic once fallocation fails for pinfile" > + > +_require_scratch > +_require_command "$F2FS_IO_PROG" f2fs_io > + > +_scratch_mkfs_sized $((1*1024*1024*1024)) >> $seqres.full > +_scratch_mount -o checkpoint=disable:10% > + > +pinfile=$SCRATCH_MNT/file > + > +# simulate fragment status in f2fs > +for ((i=0;i<256;i++)) do > + dd if=/dev/zero of=$SCRATCH_MNT/$i bs=1M count=1 >>$seqres.full 2>&1 We'd like to use xfs_io when we can: $XFS_IO_PROG -f -c "pwrite 0 1m" $SCRATCH_MNT/$i >>$seqres.full > +done > +sync > + > +for ((i=0;i<256;i+=2)) do > + rm $SCRATCH_MNT/$i >> $seqres.full 2>&1 How about "rm -f $SCRATCH_MNT/$i" without ">> $seqres.full 2>&1" ? > +done > +sync > + > +touch $pinfile > +$F2FS_IO_PROG pinfile set $pinfile >> $seqres.full > +fallocate -l $((3*256*1024*1024)) $pinfile >> $seqres.full 2>&1 Same, we'd like to use xfs_io at first, due to it's already a necessary running dependence of fstests. $XFS_IO_PROG -c "falloc 0 $((3*256*1024*1024))" $pinfile Thanks, Zorro > + > +echo "Silence is golden" > + > +status=0 > +exit > diff --git a/tests/f2fs/011.out b/tests/f2fs/011.out > new file mode 100644 > index 00000000..62e02519 > --- /dev/null > +++ b/tests/f2fs/011.out > @@ -0,0 +1,2 @@ > +QA output created by 011 > +Silence is golden > -- > 2.49.0 > _______________________________________________ Linux-f2fs-devel mailing list Linux-f2fs-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel