2 # SPDX-License-Identifier: GPL-2.0
3 # Copyright (c) 2000-2004 Silicon Graphics, Inc. All Rights Reserved.
7 # test out mkfs_xfs output on IRIX/Linux and some of its error handling
8 # ensure pv#920679 is addressed
12 _begin_fstest mkfs v2log auto quick
14 # Import common functions.
19 # filter out counts which will vary
20 # - extsz, blocks, agsize, agcount, device name, rtextents
21 # - log version varies for crc enabled fs
22 # - lsunit varies for 512/4k sector devices
23 # filter out differences between linux and irix:
25 # - mmr, mixed-case on IRIX
26 # - lazy-count on IRIX
27 # - inode-paths on IRIX
28 # - trailing spaces on Linux but not on IRIX
31 # meta-data=DEV isize=256 agcount=N, agsize=N blks
32 # data = bsize=4096 blocks=N, imaxpct=25
33 # = sunit=65 swidth=65 blks, unwritten=1
34 # naming =version 2 bsize=4096
35 # log =internal log bsize=4096 blocks=N, version=1
37 # realtime =none extsz=65536 blocks=N, rtextents=N
41 tee -a $seqres.full | \
43 -e 's/extsz=[0-9][0-9]*[ ]*/extsz=N, /' \
44 -e 's/blocks=[0-9][0-9]*/blocks=N/' \
45 -e 's/imaxpct=[0-9][0-9]*/imaxpct=N/' \
46 -e 's/agsize=[0-9][0-9]*/agsize=N/' \
47 -e 's/agcount=[0-9][0-9]*/agcount=N/' \
48 -e 's/swidth=[0-9][0-9]* blks$/&, unwritten=1/' \
49 -e 's/rtextents=[0-9][0-9]*/rtextents=N/' \
50 -e 's/meta-data=[^ ]*/meta-data=DEV/' \
51 -e 's/ *isize=[0-9]* / isize=N /' \
52 -e '/ *= *sectsz=[0-9][0-9]* *attr=[0-9][0-9]*.*$/d' \
53 -e '/ *= *mmr=[0-9][0-9]* *$/d' \
54 -e 's/ *mixed-case=[YN]//' \
55 -e 's/ *ascii-ci=[01]//' \
56 -e 's/\(version=\)\([12]\)/\1N/' \
57 -e 's/\(sunit=\)\([018] blks\)/\1N blks/' \
58 -e 's/sectsz=[0-9][0-9]* *//' \
59 -e 's/, lazy-count.*//' \
61 -e 's/\(log[ ]*=\).*bsize/\1LOG bsize/' \
62 -e 's/\(realtime[ ]*=\).*extsz/\1REALTIME extsz/' \
65 -e 's/ ftype=[01]//' \
66 -e '/^log stripe unit.*too large/d' \
67 -e '/^log stripe unit adjusted/d' \
72 # real QA test starts here
74 # Modify as appropriate.
78 _require_xfs_mkfs_without_validation
80 # choose .out file based on internal/external log
82 if [ "$USE_EXTERNAL" = yes ]; then
83 ln -s $seq.out.external $seqfull.out
85 ln -s $seq.out.internal $seqfull.out
88 # maximum log record size
89 max_lr_size=`expr 256 \* 1024`
91 big_su=`expr $max_lr_size + 4096`
94 # Test out various mkfs param combinations
96 cat >$tmp.seq.params <<EOF
97 # su too big but must be a multiple of fs block size too
98 -l version=2,su=`expr $max_lr_size + 512`
99 # test log stripe greater than LR size
100 -l version=2,su=$big_su
101 # same test but get log stripe from data stripe
102 -l version=2 -d su=$big_su,sw=1
103 # test out data stripe
104 -m crc=0 -l version=1 -d su=$big_su,sw=1
105 # test out data stripe the same but using sunit & swidth
106 -m crc=0 -l version=1 -d sunit=`expr $big_su / 512`,swidth=`expr $big_su / 512`
110 # call mkfs in a loop for various params
113 cat $tmp.seq.params \
116 if echo $mkfs | grep -q '^#'; then
117 # print out header & ignore comment
121 echo "--- mkfs=$mkfs ---"
122 export MKFS_OPTIONS="$mkfs"
123 _scratch_mkfs_xfs 2>&1 | mkfs_filter