Re: [xfstests PATCH] generic/567: add partial pages zeroing out case

[Date Prev] [Date Next] [Thread Prev] [Thread Next] [Date Index] [Thread Index]



On 2024/12/27 13:28, Nirjhar Roy wrote:
> On Mon, 2024-12-23 at 10:39 +0800, Zhang Yi wrote:
>> From: Zhang Yi <yi.zhang@xxxxxxxxxx>
>>
>> This addresses a data corruption issue encountered during partial
>> page
>> zeroing in ext4 which the block size is smaller than the page size
>> [1].
>> Expand this test to include a zeroing range test that spans two
>> partial
>> pages to cover this case.
>>
>> Link: 
>> https://lore.kernel.org/linux-ext4/20241220011637.1157197-2-yi.zhang@xxxxxxxxxxxxxxx/
>>  [1]
>> Signed-off-by: Zhang Yi <yi.zhang@xxxxxxxxxx>
>> ---
>>  tests/generic/567     | 50 +++++++++++++++++++++++++--------------
>> ----
>>  tests/generic/567.out | 18 ++++++++++++++++
>>  2 files changed, 47 insertions(+), 21 deletions(-)
>>
>> diff --git a/tests/generic/567 b/tests/generic/567
>> index fc109d0d..756280e8 100755
>> --- a/tests/generic/567
>> +++ b/tests/generic/567
>> @@ -4,43 +4,51 @@
>>  #
>>  # FS QA Test No. generic/567
>>  #
>> -# Test mapped writes against punch-hole to ensure we get the data
>> -# correctly written. This can expose data corruption bugs on
>> filesystems
>> -# where the block size is smaller than the page size.
>> +# Test mapped writes against punch-hole and zero-range to ensure we
>> get
>> +# the data correctly written. This can expose data corruption bugs
>> on
>> +# filesystems where the block size is smaller than the page size.
>>  #
>>  # (generic/029 is a similar test but for truncate.)
>>  #
>>  . ./common/preamble
>> -_begin_fstest auto quick rw punch
>> +_begin_fstest auto quick rw punch zero
>>  
>>  # Import common functions.
>>  . ./common/filter
>>  
>>  _require_scratch
>>  _require_xfs_io_command "fpunch"
>> +_require_xfs_io_command "fzero"
>>  
>>  testfile=$SCRATCH_MNT/testfile
>>  
>>  _scratch_mkfs > /dev/null 2>&1
> Since this test requires block size < page size, do you think it is a
> good idea to hard code the _scratch_mkfs parameters to explicitly pass
> the block size to < less than zero? This will require less manipulation
> with the local.config file. Or maybe have a _notrun to _notrun the test
> if the block size is not less than the page size?

Hi, Nirjhar. Thank you for the review!

Although the issue we encountered is on the configuration that block
size is less than page size, I believe it is also harmless to run this
test in an environment where the block size is equal to the page size.
This is a quick and basic test.

>>  _scratch_mount
>>  
>> -# Punch a hole straddling two pages to check that the mapped write
>> after the
>> -# hole-punching is correctly handled.
>> -
>> -$XFS_IO_PROG -t -f \
>> --c "pwrite -S 0x58 0 12288" \
>> --c "mmap -rw 0 12288" \
>> --c "mwrite -S 0x5a 2048 8192" \
>> --c "fpunch 2048 8192" \
>> --c "mwrite -S 0x59 2048 8192" \
>> --c "close" 
> Minor: isn't the close command redundant? xfs_io will in any case close
> the file right?

Yes, but this explicit close is from the original text and appears
harmless, so I'd suggest keeping it.

>>      \
>> -$testfile | _filter_xfs_io
>> -
>> -echo "==== Pre-Remount ==="
>> -_hexdump $testfile
>> -_scratch_cycle_mount
>> -echo "==== Post-Remount =="
>> -_hexdump $testfile
>> +# Punch a hole and zero out straddling two pages to check that the
>> mapped
>> +# write after the hole-punching and range-zeroing are correctly
>> handled.
>> +_straddling_test()
>> +{
>> +	local test_cmd=$1
>> +
>> +	$XFS_IO_PROG -t -f \
>> +		-c "pwrite -S 0x58 0 12288" \
>> +		-c "mmap -rw 0 12288" \
>> +		-c "mwrite -S 0x5a 2048 8192" \
>> +		-c "$test_cmd 2048 8192" \
>> +		-c "mwrite -S 0x59 2048 8192" \
>> +		-c "close"      \
>> +	$testfile | _filter_xfs_io
>> +
>> +	echo "==== Pre-Remount ==="
>> +	_hexdump $testfile
>> +	_scratch_cycle_mount
>> +	echo "==== Post-Remount =="
>> +	_hexdump $testfile
> Just guessing here: Do you think it is makes sense to test with both
> delayed and non-delayed allocation? I mean with and without "msync"?

Sorry, I don't understand why we need msync. The umount should flush
the dirty pages to the disk even without msync, I mean this this test
does not focus on the functionality of msync now.

>> +}
>> +
>> +_straddling_test "fpunch"
>> +_straddling_test "fzero"
> Minor: Since we are running 2 independant sub-tests, isn't it better to
> use 2 different files?
> 

Yes, Darrick had the same suggestion, and I have separated this into
generic/758 in my v2.

  https://lore.kernel.org/fstests/20241225125120.1952219-1-yi.zhang@xxxxxxxxxxxxxxx/

Thanks,
Yi.






[Index of Archives]     [Linux Filesystems Development]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux