]> git.apps.os.sepia.ceph.com Git - xfstests-dev.git/commitdiff
generic: test two vfsmount no peers
authorZorro Lang <zlang@redhat.com>
Tue, 14 Feb 2017 00:55:45 +0000 (19:55 -0500)
committerEryu Guan <eguan@redhat.com>
Wed, 15 Feb 2017 09:55:57 +0000 (17:55 +0800)
This test cover linux commit 7ae8fd0, when mnt_group_id=0, it means
this mount no peers. But this bug treat two zero mnt_group_id as
peers. And it cause a crash by dereference a NULL address.

As below, the crash will happen when mount fs on "B/mnt1/mnt2":

           shared            New FS           shared
     -----------------------[A/mnt1]----------------------
    |                           |                         |
    |                bind       |    bind                 |
[C/mnt1]--[slave C]<------[shared A]------>[slave B]--[B/mnt1]
                                                          |
                                                          |
                                                    [B/mnt1/mnt2]
                                                       (New FS)

Signed-off-by: Zorro Lang <zlang@redhat.com>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Reviewed-by: Eryu Guan <eguan@redhat.com>
Signed-off-by: Eryu Guan <eguan@redhat.com>
tests/generic/411 [new file with mode: 0755]
tests/generic/411.out [new file with mode: 0644]
tests/generic/group

diff --git a/tests/generic/411 b/tests/generic/411
new file mode 100755 (executable)
index 0000000..414d3a5
--- /dev/null
@@ -0,0 +1,147 @@
+#! /bin/bash
+# FS QA Test 411
+#
+# This test cover linux commit 7ae8fd0, kernel two mnt_group_id == 0
+# (no peer)vfsmount as peers. It case kernel dereference a NULL
+# address.
+#
+#-----------------------------------------------------------------------
+# Copyright (c) 2016 Red Hat Inc.  All Rights Reserved.
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License as
+# published by the Free Software Foundation.
+#
+# This program is distributed in the hope that it would be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write the Free Software Foundation,
+# Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+#-----------------------------------------------------------------------
+#
+
+seq=`basename $0`
+seqres=$RESULT_DIR/$seq
+echo "QA output created by $seq"
+
+here=`pwd`
+tmp=/tmp/$$
+status=1       # failure is the default!
+trap "_cleanup; exit \$status" 0 1 2 3 15
+
+_cleanup()
+{
+       cd /
+       rm -f $tmp.*
+       _clear_mount_stack
+}
+
+# get standard environment, filters and checks
+. ./common/rc
+. ./common/filter
+
+# remove previous $seqres.full before test
+rm -f $seqres.full
+
+# real QA test starts here
+_supported_fs generic
+_supported_os Linux
+_require_test
+_require_scratch
+_require_block_device $SCRATCH_DEV
+
+fs_stress()
+{
+       local target=$1
+
+       $FSSTRESS_PROG -z -n 500 -p 5 \
+                      -f creat=5 \
+                      -f mkdir=5 \
+                      -f dwrite=1 \
+                      -f dread=1 \
+                      -f link=2 \
+                      -f rename=1 \
+                      -f rmdir=2 \
+                      -f unlink=1 \
+                      -f symlink=1 \
+                      -f write=1 \
+                      -f read=1 \
+                      -f chown=1 \
+                      -f getdents=1 \
+                      -f fiemap=1 \
+                      -d $target >/dev/null
+       sync
+}
+
+# prepare some mountpoint dir
+MNTHEAD=$TEST_DIR/$seq
+mkdir $MNTHEAD 2>>$seqres.full
+mpA=$MNTHEAD/"$$"_mpA
+mpB=$MNTHEAD/"$$"_mpB
+mpC=$MNTHEAD/"$$"_mpC
+
+find_mnt()
+{
+       echo "------"
+       findmnt -n -o TARGET,SOURCE $SCRATCH_DEV | \
+               sed -e "s;$mpA;mpA;g" \
+                   -e "s;$mpB;mpB;g" \
+                   -e "s;$mpC;mpC;g" | \
+               _filter_spaces | _filter_scratch | \
+               _filter_test_dir | sort
+       echo "======"
+}
+
+start_test()
+{
+       local type=$1
+
+       _scratch_mkfs >$seqres.full 2>&1
+       _get_mount $SCRATCH_DEV $MNTHEAD
+       $MOUNT_PROG --make-"${type}" $MNTHEAD
+       mkdir $mpA $mpB $mpC
+}
+
+end_test()
+{
+       _clear_mount_stack
+       rm -rf $mpA $mpB $mpC
+}
+
+#
+#            shared            New FS           shared
+#      -----------------------[A/mnt1]----------------------
+#     |                           |                         |
+#     |                bind       |    bind                 |       New FS
+# [C/mnt1]--[slave C]<------[shared A]------>[slave B]--[B/mnt1]--[B/mnt1/mnt2]
+#
+crash_test()
+{
+       start_test shared
+
+       _get_mount $SCRATCH_DEV $mpA
+       mkdir $mpA/mnt1
+       $MOUNT_PROG --make-shared $mpA
+       _get_mount --bind $mpA $mpB
+       _get_mount --bind $mpA $mpC
+       $MOUNT_PROG --make-slave $mpB
+       $MOUNT_PROG --make-slave $mpC
+       _get_mount $SCRATCH_DEV $mpA/mnt1
+       mkdir $mpA/mnt1/mnt2
+
+       _get_mount $SCRATCH_DEV $mpB/mnt1/mnt2
+       find_mnt
+       fs_stress $mpB/mnt1/mnt2
+
+       end_test
+       echo "crash test passed"
+}
+
+crash_test
+
+# success, all done
+status=0
+exit
diff --git a/tests/generic/411.out b/tests/generic/411.out
new file mode 100644 (file)
index 0000000..16dadaf
--- /dev/null
@@ -0,0 +1,12 @@
+QA output created by 411
+------
+TEST_DIR/411 SCRATCH_DEV
+mpA SCRATCH_DEV
+mpA/mnt1 SCRATCH_DEV
+mpB SCRATCH_DEV
+mpB/mnt1 SCRATCH_DEV
+mpB/mnt1/mnt2 SCRATCH_DEV
+mpC SCRATCH_DEV
+mpC/mnt1 SCRATCH_DEV
+======
+crash test passed
index 0f9e3b3553901468251ca02b1538dab87d7d2369..fcb4b0624fb45a50abfc792009483d667cd10f3f 100644 (file)
 408 auto quick clone dedupe metadata
 409 auto quick mount
 410 auto quick mount
+411 auto quick mount