From d98d483b74a6357b5a8e69cb0bd87a0abdc6af09 Mon Sep 17 00:00:00 2001 From: "Darrick J. Wong" Date: Thu, 4 Oct 2018 17:19:14 -0700 Subject: [PATCH] generic: another mread-after-eof test Add Brian Foster's alternate reproducer code for the mread-after-eof problem so that we increase the chances that either this or generic/499 will catch the problem. Signed-off-by: Darrick J. Wong Reviewed-by: Eryu Guan Signed-off-by: Eryu Guan --- tests/generic/511 | 54 +++++++++++++++++++++++++++++++++++++++++++ tests/generic/511.out | 2 ++ tests/generic/group | 1 + 3 files changed, 57 insertions(+) create mode 100755 tests/generic/511 create mode 100644 tests/generic/511.out diff --git a/tests/generic/511 b/tests/generic/511 new file mode 100755 index 00000000..4d133f49 --- /dev/null +++ b/tests/generic/511 @@ -0,0 +1,54 @@ +#! /bin/bash +# SPDX-License-Identifier: GPL-2.0 +# Copyright (c) 2018 Oracle, Inc. All Rights Reserved. +# +# FS QA Test No. 511 +# +# Test a specific sequence of fsx operations that causes an mmap read past +# eof to return nonzero contents. +# +seq=`basename $0` +seqres=$RESULT_DIR/$seq +echo "QA output created by $seq" +tmp=/tmp/$$ +status=1 # failure is the default! +trap "_cleanup; exit \$status" 0 1 2 3 15 + +_cleanup() +{ + cd / + rm -f $tmp.* +} + +# get standard environment, filters and checks +. ./common/rc +. ./common/punch + +# real QA test starts here +_supported_fs generic +_supported_os Linux +_require_scratch +_require_xfs_io_command "fzero" + +rm -f $seqres.full + +_scratch_mkfs_sized $((1024 * 1024 * 256)) >>$seqres.full 2>&1 +_scratch_mount + +$XFS_IO_PROG -fc "pwrite 0 256m" -c fsync $SCRATCH_MNT/file >>$seqres.full 2>&1 +rm -f $SCRATCH_MNT/file + +cat >> $tmp.fsxops << ENDL +truncate 0x0 0x1f0d6 0x380e1 +write 0x1ad87 0x6c99 0x180d6 +zero_range 0x14426 0xd3aa 0x21a20 keep_size +mapread 0x1f69a 0x2386 0x21a20 +ENDL + +victim=$SCRATCH_MNT/a +touch $victim +$here/ltp/fsx --replay-ops $tmp.fsxops $victim > $tmp.output 2>&1 || cat $tmp.output + +echo "Silence is golden" +status=0 +exit diff --git a/tests/generic/511.out b/tests/generic/511.out new file mode 100644 index 00000000..cb0ea9e1 --- /dev/null +++ b/tests/generic/511.out @@ -0,0 +1,2 @@ +QA output created by 511 +Silence is golden diff --git a/tests/generic/group b/tests/generic/group index 635503d3..348214ac 100644 --- a/tests/generic/group +++ b/tests/generic/group @@ -513,3 +513,4 @@ 508 shutdown auto quick metadata 509 auto quick log 510 auto quick log +511 auto quick rw zero -- 2.39.5