2010-01-20 10:27:08 +11:00
|
|
|
#! /bin/bash
|
2018-06-09 11:35:45 +10:00
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
|
# Copyright (c) 2000-2002 Silicon Graphics, Inc. All Rights Reserved.
|
|
|
|
|
#
|
2009-05-28 17:04:15 +02:00
|
|
|
# FS QA Test No. 009
|
|
|
|
|
#
|
|
|
|
|
# XFS allocator test (preallocation - allocp, resvsp ,etc)
|
2001-01-15 05:01:19 +00:00
|
|
|
#
|
|
|
|
|
seq=`basename $0`
|
2013-03-15 12:28:02 +00:00
|
|
|
seqres=$RESULT_DIR/$seq
|
2001-01-15 05:01:19 +00:00
|
|
|
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()
|
|
|
|
|
{
|
|
|
|
|
echo "*** unmount"
|
2015-12-21 18:07:43 +11:00
|
|
|
_scratch_unmount
|
2001-01-15 05:01:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_init()
|
|
|
|
|
{
|
|
|
|
|
echo "*** mkfs"
|
2003-05-22 04:16:45 +00:00
|
|
|
if ! _scratch_mkfs_xfs >$tmp.out 2>&1
|
2001-01-15 05:01:19 +00:00
|
|
|
then
|
|
|
|
|
cat $tmp.out
|
|
|
|
|
echo "failed to mkfs $SCRATCH_DEV"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
echo "*** mount"
|
2018-02-07 17:31:36 +08:00
|
|
|
if ! _try_scratch_mount
|
2001-01-15 05:01:19 +00:00
|
|
|
then
|
|
|
|
|
echo "failed to mount $SCRATCH_DEV"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# get standard environment, filters and checks
|
2013-03-15 12:28:04 +00:00
|
|
|
. ./common/rc
|
|
|
|
|
. ./common/filter
|
2001-01-15 05:01:19 +00:00
|
|
|
|
|
|
|
|
# real QA test starts here
|
2004-06-15 07:32:36 +00:00
|
|
|
_supported_fs xfs
|
2001-01-15 05:01:19 +00:00
|
|
|
|
|
|
|
|
_require_scratch
|
2018-11-10 12:51:43 +01:00
|
|
|
_require_xfs_io_command "falloc"
|
2001-01-15 05:01:19 +00:00
|
|
|
|
2018-09-24 20:49:23 +05:30
|
|
|
_filesize()
|
|
|
|
|
{
|
|
|
|
|
ls -l $1 | $AWK_PROG -v bsize="$bsize" '{print "filesize = " $5 / bsize}'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_block_filter()
|
|
|
|
|
{
|
|
|
|
|
$AWK_PROG -v bsize="$bsize" '
|
|
|
|
|
/blocksize/ {
|
|
|
|
|
printf(" blocksize BSIZE\n")
|
|
|
|
|
|
|
|
|
|
next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/CMD/ {
|
|
|
|
|
split($3, off, "=")
|
2019-12-16 00:10:55 +08:00
|
|
|
offset = strtonum(off[2])
|
2018-09-24 20:49:23 +05:30
|
|
|
if (offset != -1)
|
|
|
|
|
offset = offset / bsize
|
|
|
|
|
|
|
|
|
|
split($4, len, "=")
|
2019-12-16 00:10:55 +08:00
|
|
|
nr_blocks = strtonum(len[2])
|
2018-09-24 20:49:23 +05:30
|
|
|
if (nr_blocks != -1)
|
|
|
|
|
nr_blocks = nr_blocks / bsize
|
|
|
|
|
|
|
|
|
|
printf(" %s %s off=%s, len=%d\n", $1, $2, offset, nr_blocks)
|
|
|
|
|
|
|
|
|
|
next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/MAP/ {
|
|
|
|
|
split($2, off, "=")
|
2019-12-16 00:10:55 +08:00
|
|
|
offset = strtonum(off[2])
|
2018-09-24 20:49:23 +05:30
|
|
|
if (offset != -1)
|
|
|
|
|
offset = offset / bsize
|
|
|
|
|
|
|
|
|
|
split($3, len, "=")
|
|
|
|
|
|
2019-12-16 00:10:55 +08:00
|
|
|
nr_blocks = strtonum(len[2])
|
2018-09-24 20:49:23 +05:30
|
|
|
|
|
|
|
|
if (nr_blocks != -1)
|
|
|
|
|
nr_blocks = nr_blocks / bsize
|
|
|
|
|
|
|
|
|
|
printf(" %s off=%s, len=%d %s\n", $1, offset, nr_blocks, $4)
|
|
|
|
|
|
|
|
|
|
next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/TRUNCATE/ {
|
|
|
|
|
split($2, off, "=")
|
2019-12-16 00:10:55 +08:00
|
|
|
offset = strtonum(off[2]) / bsize
|
2018-09-24 20:49:23 +05:30
|
|
|
|
|
|
|
|
printf(" %s off=%s\n", $1, offset)
|
|
|
|
|
|
|
|
|
|
next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/\[[0-9]+,[0-9]+\]:/ {
|
|
|
|
|
printf(" %s BLOCKRANGE\n", $1)
|
|
|
|
|
|
|
|
|
|
next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
print
|
|
|
|
|
|
|
|
|
|
next
|
|
|
|
|
}
|
|
|
|
|
'
|
|
|
|
|
}
|
|
|
|
|
|
2001-01-15 05:01:19 +00:00
|
|
|
_init
|
|
|
|
|
out=$SCRATCH_MNT/$$.tmp
|
|
|
|
|
|
2018-09-24 20:49:23 +05:30
|
|
|
# This isn't really related to fs block size, it's just what
|
|
|
|
|
# alloc uses for the "block" unit in it's input parameters...
|
|
|
|
|
# However, xfs_alloc_file_space() rounds up allocation
|
|
|
|
|
# request by the filesystem's block size.
|
|
|
|
|
bsize=$(_get_file_block_size $SCRATCH_MNT)
|
|
|
|
|
|
2001-01-15 05:01:19 +00:00
|
|
|
# since we're using a clean FS here, we make some assumptions
|
|
|
|
|
# about availability of contiguous blocks
|
|
|
|
|
|
|
|
|
|
# also interesting to note is that ALLOC == FREE. seriously.
|
|
|
|
|
# the _length is ignored_ in irix. the file is allocated up
|
|
|
|
|
# to the specified offset, and zero filled if previously
|
|
|
|
|
# unallocated. the file is truncated at the specified point.
|
|
|
|
|
|
|
|
|
|
echo "*** test 1 - reservations cleared on O_TRUNC"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
r 0 1000b
|
|
|
|
|
m
|
|
|
|
|
EOF
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out -t | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
m
|
|
|
|
|
EOF
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
|
|
|
|
echo "*** test 2 - reserve & filesize"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
r 0 1000b
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
|
|
|
|
echo "*** test 3 - alloc & filesize"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
a 1000b
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
|
|
|
|
echo "*** test 4 - allocations cleared on O_TRUNC"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
a 1000b
|
|
|
|
|
EOF
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out -t | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
m
|
|
|
|
|
EOF
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
|
|
|
|
echo "*** test 5 - reserve / unreserve"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
r 0 100b
|
|
|
|
|
u 100b 500b
|
|
|
|
|
m
|
|
|
|
|
u 900b 200b
|
|
|
|
|
m
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
echo "*** test 6 - reserve adjacent"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -t -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
r 0 100b
|
|
|
|
|
r 100b 100b
|
|
|
|
|
m
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
echo "*** test 7 - alloc"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
a 1000b
|
|
|
|
|
m
|
|
|
|
|
a 2000b
|
|
|
|
|
m
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
|
|
|
|
echo "*** test 8 - alloc & truncate"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
a 1000b
|
|
|
|
|
m
|
|
|
|
|
t 500b
|
|
|
|
|
m
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
|
|
|
|
echo "*** test 9 - reserve & truncate"
|
|
|
|
|
rm -f $out
|
2019-10-21 21:35:46 +08:00
|
|
|
cat <<EOF | $here/src/alloc -n -b $bsize -f $out | _block_filter
|
2001-01-15 05:01:19 +00:00
|
|
|
r 0 1000b
|
|
|
|
|
m
|
|
|
|
|
t 500b
|
|
|
|
|
m
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
_filesize $out
|
|
|
|
|
|
|
|
|
|
status=0
|
|
|
|
|
exit
|