xref: /freebsd/tools/test/stress2/misc/msdos4.sh (revision 61e21613)
1#!/bin/sh
2
3#
4# Copyright (c) 2010 Peter Holm <pho@FreeBSD.org>
5# All rights reserved.
6#
7# Redistribution and use in source and binary forms, with or without
8# modification, are permitted provided that the following conditions
9# are met:
10# 1. Redistributions of source code must retain the above copyright
11#    notice, this list of conditions and the following disclaimer.
12# 2. Redistributions in binary form must reproduce the above copyright
13#    notice, this list of conditions and the following disclaimer in the
14#    documentation and/or other materials provided with the distribution.
15#
16# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19# ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26# SUCH DAMAGE.
27#
28
29[ `id -u` -ne 0 ] && echo "Must be root!" && exit 1
30
31# "panic: leaf should be empty" seen
32
33# "panic: Assertion sq->sq_wchan != NULL" seen:
34# https://people.freebsd.org/~pho/stress/log/msdos4.txt
35
36. ../default.cfg
37
38[ -x /sbin/mount_msdosfs ] || exit
39log=/tmp/msdos4.sh.log
40mount | grep "$mntpoint" | grep -q md$mdstart && umount -f $mntpoint
41mdconfig -l | grep -q $mdstart &&  mdconfig -d -u $mdstart
42
43mdconfig -a -t swap -s 1g -u $mdstart
44gpart create -s bsd md$mdstart > /dev/null
45gpart add -t freebsd-ufs md$mdstart > /dev/null
46part=a
47newfs_msdos /dev/md${mdstart}$part > /dev/null
48mount -t msdosfs /dev/md${mdstart}$part $mntpoint || exit 1
49
50export RUNDIR=$mntpoint/stressX
51export runRUNTIME=10m
52export TESTPROGS='
53testcases/lockf2/lockf2
54testcases/openat/openat
55testcases/rw/rw
56testcases/fts/fts
57testcases/lockf/lockf
58testcases/creat/creat
59testcases/mkdir/mkdir
60testcases/rename/rename
61testcases/swap/swap
62'
63
64(cd ..; ./testcases/run/run $TESTPROGS)
65
66while mount | grep "$mntpoint" | grep -q md$mdstart; do
67	umount $mntpoint || sleep 1
68done
69fsck -t msdosfs -y /dev/md${mdstart}$part > $log 2>&1
70s=0
71if egrep -q "BAD|INCONSISTENCY|MODIFIED" $log; then
72	cat $log
73	rm $log
74	s=1
75fi
76mdconfig -d -u $mdstart
77s=0	# Ignore for now
78exit $s
79