From: Dave Chinner Date: Tue, 26 May 2015 02:51:53 +0000 (+1000) Subject: generic/223, xfs/203: IO is not well aligned X-Git-Tag: v2022.05.01~2878 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=6bd4b513af0478fb5f44b535ceea12a5b3b94165;p=users%2Fhch%2Fxfstests-dev.git generic/223, xfs/203: IO is not well aligned On certain configurations (e.g. MOUNT_OPTIONS="-o dax") we get different allocation patterns due to the writes being done in multiple pwrite() calls. e.g. the write is 8k, but the buffer size is 4k, and so the filesystem sees 4k writes. If the filesytem is not using delayed allocation, then the allocation context is a 4k write rather than an 8k write and so they don't get appropriately aligned. Fix this by making the write buffer the same size and the writes being done. Signed-off-by: Dave Chinner Reviewed-by: Brian Foster Signed-off-by: Dave Chinner --- diff --git a/tests/generic/223 b/tests/generic/223 index a67b8d584..f150dc935 100755 --- a/tests/generic/223 +++ b/tests/generic/223 @@ -69,7 +69,7 @@ for SUNIT_K in 8 16 32 64 128; do $XFS_IO_PROG -f -c "falloc 0 $SIZE" \ $SCRATCH_MNT/file-$FILE-$SIZE-falloc \ >> $seqres.full 2>&1 - $XFS_IO_PROG -f -c "pwrite 0 $SIZE" \ + $XFS_IO_PROG -f -c "pwrite -b $SIZE 0 $SIZE" \ $SCRATCH_MNT/file-$FILE-$SIZE-write \ >> $seqres.full 2>&1 src/t_stripealign $SCRATCH_MNT/file-$FILE-$SIZE-falloc \ diff --git a/tests/xfs/203 b/tests/xfs/203 index 7e18ca3c1..2ac529031 100755 --- a/tests/xfs/203 +++ b/tests/xfs/203 @@ -38,11 +38,11 @@ _write_holes() let fsize=$(($writes * 0x100000)) # prevent EOF preallocation from affecting results - xfs_io -f $file -c "truncate $fsize" + $XFS_IO_PROG -f $file -c "truncate $fsize" offset=0 for i in `seq 0 $writes`; do - xfs_io -f $file -c "pwrite -q $offset 64k" + $XFS_IO_PROG -f $file -c "pwrite -b 64k -q $offset 64k" let offset=$offset+0x100000 done }