@@ -33,6 +33,16 @@ BC=$(which bc 2> /dev/null) || BC=
VALID_TEST_ID="[0-9]\{3\}"
VALID_TEST_NAME="$VALID_TEST_ID-\?[[:alnum:]-]*"
+# When running tests with a realtime device configured, the realtime inherit
+# flag will be set during mkfs via -d rtinherit=1 option. For some tests
+# this may render the test invalid (i.e. it uses a function which is not
+# supported by the realtime subvolume); to prevent failure these tests may
+# disable this behavior by calling _require_no_rtinherit .
+_require_no_rtinherit()
+{
+ RT_INHERIT=false
+}
+
_require_math()
{
if [ -z "$BC" ]; then
@@ -562,6 +572,13 @@ _scratch_do_mkfs()
local mkfs_status
local tmp=`mktemp -u`
+ # Add rtinherit=1 to mkfs so we exercise realtime subvolume during
+ # our tests. Tests can opts out of this behavior by calling
+ # _require_no_rtinherit.
+ if $RT_INHERIT && echo "$mkfs_cmd" | grep rtdev &> /dev/null; then
+ extra_mkfs_options="$extra_mkfs_options -d rtinherit=1"
+ fi
+
# save mkfs output in case conflict means we need to run again.
# only the output for the mkfs that applies should be shown
eval "$mkfs_cmd $MKFS_OPTIONS $extra_mkfs_options $SCRATCH_DEV" \
@@ -760,7 +777,12 @@ _mkfs_dev()
;;
*)
- yes | $MKFS_PROG -t $FSTYP -- $MKFS_OPTIONS $* \
+ local extra_mkfs_options="$*"
+ # Similar behavior to the scratch variant of this
+ if $RT_INHERIT && echo $extra_mkfs_options | grep rtdev &> /dev/null; then
+ extra_mkfs_options="$extra_mkfs_options -d rtinherit=1"
+ fi
+ yes | $MKFS_PROG -t $FSTYP -- $MKFS_OPTIONS $extra_mkfs_options \
2>$tmp.mkfserr 1>$tmp.mkfsstd
;;
esac
@@ -48,6 +48,7 @@ _require_scratch
_require_dm_target error
_require_xfs_io_command "falloc"
_require_odirect
+_require_no_rtinherit
rm -f $seqres.full
@@ -47,6 +47,7 @@ _supported_os Linux
_require_scratch
_require_dm_target error
_require_xfs_io_command "falloc"
+_require_no_rtinherit
_require_aiodio "aiocp"
AIO_TEST="src/aio-dio-regress/aiocp"
@@ -53,6 +53,7 @@ _supported_os Linux
_require_scratch
_require_test_program "feature"
_require_aiodio aio-dio-eof-race
+_require_no_rtinherit
# limit the filesystem size, to save the time of filling filesystem
_scratch_mkfs_sized $((256 * 1024 * 1024)) >>$seqres.full 2>&1
@@ -47,6 +47,7 @@ _cleanup()
# real QA test starts here
_supported_os Linux
_require_scratch
+_require_no_rtinherit
# Generally, we want to avoid journal errors on the extended testcase. Only
# unset the -s flag if we have a logdev
@@ -66,6 +66,7 @@ _supported_fs xfs
_supported_os Linux
_require_scratch
+_require_no_rtinherit
protofile=$tmp.proto
tempfile=$tmp.file
@@ -96,6 +96,7 @@ _supported_os Linux
_require_scratch
_require_no_large_scratch_dev
+_require_no_rtinherit
# sanity test - default + one root directory entry
# Note: must do this proto/mkfs now for later inode size calcs
@@ -50,6 +50,7 @@ _supported_fs xfs
_supported_os Linux
_require_scratch
+_require_no_rtinherit
_check_filestreams_support || _notrun "filestreams not available"
@@ -56,6 +56,7 @@ _filter_version()
_supported_fs xfs
_supported_os Linux
+_require_no_rtinherit
_require_scratch
_require_attrs
_require_attr_v1
To better exercise the data path code of realtime subvolumes, we will set rtinherit=1 during mkfs calls. For tests which this is not desired we introduce a _require_no_rtinherit function to opt out of this behavior. Signed-off-by: Richard Wareing <rwareing@fb.com> --- common/rc | 24 +++++++++++++++++++++++- tests/generic/250 | 1 + tests/generic/252 | 1 + tests/generic/427 | 1 + tests/generic/441 | 1 + tests/xfs/019 | 1 + tests/xfs/031 | 1 + tests/xfs/170 | 1 + tests/xfs/187 | 1 + 9 files changed, 31 insertions(+), 1 deletion(-)