18a272653SPeter Holm#!/bin/sh 28a272653SPeter Holm 38a272653SPeter Holm# 48a272653SPeter Holm# Copyright (c) 2014 EMC Corp. 58a272653SPeter Holm# All rights reserved. 68a272653SPeter Holm# 78a272653SPeter Holm# Redistribution and use in source and binary forms, with or without 88a272653SPeter Holm# modification, are permitted provided that the following conditions 98a272653SPeter Holm# are met: 108a272653SPeter Holm# 1. Redistributions of source code must retain the above copyright 118a272653SPeter Holm# notice, this list of conditions and the following disclaimer. 128a272653SPeter Holm# 2. Redistributions in binary form must reproduce the above copyright 138a272653SPeter Holm# notice, this list of conditions and the following disclaimer in the 148a272653SPeter Holm# documentation and/or other materials provided with the distribution. 158a272653SPeter Holm# 168a272653SPeter Holm# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 178a272653SPeter Holm# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 188a272653SPeter Holm# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 198a272653SPeter Holm# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 208a272653SPeter Holm# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 218a272653SPeter Holm# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 228a272653SPeter Holm# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 238a272653SPeter Holm# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 248a272653SPeter Holm# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 258a272653SPeter Holm# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 268a272653SPeter Holm# SUCH DAMAGE. 278a272653SPeter Holm# 288a272653SPeter Holm 298a272653SPeter Holm# Variation of crossmp3.sh 308a272653SPeter Holm 318a272653SPeter Holm[ `id -u ` -ne 0 ] && echo "Must be root!" && exit 1 328a272653SPeter Holm 338a272653SPeter Holm. ../default.cfg 348a272653SPeter Holm 358a272653SPeter HolmN=`sysctl -n hw.ncpu` 36*c7bc30c2SPeter Holm[ $N -gt 32 ] && N=32 # Arbitrary cap 378a272653SPeter Holmusermem=`sysctl -n hw.usermem` 388a272653SPeter Holm[ `swapinfo | wc -l` -eq 1 ] && usermem=$((usermem/100*80)) 398a272653SPeter Holmsize=$((usermem / 1024 / 1024 / N)) 408a272653SPeter Holm 418a272653SPeter Holmmounts=$N # Number of parallel scripts 428a272653SPeter Holm 438a272653SPeter Holmif [ $# -eq 0 ]; then 448a272653SPeter Holm for i in `jot $mounts`; do 458a272653SPeter Holm m=$(( i + mdstart - 1 )) 468a272653SPeter Holm [ ! -d ${mntpoint}$m ] && mkdir ${mntpoint}$m 478a272653SPeter Holm mount | grep "${mntpoint}$m " | grep -q md$m && 488a272653SPeter Holm umount ${mntpoint}$m 498a272653SPeter Holm mdconfig -l | grep -q md$m && mdconfig -d -u $m 508a272653SPeter Holm 518a272653SPeter Holm mdconfig -a -t swap -s ${size}m -u $m 52608c97bfSPeter Holm newfs $newfs_flags md${m} > /dev/null 2>&1 538a272653SPeter Holm done 548a272653SPeter Holm 558a272653SPeter Holm # start the parallel tests 568a272653SPeter Holm for i in `jot $mounts`; do 578a272653SPeter Holm m=$(( i + mdstart - 1 )) 588a272653SPeter Holm ./$0 $m & 598a272653SPeter Holm ./$0 find & 608a272653SPeter Holm done 618a272653SPeter Holm 628a272653SPeter Holm wait 638a272653SPeter Holm 648a272653SPeter Holm for i in `jot $mounts`; do 658a272653SPeter Holm m=$(( i + mdstart - 1 )) 668a272653SPeter Holm mdconfig -d -u $m 678a272653SPeter Holm rm -f $D$m 688a272653SPeter Holm done 698a272653SPeter Holm exit 0 708a272653SPeter Holmelse 718a272653SPeter Holm touch /tmp/crossmp.continue 728a272653SPeter Holm if [ $1 = find ]; then 738a272653SPeter Holm while [ -f /tmp/crossmp.continue ]; do 748a272653SPeter Holm find ${mntpoint}* -type f > /dev/null 2>&1 758a272653SPeter Holm done 768a272653SPeter Holm else 778a272653SPeter Holm # The test: Parallel mount and unmount 78005dd61dSPeter Holm i=0 798a272653SPeter Holm m=$1 80005dd61dSPeter Holm start=`date +%s` 81005dd61dSPeter Holm while [ $((`date +%s`- start)) -lt 300 ]; do 82608c97bfSPeter Holm mount /dev/md${m} ${mntpoint}$m 838a272653SPeter Holm chmod 777 ${mntpoint}$m 848a272653SPeter Holm l=`jot -r 1 65535` 858a272653SPeter Holm dd if=/dev/zero of=$mntpoint/$i bs=$l count=100 \ 868a272653SPeter Holm status=none 878a272653SPeter Holm rm -f $mntpoint/$i 888a272653SPeter Holm 898a272653SPeter Holm while mount | grep -q "on ${mntpoint}$m "; do 908a272653SPeter Holm opt=$([ $((`date '+%s'` % 2)) -eq 0 ] && 918a272653SPeter Holm echo "-f") 928a272653SPeter Holm umount $opt ${mntpoint}$m > /dev/null 2>&1 938a272653SPeter Holm done 94005dd61dSPeter Holm i=$((i + 1)) 958a272653SPeter Holm done 968a272653SPeter Holm rm -f /tmp/crossmp.continue 978a272653SPeter Holm fi 988a272653SPeter Holmfi 99