@@ -96,6 +96,11 @@ _require_btrfs_fs_feature()
modprobe btrfs > /dev/null 2>&1
[ -e /sys/fs/btrfs/features/$feat ] || \
_notrun "Feature $feat not supported by the available btrfs version"
+
+ if [ $feat = "raid56" ]; then
+ # Zoned btrfs only supports SINGLE profile
+ _require_non_zoned_device "${SCRATCH_DEV}"
+ fi
}
_require_btrfs_fs_sysfs()
@@ -222,6 +227,21 @@ _btrfs_get_profile_configs()
else
local unsupported=()
fi
+
+ if _scratch_btrfs_is_zoned; then
+ # Zoned btrfs only supports SINGLE profile
+ unsupported+=(
+ "dup"
+ "raid0"
+ "raid1"
+ "raid1c3"
+ "raid1c4"
+ "raid10"
+ "raid5"
+ "raid6"
+ )
+ fi
+
for unsupp in "${unsupported[@]}"; do
if [ "${profiles[0]}" == "$unsupp" -o "${profiles[1]}" == "$unsupp" ]; then
if [ -z "$BTRFS_PROFILE_CONFIGS" ]; then
@@ -419,3 +439,9 @@ _btrfs_rescan_devices()
{
$BTRFS_UTIL_PROG device scan &> /dev/null
}
+
+_scratch_btrfs_is_zoned()
+{
+ [ `_zone_type ${SCRATCH_DEV}` != "none" ] && return 0
+ return 1
+}
@@ -173,12 +173,20 @@ _test_remove()
_scratch_unmount
}
-_test_raid0
-_test_raid1
-_test_raid10
+# Zoned btrfs only supports SINGLE profile
+if ! _scratch_btrfs_is_zoned; then
+ _test_raid0
+ _test_raid1
+ _test_raid10
+fi
+
_test_single
_test_add
-_test_replace
+# _test_replace() uses raid1, but zoned btrfs only supports SINGLE
+# profile
+if ! _scratch_btrfs_is_zoned; then
+ _test_replace
+fi
_test_remove
echo "Silence is golden"
@@ -226,15 +226,18 @@ btrfs_replace_test()
}
workout "-m single -d single" 1 no 64
-workout "-m single -d single -M" 1 no 64
-workout "-m dup -d single" 1 no 64
-workout "-m dup -d single" 1 cancel 1024
-workout "-m dup -d dup -M" 1 no 64
-workout "-m raid0 -d raid0" 2 no 64
-workout "-m raid1 -d raid1" 2 no 2048
-workout "-m raid5 -d raid5" 2 no 64
-workout "-m raid6 -d raid6" 3 no 64
-workout "-m raid10 -d raid10" 4 no 64
+# Mixed BG & RAID/DUP profiles are not supported on zoned btrfs
+if ! _scratch_btrfs_is_zoned; then
+ workout "-m dup -d single" 1 no 64
+ workout "-m dup -d single" 1 cancel 1024
+ workout "-m raid0 -d raid0" 2 no 64
+ workout "-m raid1 -d raid1" 2 no 2048
+ workout "-m raid10 -d raid10" 4 no 64
+ workout "-m single -d single -M" 1 no 64
+ workout "-m dup -d dup -M" 1 no 64
+ workout "-m raid5 -d raid5" 2 no 64
+ workout "-m raid6 -d raid6" 3 no 64
+fi
echo "*** done"
status=0
@@ -28,6 +28,8 @@ _require_scratch_nocheck
_require_command "$BTRFS_CONVERT_PROG" btrfs-convert
_require_command "$MKFS_EXT4_PROG" mkfs.ext4
_require_command "$E2FSCK_PROG" e2fsck
+# ext4 does not support zoned block device
+_require_non_zoned_device "${SCRATCH_DEV}"
_require_fs_space $SCRATCH_MNT $(du -s /lib/modules/`uname -r` | ${AWK_PROG} '{print $1}')
@@ -17,6 +17,8 @@ _begin_fstest auto
# real QA test starts here
_supported_fs btrfs
_require_scratch_dev_pool 4
+# Zoned btrfs only supports SINGLE profile
+_require_non_zoned_device "${SCRATCH_DEV}"
create_group_profile()
{
@@ -27,6 +27,8 @@ _cleanup()
_supported_fs btrfs
_require_scratch
_require_dm_target flakey
+# Zoned btrfs does not support inode cache
+_require_non_zoned_device "$SCRATCH_DEV"
_scratch_mkfs >> $seqres.full 2>&1
@@ -18,6 +18,8 @@ _begin_fstest auto quick metadata
# real QA test starts here
_supported_fs btrfs
_require_scratch
+# Writing non-contiguous data directly to the device
+_require_non_zoned_device $SCRATCH_DEV
_scratch_mkfs >>$seqres.full 2>&1
@@ -49,6 +49,10 @@ _scratch_dev_pool_get 2
dev1=`echo $SCRATCH_DEV_POOL | awk '{print $1}'`
dev2=`echo $SCRATCH_DEV_POOL | awk '{print $2}'`
+# RAID1 is not supported on zoned btrfs
+_require_non_zoned_device "$dev1"
+_require_non_zoned_device "$dev2"
+
dev1_sz=`blockdev --getsize64 $dev1`
dev2_sz=`blockdev --getsize64 $dev2`
# get min of both
@@ -18,6 +18,8 @@ _supported_fs btrfs
_require_scratch
_require_btrfs_command inspect-internal dump-super
_require_btrfs_fs_feature free_space_tree
+# Zoned btrfs does not support space_cache(v1)
+_require_non_zoned_device "${SCRATCH_DEV}"
mkfs_v1()
{
@@ -22,6 +22,8 @@ _begin_fstest auto convert
# Modify as appropriate.
_supported_fs btrfs
_require_scratch_nocheck
+# ext4 does not support zoned block device
+_require_non_zoned_device "${SCRATCH_DEV}"
_require_command "$BTRFS_CONVERT_PROG" btrfs-convert
_require_command "$MKFS_EXT4_PROG" mkfs.ext4
@@ -26,6 +26,8 @@ _require_scratch_dev_pool 2
_require_btrfs_command inspect-internal dump-tree
_require_command "$FILEFRAG_PROG" filefrag
_require_odirect
+# Overwriting data is forbidden on a zoned block device
+_require_non_zoned_device "${SCRATCH_DEV}"
get_physical()
{
@@ -59,7 +59,7 @@ for (( i = 0; i < 64; i++ )); do
$BTRFS_UTIL_PROG device del $device_1 $SCRATCH_MNT
$BTRFS_UTIL_PROG device add -f $device_1 $SCRATCH_MNT
$BTRFS_UTIL_PROG device del $device_2 $SCRATCH_MNT
-done
+done | grep -v 'Resetting device zone'
_scratch_dev_pool_put
echo "Silence is golden"
@@ -18,6 +18,8 @@ _begin_fstest auto volume balance
# Modify as appropriate.
_supported_fs btrfs
_require_scratch_dev_pool 4
+# Zoned btrfs only supports SINGLE profile
+_require_non_zoned_device "${SCRATCH_DEV}"
declare -a TEST_VECTORS=(
# $nr_dev_min:$data:$metadata:$data_convert:$metadata_convert
@@ -30,6 +30,8 @@ _supported_fs btrfs
_require_test
_require_scratch
_require_scratch_dev_pool 5
+# Zoned btrfs only supports SINGLE profile
+_require_non_zoned_device ${SCRATCH_DEV}
workout()
{
@@ -20,6 +20,8 @@ _supported_fs btrfs
_require_command "$WIPEFS_PROG" wipefs
_require_scratch
_require_scratch_dev_pool 4
+# Zoned btrfs only supports SINGLE profile
+_require_non_zoned_device ${SCRATCH_DEV}
workout()
{
@@ -24,6 +24,8 @@ get_physical()
# Modify as appropriate.
_supported_fs btrfs
+# Overwriting data is forbidden on a zoned block device
+_require_non_zoned_device $SCRATCH_DEV
_scratch_mkfs > /dev/null
# disable freespace inode to ensure file is the first thing in the data
@@ -173,21 +173,28 @@ for ((i = 1; i <= 3; i++)); do
test_fsync "link_cow_$i" "link"
done
-# Now lets test with nodatacow.
_unmount_flakey
-MOUNT_OPTIONS="-o nodatacow"
-_mount_flakey
-echo "Testing fsync after rename with NOCOW writes"
-for ((i = 1; i <= 3; i++)); do
- test_fsync "rename_nocow_$i" "rename"
-done
-echo "Testing fsync after link with NOCOW writes"
-for ((i = 1; i <= 3; i++)); do
- test_fsync "link_nocow_$i" "link"
-done
-
-_unmount_flakey
+# Now lets test with nodatacow.
+if ! _scratch_btrfs_is_zoned; then
+ MOUNT_OPTIONS="-o nodatacow"
+ _mount_flakey
+
+ echo "Testing fsync after rename with NOCOW writes"
+ for ((i = 1; i <= 3; i++)); do
+ test_fsync "rename_nocow_$i" "rename"
+ done
+ echo "Testing fsync after link with NOCOW writes"
+ for ((i = 1; i <= 3; i++)); do
+ test_fsync "link_nocow_$i" "link"
+ done
+
+ _unmount_flakey
+else
+ # Fake result. Zoned btrfs does not support NOCOW
+ echo "Testing fsync after rename with NOCOW writes"
+ echo "Testing fsync after link with NOCOW writes"
+fi
status=0
exit
Modify btrfs tests to require non-zoned block device or limit some part of tests not to be run on zone block devices. Modified tests by the reasons: * Mixed BG - btrfs/011 * Non-single profile - btrfs/003 - btrfs/011 - btrfs/023 - btrfs/124 - btrfs/195 - btrfs/197 - btrfs/198 - and these are restricted indirectly by "_require_btrfs_fs_feature raid56" - btrfs/125 - btrfs/148 - btrfs/157 - btrfs/158 * Convert from ext4 - btrfs/012 - btrfs/136 * nodatacow - btrfs/236 * inode cache - btrfs/049 * space cache (v1) - btrfs/131 * write outside of FS code - btrfs/116 - btrfs/140 - btrfs/215 * verbose output - btrfs/194 Signed-off-by: Naohiro Aota <naohiro.aota@wdc.com> --- common/btrfs | 26 ++++++++++++++++++++++++++ tests/btrfs/003 | 16 ++++++++++++---- tests/btrfs/011 | 21 ++++++++++++--------- tests/btrfs/012 | 2 ++ tests/btrfs/023 | 2 ++ tests/btrfs/049 | 2 ++ tests/btrfs/116 | 2 ++ tests/btrfs/124 | 4 ++++ tests/btrfs/131 | 2 ++ tests/btrfs/136 | 2 ++ tests/btrfs/140 | 2 ++ tests/btrfs/194 | 2 +- tests/btrfs/195 | 2 ++ tests/btrfs/197 | 2 ++ tests/btrfs/198 | 2 ++ tests/btrfs/215 | 2 ++ tests/btrfs/236 | 33 ++++++++++++++++++++------------- 17 files changed, 97 insertions(+), 27 deletions(-)