Re: [PATCH] xfs/078: instead file image by mkfs on loopback device

[Date Prev] [Date Next] [Thread Prev] [Thread Next] [Date Index] [Thread Index]



On Tue, Mar 7, 2017 at 9:22 AM, Zorro Lang <zlang@xxxxxxxxxx> wrote:
> If test on 4k sector size device, xfs/078 will fail when it try to
> make a filesystem image with block size less than 4096. But if we
> attach the file image to a loop device, it can accept 512 block
> size. So this patch attach a loop device before do mkfs.xfs.
>
> Signed-off-by: Zorro Lang <zlang@xxxxxxxxxx>
> ---
>  tests/xfs/078     | 50 ++++++++++++++++++++++++++++----------------------
>  tests/xfs/078.out | 16 ++++++++--------
>  2 files changed, 36 insertions(+), 30 deletions(-)
>
> diff --git a/tests/xfs/078 b/tests/xfs/078
> index 0d6eb55..2b8e8f1 100755
> --- a/tests/xfs/078
> +++ b/tests/xfs/078
> @@ -34,11 +34,14 @@ trap "_cleanup; rm -f $tmp.*; exit \$status" 0 1 2 3 15
>
>  _cleanup()
>  {
> -    cd /
> -    rm -f $tmp.*
> -    umount $LOOP_MNT 2>/dev/null
> -    [ -n "$LOOP_DEV" ] && losetup -d $LOOP_DEV
> -    rmdir $LOOP_MNT
> +       cd /
> +       rm -f $tmp.*
> +       umount $LOOP_MNT 2>/dev/null

umount -d ?

> +       if [ -n "$LOOP_DEV" ]; then
> +               _destroy_loop_device $LOOP_DEV
> +               rm -f $LOOP_IMG

$LOOP_IMG can exist also when $LOOP_DEV does not
makes sense to rm -f $LOOP_IMG anyway.

> +       fi
> +       rmdir $LOOP_MNT
>  }
>
>  # get standard environment, filters and checks
> @@ -52,6 +55,7 @@ _supported_os Linux
>  _require_test
>  # Must have loop device
>  _require_loop
> +_require_xfs_io_command "truncate"
>
>  LOOP_IMG=$TEST_DIR/$seq.fs
>  LOOP_MNT=$TEST_DIR/$seq.mnt
> @@ -77,9 +81,12 @@ _grow_loop()
>         check=$4
>         agsize=$5
>
> -       dparam="file,name=$LOOP_IMG,size=$original"
> +       $XFS_IO_PROG -f -c "truncate $original" $LOOP_IMG
> +       LOOP_DEV=`_create_loop_device $LOOP_IMG`
> +
> +       dparam=""
>         if [ -n "$agsize" ]; then
> -               dparam="$dparam,agsize=$agsize"
> +               dparam="-d agsize=$agsize"
>         fi
>
>         echo
> @@ -87,20 +94,21 @@ _grow_loop()
>         echo
>
>         echo "*** mkfs loop file (size=$original)"
> -       mkfs_crc_opts="-m crc=0"
> -       if [ -n "$XFS_MKFS_HAS_NO_META_SUPPORT" ]; then
> -               mkfs_crc_opts=""
> +       mkfs_crc_opts=""
> +       if [ $bsize -lt 1024 -a -z "$XFS_MKFS_HAS_NO_META_SUPPORT" ]; then
> +               mkfs_crc_opts="-m crc=0"
>         fi
> -       $MKFS_XFS_PROG $mkfs_crc_opts -b size=$bsize -d $dparam \
> +       $MKFS_XFS_PROG $mkfs_crc_opts -b size=$bsize $dparam $LOOP_DEV \
>                 | _filter_mkfs 2>/dev/null
>
>         echo "*** extend loop file"
> +       _destroy_loop_device $LOOP_DEV
>         $XFS_IO_PROG -c "pwrite $new_size $bsize" $LOOP_IMG | _filter_io
> +       LOOP_DEV=`_create_loop_device $LOOP_IMG`
>         echo "*** mount loop filesystem"
> -       mount -t xfs -o loop $LOOP_IMG $LOOP_MNT
> +       mount -t xfs $LOOP_DEV $LOOP_MNT
>
>         echo "*** grow loop filesystem"
> -       #xfs_growfs $LOOP_MNT 2>&1 | grep -e "^data" #| _filter_growfs 2>/dev/null
>         $XFS_GROWFS_PROG $LOOP_MNT 2>&1 |  _filter_growfs 2>&1
>
>         echo "*** unmount"
> @@ -110,23 +118,21 @@ _grow_loop()
>         if [ "$check" -gt "0" ]
>         then
>                 echo "*** check"
> -               LOOP_DEV=`losetup -f`
> -               losetup $LOOP_DEV $LOOP_IMG
> -                _check_xfs_filesystem $LOOP_DEV none none
> -               losetup -d $LOOP_DEV
> -               LOOP_DEV=
> +               _check_xfs_filesystem $LOOP_DEV none none

