blob: e4195d9bd4bf52aebc2cb35f8c1e1032bb454e57 (
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2015 Oracle, Inc. All Rights Reserved.
#
# FS QA Test No. 117
#
# Create and populate an XFS filesystem, corrupt an inode, then see how
# the kernel and xfs_repair deal with it.
#
. ./common/preamble
_begin_fstest fuzzers
# Override the default cleanup function.
_cleanup()
{
cd /
#rm -f $tmp.*
}
# Import common functions.
. ./common/filter
. ./common/attr
. ./common/populate
# real QA test starts here
_supported_fs xfs
_require_scratch
test -n "${FORCE_FUZZ}" || _require_scratch_xfs_crc
_require_attrs
_require_populate_commands
_require_xfs_db_blocktrash_z_command
test -z "${FUZZ_ARGS}" && FUZZ_ARGS="-n 8 -3"
victimdir="${SCRATCH_MNT}/scratchdir"
echo "+ create scratch fs"
_scratch_mkfs_xfs > /dev/null
echo "+ mount fs image"
_scratch_mount
blksz="$(stat -f -c '%s' "${SCRATCH_MNT}")"
echo "+ make some files"
mkdir -p "$victimdir"
rootdir="$(stat -c '%i' "$SCRATCH_MNT")"
rootchunk=$(( rootdir / 64 ))
# First we create some dummy file so that the victim files don't get created
# in the same inode chunk as the root directory, because a corrupt inode in
# the root chunk causes mount to fail.
for ((i = 0; i < 256; i++)); do
fname="$SCRATCH_MNT/dummy.$i"
touch "$fname"
ino="$(stat -c '%i' "$fname")"
ichunk=$(( ino / 64 ))
test "$ichunk" -gt "$rootchunk" && break
done
# Now create some victim files
inos=()
for ((i = 0; i < 64; i++)); do
fname="$victimdir/test.$i"
touch "$fname"
inos+=("$(stat -c '%i' "$fname")")
done
echo "First victim inode is: " >> $seqres.full
stat -c '%i' "$fname" >> $seqres.full
umount "${SCRATCH_MNT}"
echo "+ check fs"
_scratch_xfs_repair -n >> $seqres.full 2>&1 || _fail "xfs_repair should not fail"
echo "+ corrupt image"
for ino in "${inos[@]}"; do
_scratch_xfs_db -x -c "inode ${ino}" -c "stack" -c "blocktrash -x 32 -y $((blksz * 8)) -z ${FUZZ_ARGS}" >> $seqres.full 2>&1
done
echo "+ mount image && modify files"
broken=1
if _try_scratch_mount >> $seqres.full 2>&1; then
for ((i = 0; i < 64; i++)); do
fname="$victimdir/test.$i"
stat "$fname" &>> $seqres.full
test $? -eq 0 && broken=0
touch "$fname" &>> $seqres.full
test $? -eq 0 && broken=0
done
umount "${SCRATCH_MNT}"
fi
echo "broken: ${broken}"
echo "+ repair fs"
_repair_scratch_fs >> $seqres.full 2>&1
echo "+ mount image (2)"
_scratch_mount
echo "+ chattr -R -i"
$CHATTR_PROG -R -f -i "${SCRATCH_MNT}/"
echo "+ modify files (2)"
broken=0
for x in `seq 1 64`; do
test -e "${TESTFILE}.${x}" || continue
echo "test ${x}" >> $seqres.full
stat "${TESTFILE}.${x}" >> $seqres.full 2>&1
test $? -ne 0 && broken=1
touch "${TESTFILE}.${x}" >> $seqres.full 2>&1
test $? -ne 0 && broken=1
echo "${x}: broken=${broken}" >> $seqres.full
done
echo "broken: ${broken}"
umount "${SCRATCH_MNT}"
echo "+ check fs (2)"
_scratch_xfs_repair -n >> $seqres.full 2>&1 || _fail "xfs_repair should not fail"
status=0
exit
|