|
|
| File: [Development] / xfs-cmds / xfstests / 135 (download)
Revision 1.2, Mon Oct 16 15:46:05 2006 UTC (11 years ago) by ddiss.longdrop.melbourne.sgi.com
run test on scratch dir remove failure case for when scratch is not mounted before test Merge of master-melb:xfs-cmds:27201a by kenmcd. |
#! /bin/sh
# FSQA Test No. 133
#
# Concurrent I/O to same file to ensure no deadlocks
#
#-----------------------------------------------------------------------
# Copyright (c) 2006 Silicon Graphics, Inc. All Rights Reserved.
#-----------------------------------------------------------------------
#
# creator
owner=lachlan@sgi.com
seq=`basename $0`
echo "QA output created by $seq"
here=`pwd`
tmp=/tmp/$$
status=1 # failure is the default!
trap "_cleanup; exit \$status" 0 1 2 3 15
_cleanup()
{
_cleanup_testdir
}
# get standard environment, filters and checks
. ./common.rc
. ./common.filter
# real QA test starts here
_supported_fs xfs
_supported_os Linux IRIX
_setup_testdir
_require_scratch
_scratch_mkfs_xfs >/dev/null 2>&1
_umount_mount()
{
CWD=`pwd`
cd /
# pipe error into /dev/null, in case not mounted (after _require_scratch)
umount $SCRATCH_MNT 2>/dev/null
_scratch_mount
cd "$CWD"
}
_umount_mount
cd $SCRATCH_MNT
# create file with async I/O
xfs_io -f -c 'pwrite -b 4k -S 0x12 0 4k' async_file > /dev/null
# create file with sync I/O
xfs_io -f -s -c 'pwrite -b 4k -S 0x34 0 4k' sync_file > /dev/null
# create file with sync I/O
xfs_io -f -d -c 'pwrite -b 4k -S 0x56 0 4k' direct_file > /dev/null
_umount_mount
# check file size and contents
od -Ad -x async_file
od -Ad -x sync_file
od -Ad -x direct_file
rm -f async_file sync_file direct_file
status=0
exit