This looks correct, /but/, I ran into umount implementations (Android's busybox)
that were too eager to detach the loop device even though -d was not specified
and even though mount did not have -o loop option.
To be fair, the umount man page lists the conditions when umount *will* detach
the loop device, but it does not explicitly say that it *will not*
detach otherwise.

So perhaps it would be safer to use umount -d above and keep this code
that recreated loop device for check_xfs_filesystem?

>         fi
>
> +       _destroy_loop_device $LOOP_DEV
> +       LOOP_DEV=
>         rm -f $LOOP_IMG
>  }
>
>  # Wes' problem sizes...
> -_grow_loop 168024b 1376452608 4096 1
> +_grow_loop $((168024*4096)) 1376452608 4096 1
>
>  # Some other blocksize cases...
> -_grow_loop 168024b 1376452608 2048 1
> -_grow_loop 168024b 1376452608 512 1 16m
> -_grow_loop 168024b 688230400 1024 1
> +_grow_loop $((168024*2048)) 1376452608 2048 1
> +_grow_loop $((168024*512)) 1376452608 512 1 16m
> +_grow_loop $((168024*1024)) 688230400 1024 1
>
>  # Other corner cases suggested by dgc
>  # also the following doesn't check if the filesystem is consistent.
> diff --git a/tests/xfs/078.out b/tests/xfs/078.out
> index 4d294aa..cc3c47d 100644
> --- a/tests/xfs/078.out
> +++ b/tests/xfs/078.out
> @@ -1,9 +1,9 @@
>  QA output created by 078
>  *** create loop mount point
>
> -=== GROWFS (from 168024b to 1376452608, 4096 blocksize)
> +=== GROWFS (from 688226304 to 1376452608, 4096 blocksize)
>
> -*** mkfs loop file (size=168024b)
> +*** mkfs loop file (size=688226304)
>  meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
>  data     = bsize=XXX blocks=XXX, imaxpct=PCT
>           = sunit=XXX swidth=XXX, unwritten=X
> @@ -19,9 +19,9 @@ data blocks changed from 168024 to 336048
>  *** unmount
>  *** check
>
> -=== GROWFS (from 168024b to 1376452608, 2048 blocksize)
> +=== GROWFS (from 344113152 to 1376452608, 2048 blocksize)
>
> -*** mkfs loop file (size=168024b)
> +*** mkfs loop file (size=344113152)
>  meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
>  data     = bsize=XXX blocks=XXX, imaxpct=PCT
>           = sunit=XXX swidth=XXX, unwritten=X
> @@ -37,9 +37,9 @@ data blocks changed from 168024 to 672096
>  *** unmount
>  *** check
>
> -=== GROWFS (from 168024b to 1376452608, 512 blocksize)
> +=== GROWFS (from 86028288 to 1376452608, 512 blocksize)
>
> -*** mkfs loop file (size=168024b)
> +*** mkfs loop file (size=86028288)
>  meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
>  data     = bsize=XXX blocks=XXX, imaxpct=PCT
>           = sunit=XXX swidth=XXX, unwritten=X
> @@ -55,9 +55,9 @@ data blocks changed from 163840 to 2688384
>  *** unmount
>  *** check
>
> -=== GROWFS (from 168024b to 688230400, 1024 blocksize)
> +=== GROWFS (from 172056576 to 688230400, 1024 blocksize)
>
> -*** mkfs loop file (size=168024b)
> +*** mkfs loop file (size=172056576)
>  meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
>  data     = bsize=XXX blocks=XXX, imaxpct=PCT
>           = sunit=XXX swidth=XXX, unwritten=X
> --
> 2.7.4
>
> --
> To unsubscribe from this list: send the line "unsubscribe fstests" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe fstests" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Filesystems Development]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux