From: Eryu Guan Date: Tue, 26 May 2015 02:51:57 +0000 (+1000) Subject: xfs: be compatible with older mkfs.xfs which has no v5 support X-Git-Tag: v2022.05.01~2876 X-Git-Url: http://git.apps.os.sepia.ceph.com/?a=commitdiff_plain;h=90a3bfc5b673cc06ec81b7f7dc9788d3e30c5993;p=xfstests-dev.git xfs: be compatible with older mkfs.xfs which has no v5 support With the change to CRCs by default, some tests are updated to call mkfs with "-m crc=0" option directly, and this breaks testings on older distros where mkfs.xfs doesn't have crc support. Introduce a new variable to tell if mkfs.xfs supports v5 xfs and do tweaks in _scratch_mkfs_xfs_opts() based on it. Signed-off-by: Eryu Guan Reviewed-by: Dave Chinner Signed-off-by: Dave Chinner --- diff --git a/common/config b/common/config index 37322874..8e21c286 100644 --- a/common/config +++ b/common/config @@ -239,6 +239,17 @@ if [ -x /usr/sbin/selinuxenabled ] && /usr/sbin/selinuxenabled; then export SELINUX_MOUNT_OPTIONS fi +# check if mkfs.xfs supports v5 xfs +XFS_MKFS_HAS_NO_META_SUPPORT="" +touch /tmp/crc_check.img +$MKFS_XFS_PROG -N -d file,name=/tmp/crc_check.img,size=32m -m crc=0 \ + >/dev/null 2>&1; +if [ $? -ne 0 ]; then + XFS_MKFS_HAS_NO_META_SUPPORT=true +fi +rm -f /tmp/crc_check.img +export XFS_MKFS_HAS_NO_META_SUPPORT + _mount_opts() { case $FSTYP in diff --git a/common/rc b/common/rc index c3f60902..900b6e55 100644 --- a/common/rc +++ b/common/rc @@ -308,6 +308,11 @@ _scratch_mkfs_xfs_opts() { mkfs_opts=$* + # remove crc related mkfs options if mkfs.xfs doesn't support v5 xfs + if [ -n "$XFS_MKFS_HAS_NO_META_SUPPORT" ]; then + mkfs_opts=`echo $mkfs_opts | sed "s/-m\s\+crc=.//"` + fi + _scratch_options mkfs $MKFS_XFS_PROG $SCRATCH_OPTIONS $mkfs_opts $SCRATCH_DEV diff --git a/tests/xfs/073 b/tests/xfs/073 index 45a3fdf6..32faffdf 100755 --- a/tests/xfs/073 +++ b/tests/xfs/073 @@ -156,7 +156,12 @@ _verify_copy $imgs.image $SCRATCH_DEV $SCRATCH_MNT echo echo === copying scratch device to single target, large ro device -${MKFS_XFS_PROG} -m crc=0 -dfile,name=$imgs.source,size=100g | _filter_mkfs 2>/dev/null +mkfs_crc_opts="-m crc=0" +if [ -n "$XFS_MKFS_HAS_NO_META_SUPPORT" ]; then + mkfs_crc_opts="" +fi +${MKFS_XFS_PROG} $mkfs_crc_opts -dfile,name=$imgs.source,size=100g \ + | _filter_mkfs 2>/dev/null rmdir $imgs.source_dir 2>/dev/null mkdir $imgs.source_dir