summaryrefslogtreecommitdiff
path: root/tests/btrfs/132
blob: d0ac51e47126745616d7c74f373c2b01524671a8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2016 Fujitsu.  All Rights Reserved.
#
# FS QA Test 132
#
# Check if false ENOSPC will happen when parallel buffer write happens
# The problem is caused by incorrect metadata reservation for any buffered
# write whose max extent size is not 128M (including compression and in-band
# dedupe).
#
. ./common/preamble
_begin_fstest auto enospc

# Override the default cleanup function.
_cleanup()
{
	cd /
	rm -f $tmp.*
	kill $pids &> /dev/null
	wait
}

. ./common/filter

_supported_fs btrfs
_require_scratch

# Use small filesystem to trigger the bug more easily
# It's highly recommened to run this test case with MKFS_OPTIONS="-n 64k"
# to further increase the possibility
# Since the false ENOSPC happens due to incorrect metadata reservation,
# larger nodesize and small fs will make it much easier to reproduce
_scratch_mkfs_sized $((512 * 1024 * 1024)) >> $seqres.full 2>&1

# Recommended to use MOUNT_OPTIONS="-o compress" to trigger the bug
_scratch_mount

sleep_time=$(($TIME_FACTOR * 30))
loop_writer()
{
	offset=$1
	len=$2
	file=$3

	while true; do
		# Only need stderr, and we need to specify small block size
		# but still large enough trigger compression
		$XFS_IO_PROG -c "pwrite -b 8K $offset $len" $file > /dev/null
	done
}

touch $SCRATCH_MNT/testfile

# Start 2 writter writting into the same file
# The file is 142M, which is smaller than 1/2 of the filesystem,
# so no other cause can lead to ENOSPC.
loop_writer 0 128M $SCRATCH_MNT/testfile &
pids=$!
loop_writer 128M 16M $SCRATCH_MNT/testfile &
pids="$pids $!"

sleep $sleep_time

kill $pids
wait

# Wait all writers really exits
while pgrep -f "$SCRATCH_MNT" > /dev/null; do
	sleep 1
done

echo "Silence is golden"
status=0
exit