xref: /freebsd/tools/test/stress2/misc/altbufferflushes.sh (revision 8a272653d9fbd9fc37691c9aad6a05089b4ecb4d)
1*8a272653SPeter Holm#!/bin/sh
2*8a272653SPeter Holm
3*8a272653SPeter Holm#
4*8a272653SPeter Holm# Copyright (c) 2008 Peter Holm <pho@FreeBSD.org>
5*8a272653SPeter Holm# All rights reserved.
6*8a272653SPeter Holm#
7*8a272653SPeter Holm# Redistribution and use in source and binary forms, with or without
8*8a272653SPeter Holm# modification, are permitted provided that the following conditions
9*8a272653SPeter Holm# are met:
10*8a272653SPeter Holm# 1. Redistributions of source code must retain the above copyright
11*8a272653SPeter Holm#    notice, this list of conditions and the following disclaimer.
12*8a272653SPeter Holm# 2. Redistributions in binary form must reproduce the above copyright
13*8a272653SPeter Holm#    notice, this list of conditions and the following disclaimer in the
14*8a272653SPeter Holm#    documentation and/or other materials provided with the distribution.
15*8a272653SPeter Holm#
16*8a272653SPeter Holm# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17*8a272653SPeter Holm# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*8a272653SPeter Holm# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*8a272653SPeter Holm# ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20*8a272653SPeter Holm# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21*8a272653SPeter Holm# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22*8a272653SPeter Holm# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23*8a272653SPeter Holm# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24*8a272653SPeter Holm# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25*8a272653SPeter Holm# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26*8a272653SPeter Holm# SUCH DAMAGE.
27*8a272653SPeter Holm#
28*8a272653SPeter Holm
29*8a272653SPeter Holm# Regression test. This script caused this panic:
30*8a272653SPeter Holm
31*8a272653SPeter Holm# panic: lockmgr: locking against myself
32*8a272653SPeter Holm# cpuid = 2
33*8a272653SPeter Holm# KDB: enter: panic
34*8a272653SPeter Holm# [thread pid 2526 tid 100070 ]
35*8a272653SPeter Holm# Stopped at      kdb_enter+0x2b: nop
36*8a272653SPeter Holm# db> bt
37*8a272653SPeter Holm# Tracing pid 2526 tid 100070 td 0xc46f8360
38*8a272653SPeter Holm# kdb_enter(c094247f) at kdb_enter+0x2b
39*8a272653SPeter Holm# panic(c09402b6,c46f8360,0,12,c06af5d9,...) at panic+0x14b
40*8a272653SPeter Holm# _lockmgr(d864a748,202122,c479f788,c46f8360,c094b01c,12d) at _lockmgr+0x41a
41*8a272653SPeter Holm# getblk(c479f6b8,5d51940,0,4000,0,...) at getblk+0x13c
42*8a272653SPeter Holm# breadn(c479f6b8,5d51940,0,4000,0,...) at breadn+0x2f
43*8a272653SPeter Holm# bread(c479f6b8,5d51940,0,4000,0,e6d13544,c4743eac,0,c095a185,56d) at bread+0x20
44*8a272653SPeter Holm# ffs_alloccg(c47408c4,104,1754628,0,4000,c4743eac,1,c095a185,4d8) at ffs_alloccg+0x11d
45*8a272653SPeter Holm# ffs_hashalloc(c47408c4,104,1754628,0,4000,...) at ffs_hashalloc+0x45
46*8a272653SPeter Holm# ffs_alloc(c47408c4,3f2cd,0,1754628,0,4000,c42fd400,e6d13674) at ffs_alloc+0x1a5
47*8a272653SPeter Holm# ffs_balloc_ufs2(c4735d70,fcb34000,0,4000,c42fd400,...) at ffs_balloc_ufs2+0x1619
48*8a272653SPeter Holm# ffs_copyonwrite(c479f6b8,d84e3d08) at ffs_copyonwrite+0x3d3
49*8a272653SPeter Holm# ffs_geom_strategy(c479f7c0,d84e3d08) at ffs_geom_strategy+0xbd
50*8a272653SPeter Holm# bufwrite(d84e3d08,4000,d84e3d08,e6d137e4,c070b7a9,...) at bufwrite+0x17a
51*8a272653SPeter Holm# ffs_bufwrite(d84e3d08) at ffs_bufwrite+0x282
52*8a272653SPeter Holm# vfs_bio_awrite(d84e3d08) at vfs_bio_awrite+0x235
53*8a272653SPeter Holm# bdwrite(d864a6e8,c4743eac,0,c095a185,57c,...) at bdwrite+0x237
54*8a272653SPeter Holm# ffs_alloccg(c4b54a50,104,1754628,0,4000,c4743eac,1,c095a185,4d8) at ffs_alloccg+0x1f6
55*8a272653SPeter Holm# ffs_hashalloc(c4b54a50,104,1754628,0,4000,...) at ffs_hashalloc+0x45
56*8a272653SPeter Holm# ffs_alloc(c4b54a50,1b00c,0,1754628,0,4000,c4b22a80,e6d139ac) at ffs_alloc+0x1a5
57*8a272653SPeter Holm# ffs_balloc_ufs2(c4e72158,6c030000,0,4000,c4b22a80,...) at ffs_balloc_ufs2+0x1619
58*8a272653SPeter Holm# ffs_write(e6d13b98) at ffs_write+0x2ac
59*8a272653SPeter Holm# VOP_WRITE_APV(c0a00e80,e6d13b98) at VOP_WRITE_APV+0x132
60*8a272653SPeter Holm# vn_write(c46c65a0,e6d13c60,c4b22a80,0,c46f8360) at vn_write+0x1f6
61*8a272653SPeter Holm# dofilewrite(c46f8360,4,c46c65a0,e6d13c60,ffffffff,...) at dofilewrite+0x77
62*8a272653SPeter Holm# kern_writev(c46f8360,4,e6d13c60,8430000,d0000,...) at kern_writev+0x36
63*8a272653SPeter Holm# write(c46f8360,e6d13d00) at write+0x45
64*8a272653SPeter Holm# syscall(e6d13d38) at syscall+0x256
65*8a272653SPeter Holm
66*8a272653SPeter Holm[ `id -u ` -ne 0 ] && echo "Must be root!" && exit 1
67*8a272653SPeter Holm
68*8a272653SPeter Holmpersist () {
69*8a272653SPeter Holm	false
70*8a272653SPeter Holm	while [ $? -ne 0 ]; do
71*8a272653SPeter Holm		$1 > /dev/null 2>&1
72*8a272653SPeter Holm		sleep 1
73*8a272653SPeter Holm	done
74*8a272653SPeter Holm}
75*8a272653SPeter Holm
76*8a272653SPeter Holmdiskfree=`df -k /var/tmp | tail -1 | awk '{print $4}'`
77*8a272653SPeter Holm[ $((diskfree / 1024 / 1024)) -lt 5 ] && echo "Not enough disk space" && exit 1
78*8a272653SPeter Holm
79*8a272653SPeter Holmrm -f /var/.snap/stress2 /var/tmp/big.?
80*8a272653SPeter Holmtrap "rm -f /var/.snap/stress2 /var/tmp/big.?" EXIT INT
81*8a272653SPeter Holmpersist 'mksnap_ffs /var /var/.snap/stress2'
82*8a272653SPeter Holmtresh=`sysctl  vfs.dirtybufthresh | awk '{print $NF}'`
83*8a272653SPeter Holmsysctl vfs.dirtybufthresh=10
84*8a272653SPeter Holm
85*8a272653SPeter Holmcd /var/tmp
86*8a272653SPeter Holmfor j in `jot 5`; do
87*8a272653SPeter Holm	old=`sysctl  vfs.altbufferflushes | awk '{print $NF}'`
88*8a272653SPeter Holm	for i in `jot 4`; do
89*8a272653SPeter Holm		echo "`date '+%T'` Create big.$i"
90*8a272653SPeter Holm		dd if=/dev/zero of=big.$i bs=1m count=4k status=none
91*8a272653SPeter Holm	done
92*8a272653SPeter Holm	sleep 1
93*8a272653SPeter Holm	rm -rf /var/tmp/big.?
94*8a272653SPeter Holm	new=`sysctl  vfs.altbufferflushes | awk '{print $NF}'`
95*8a272653SPeter Holm	[ $new -ne $old ] && echo "vfs.altbufferflushes changed from $old to $new."
96*8a272653SPeter Holmdone
97*8a272653SPeter Holmsysctl vfs.dirtybufthresh=$tresh
98*8a272653SPeter Holmrm -f /var/.snap/stress2
99