xref: /freebsd/tools/test/stress2/misc/suj16.sh (revision 774bb1c256fbc58a7e8d0d1f7d6427007105b334)
1#!/bin/sh
2
3#
4# Copyright (c) 2011 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# mksnap_ffs(8) test scenario
30
31# Livelock seen in ffs_sync().
32# "panic: initiate_write_bmsafemap: block 846816 marked free" seen.
33# Zero size snapshot file seen.
34
35[ `id -u ` -ne 0 ] && echo "Must be root!" && exit 1
36
37. ../default.cfg
38
39mount | grep $mntpoint | grep -q /dev/md && umount -f $mntpoint
40mdconfig -l | grep -q md$mdstart &&  mdconfig -d -u $mdstart
41
42mdconfig -a -t swap -s 2g -u $mdstart || exit 1
43bsdlabel -w md$mdstart auto
44
45newfs -j md${mdstart}$part > /dev/null 2>&1
46
47mount /dev/md${mdstart}$part $mntpoint
48chmod 777 $mntpoint
49
50export runRUNTIME=30m
51export RUNDIR=$mntpoint/stressX
52export creatINCARNATIONS=2
53
54export TESTPROGS="
55testcases/creat/creat
56"
57su $testuser -c 'cd ..; ./testcases/run/run $TESTPROGS' > /dev/null 2>&1 &
58rpid=$!
59mdstart2=$((mdstart + 1))
60mntpoint2=${mntpoint}2
61[ -d $mntpoint2 ] || mkdir $mntpoint2
62mount | grep $mntpoint2 | grep -q /dev/md && umount -f $mntpoint2
63mdconfig -l | grep -q md$mdstart2 &&  mdconfig -d -u $mdstart2
64while kill -0 $rpid 2> /dev/null; do
65	rm -f $mntpoint/.snap/suj16
66	{ mksnap_ffs $mntpoint $mntpoint/.snap/suj16 || continue; } 2>&1 | \
67		grep -v "Resource temporarily unavailable"
68	[ ! -s $mntpoint/.snap/suj16 ] && continue
69	mdconfig -a -t vnode -f $mntpoint/.snap/suj16 -u $mdstart2 -o readonly
70	mount -r /dev/md$mdstart2 $mntpoint2
71
72	ls -l $mntpoint2 > /dev/null
73
74	umount $mntpoint2
75	mdconfig -d -u $mdstart2
76done
77wait
78
79while mount | grep $mntpoint | grep -q /dev/md; do
80	umount $mntpoint || sleep 1
81done
82mdconfig -d -u $mdstart
83