37ff2bd92da74055b3405b776509d18faff74878
[xfstests-dev.git] / tests / xfs / 341
1 #! /bin/bash
2 # SPDX-License-Identifier: GPL-2.0
3 # Copyright (c) 2016, Oracle and/or its affiliates.  All Rights Reserved.
4 #
5 # FS QA Test No. 341
6 #
7 # Cross-link file block into rtrmapbt and see if repair fixes it.
8 #
9 seq=`basename "$0"`
10 seqres="$RESULT_DIR/$seq"
11 echo "QA output created by $seq"
12
13 here=`pwd`
14 tmp=/tmp/$$
15 status=1    # failure is the default!
16 trap "_cleanup; exit \$status" 0 1 2 3 15
17
18 _cleanup()
19 {
20         cd /
21         rm -rf "$tmp".*
22 }
23
24 # get standard environment, filters and checks
25 . ./common/rc
26 . ./common/filter
27
28 # real QA test starts here
29 _supported_fs xfs
30 _require_realtime
31 _require_xfs_scratch_rmapbt
32 _require_test_program "punch-alternating"
33 _disable_dmesg_check
34
35 rm -f "$seqres.full"
36
37 echo "Format and mount"
38 _scratch_mkfs | _filter_mkfs 2>$tmp.mkfs >/dev/null
39 . $tmp.mkfs
40 cat $tmp.mkfs > "$seqres.full" 2>&1
41 _scratch_mount
42 blksz="$(_get_block_size $SCRATCH_MNT)"
43
44 # inode core size is at least 176 bytes; btree header is 56 bytes;
45 # rtrmap record is 32 bytes; and rtrmap key/pointer are 56 bytes.
46 i_ptrs=$(( (isize - 176) / 56 ))
47 bt_recs=$(( (blksz - 56) / 32 ))
48
49 blocks=$((i_ptrs * bt_recs + 1))
50 len=$((blocks * rtextsz))
51
52 echo "Create some files"
53 $XFS_IO_PROG -f -R -c "falloc 0 $len" -c "pwrite -S 0x68 -b 1048576 0 $len" $SCRATCH_MNT/f1 >> $seqres.full
54 $XFS_IO_PROG -f -R -c "falloc 0 $len" -c "pwrite -S 0x68 -b 1048576 0 $len" $SCRATCH_MNT/f2 >> $seqres.full
55 $here/src/punch-alternating $SCRATCH_MNT/f1 >> "$seqres.full"
56 $here/src/punch-alternating $SCRATCH_MNT/f2 >> "$seqres.full"
57 echo garbage > $SCRATCH_MNT/f3
58 ino=$(stat -c '%i' $SCRATCH_MNT/f3)
59 _scratch_unmount
60
61 echo "Corrupt fs"
62 fsbno=$(_scratch_xfs_db -c "inode $ino" -c 'bmap' | \
63         sed -e 's/^.*startblock \([0-9]*\) .*$/\1/g')
64
65 _scratch_xfs_db -x -c 'sb 0' -c 'addr rrmapino' \
66         -c "write u3.rtrmapbt.ptrs[1] $fsbno" -c 'p' >> $seqres.full
67 _scratch_mount
68
69 echo "Try to create more files"
70 $XFS_IO_PROG -f -R -c "pwrite -S 0x68 0 9999" $SCRATCH_MNT/f5 >> $seqres.full 2>&1
71 test -e $SCRATCH_MNT/f5 && echo "should not have been able to write f5"
72
73 echo "Repair fs"
74 _scratch_unmount 2>&1 | _filter_scratch
75 _repair_scratch_fs >> $seqres.full 2>&1
76
77 echo "Try to create more files (again)"
78 _scratch_mount
79 $XFS_IO_PROG -f -R -c "pwrite -S 0x68 0 9999" $SCRATCH_MNT/f4 >> $seqres.full
80
81 # success, all done
82 status=0
83 exit