]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - tools/test/stress2/misc/newfs4.sh
contrib/bc: update to version 5.1.1
[FreeBSD/FreeBSD.git] / tools / test / stress2 / misc / newfs4.sh
1 #!/bin/sh
2
3 #
4 # Copyright (c) 2008-2013 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 . ../default.cfg
32
33 # Deadlock problems. Test scenario by Lev Serebryakov <lev@freebsd.org>
34 # newfs -O2 -U -b 65536
35 # The io programs will get stuck in nbufkv wait state.
36
37 # Threads stuck in newbuf:
38 # https://people.freebsd.org/~pho/stress/log/newfs4-2.txt
39
40 odir=`pwd`
41 cd /tmp
42 sed '1,/^EOF/d' < $odir/$0 > newfs4.c
43 mycc -o newfs4 -Wall -Wextra newfs4.c || exit 1
44 rm -f newfs4.c
45 cd $odir
46
47 mount | grep "$mntpoint" | grep -q md${mdstart}$part && umount $mntpoint
48 mdconfig -l | grep md$mdstart > /dev/null &&  mdconfig -d -u $mdstart
49
50 size=9  # Gb
51 [ `df -k $(dirname $diskimage) | tail -1 | \
52     awk '{print $4}'` -lt $((size * 1024 * 1024)) ] && \
53     echo "Not enough disk space on `dirname $diskimage`." && exit 1
54 trap "rm -f $diskimage" EXIT INT
55 dd if=/dev/zero of=$diskimage bs=1m count=$((size * 1024)) status=none ||
56         exit 1
57
58 blocksize="-b 65536"
59 opt="-O2 -U"
60 mdconfig -a -t vnode -f $diskimage -u $mdstart
61 bsdlabel -w md$mdstart auto
62 newfs $blocksize $opt md${mdstart}$part > /dev/null
63 mount /dev/md${mdstart}$part $mntpoint
64
65 cd $mntpoint
66 truncate -s 2g f1
67 truncate -s 2g f2
68 truncate -s 2g f3
69 truncate -s 2g f4
70 /tmp/newfs4 f1 &
71 /tmp/newfs4 f2 &
72 /tmp/newfs4 f3 &
73 /tmp/newfs4 f4 &
74 wait
75
76 while mount | grep "$mntpoint" | grep -q md${mdstart}$part; do
77         umount -f $mntpoint || sleep 1
78 done
79 checkfs /dev/md${mdstart}$part; s=$?
80
81 mdconfig -d -u $mdstart
82 rm -f /tmp/newfs4
83 exit $s
84
85 EOF
86 #include <sys/types.h>
87 #include <sys/stat.h>
88
89 #include <err.h>
90 #include <fcntl.h>
91 #include <stdio.h>
92 #include <stdlib.h>
93 #include <unistd.h>
94
95 /* Perform random IO operations on a file */
96
97 int
98 main(int argc, char **argv)
99 {
100         struct stat sb;
101         off_t bp, maxb;
102         long i;
103         int fd;
104         char buf[256];
105
106         if (argc != 2) {
107                 fprintf(stderr, "Usage %s: file\n", argv[0]);
108                 return (1);
109         }
110         if ((fd = open(argv[1], O_RDWR)) == -1)
111                 err(1, "open(%s)", argv[1]);
112         if (fstat(fd, &sb) == -1)
113                 err(1, "fstatf(stdin)");
114         maxb = sb.st_size - sizeof(buf);
115
116         for (i = 0; i < 10000; i++) {
117                 bp = arc4random();
118                 bp = (bp << 31 | arc4random()) % maxb;
119
120                 if (lseek(fd, bp, 0) == -1)
121                         err(1, "lseek()");
122                 if (write(fd, buf, sizeof(buf)) != sizeof(buf))
123                         err(1, "write()");
124         }
125         close(fd);
126
127         return (0);
128 }