From owner-svn-src-user@freebsd.org Tue Sep 1 20:49:39 2015 Return-Path: Delivered-To: svn-src-user@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 77ACE9C8E51 for ; Tue, 1 Sep 2015 20:49:39 +0000 (UTC) (envelope-from pho@FreeBSD.org) Received: from repo.freebsd.org (repo.freebsd.org [IPv6:2001:1900:2254:2068::e6a:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 4FCFDEBD; Tue, 1 Sep 2015 20:49:39 +0000 (UTC) (envelope-from pho@FreeBSD.org) Received: from repo.freebsd.org ([127.0.1.70]) by repo.freebsd.org (8.15.2/8.15.2) with ESMTP id t81Kndgu095668; Tue, 1 Sep 2015 20:49:39 GMT (envelope-from pho@FreeBSD.org) Received: (from pho@localhost) by repo.freebsd.org (8.15.2/8.15.2/Submit) id t81Kndq8095667; Tue, 1 Sep 2015 20:49:39 GMT (envelope-from pho@FreeBSD.org) Message-Id: <201509012049.t81Kndq8095667@repo.freebsd.org> X-Authentication-Warning: repo.freebsd.org: pho set sender to pho@FreeBSD.org using -f From: Peter Holm Date: Tue, 1 Sep 2015 20:49:39 +0000 (UTC) To: src-committers@freebsd.org, svn-src-user@freebsd.org Subject: svn commit: r287377 - user/pho/stress2/misc X-SVN-Group: user MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-user@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: "SVN commit messages for the experimental " user" src tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 01 Sep 2015 20:49:39 -0000 Author: pho Date: Tue Sep 1 20:49:38 2015 New Revision: 287377 URL: https://svnweb.freebsd.org/changeset/base/287377 Log: Regression test added. Sponsored by: EMC / Isilon storage division Added: user/pho/stress2/misc/trim6.sh (contents, props changed) Added: user/pho/stress2/misc/trim6.sh ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ user/pho/stress2/misc/trim6.sh Tue Sep 1 20:49:38 2015 (r287377) @@ -0,0 +1,56 @@ +#!/bin/sh + +# +# Copyright (c) 2015 EMC Corp. +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions +# are met: +# 1. Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# 2. Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in the +# documentation and/or other materials provided with the distribution. +# +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND +# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE +# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS +# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) +# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY +# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF +# SUCH DAMAGE. +# +# $FreeBSD$ +# + +# Test scenario for exhausting limited malloc KVA on 32bit machine, by +# extending a file on a UFS SU volume. + +# Create a large file on a file system with trim enabled. +# Watchdog timeout seen: +# https://people.freebsd.org/~pho/stress/log/trim6.txt +# Fixed by r287361. + +[ `id -u ` -ne 0 ] && echo "Must be root!" && exit 1 + +r=`mount | grep -w soft-updates | awk '{print $1}' | while read dev; do + dumpfs $dev | head -20 | grep -qw trim || continue + df -k $dev +done | sort -rn +3 | head -1 | awk '{print $4, $6}'` +[ -z "$r" ] && exit # No trim enabled file systems found +set $r +free=$(($1 / 1024 / 10 * 9)) # in Mb +max=$((128 * 1024)) # Max is 128 GB +[ $free -gt $max ] && free=$max +mp=$2 +image=`echo $mp/diskimage | sed s#//#/#` # fix "//" for case mp = "/" +trap "rm -f $image" EXIT SIGINT + +echo "dd if=/dev/zero of=$image bs=1m count=$free" +dd if=/dev/zero of=$image bs=1m count=$free 2>&1 | + egrep -v 'records|transferred'