2010-01-20 10:27:08 +11:00
|
|
|
##/bin/bash
|
2018-06-09 11:34:49 +10:00
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
2005-11-09 02:50:19 +00:00
|
|
|
# Copyright (c) 2000-2002 Silicon Graphics, Inc. All Rights Reserved.
|
2001-01-15 05:01:19 +00:00
|
|
|
#
|
|
|
|
|
# Functions useful for xfs_repair tests
|
|
|
|
|
|
|
|
|
|
_zero_position()
|
|
|
|
|
{
|
|
|
|
|
value=$1
|
|
|
|
|
struct="$2"
|
|
|
|
|
|
|
|
|
|
# set values for off/len variables provided by db
|
|
|
|
|
eval `xfs_db -r -c "$struct" -c stack $SCRATCH_DEV | perl -ne '
|
|
|
|
|
if (/byte offset (\d+), length (\d+)/) {
|
|
|
|
|
print "offset=$1\nlength=$2\n"; exit
|
|
|
|
|
}'`
|
|
|
|
|
if [ -z "$offset" -o -z "$length" ]; then
|
|
|
|
|
echo "cannot calculate offset ($offset) or length ($length)"
|
|
|
|
|
exit
|
|
|
|
|
fi
|
|
|
|
|
length=`expr $length / 512`
|
2019-10-21 21:35:46 +08:00
|
|
|
$here/src/devzero -v $value -b 1 -n $length -o $offset $SCRATCH_DEV \
|
2002-12-19 01:46:51 +00:00
|
|
|
| perl -npe 's/\d\.\d\dKb/X.XXKb/g'
|
2001-01-15 05:01:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_filter_repair()
|
|
|
|
|
{
|
|
|
|
|
perl -ne '
|
|
|
|
|
# for sb
|
|
|
|
|
/- agno = / && next; # remove each AG line (variable number)
|
|
|
|
|
s/(pointer to) (\d+)/\1 INO/;
|
2020-02-27 20:50:49 -08:00
|
|
|
# Changed inode output in 5.5.0
|
|
|
|
|
s/sb root inode value /sb root inode /;
|
|
|
|
|
s/realtime bitmap inode value /realtime bitmap inode /;
|
|
|
|
|
s/realtime summary inode value /realtime summary inode /;
|
|
|
|
|
s/ino pointer to /inode pointer to /;
|
|
|
|
|
#
|
|
|
|
|
s/(sb root inode) (\d+)( \(NULLFSINO\))?/\1 INO/;
|
2002-08-19 21:38:12 +00:00
|
|
|
s/(realtime bitmap inode) (\d+)( \(NULLFSINO\))?/\1 INO/;
|
|
|
|
|
s/(realtime summary inode) (\d+)( \(NULLFSINO\))?/\1 INO/;
|
2001-01-15 05:01:19 +00:00
|
|
|
s/(inconsistent with calculated value) (\d+)/\1 INO/;
|
|
|
|
|
s/\.+(found)/\1/g; # remove "searching" output
|
|
|
|
|
# for agf + agi
|
|
|
|
|
s/(bad length -{0,1}\d+ for ag. 0, should be) (\d+)/\1 LENGTH/;
|
|
|
|
|
s/(bad length # -{0,1}\d+ for ag. 0, should be) (\d+)/\1 LENGTH/;
|
|
|
|
|
s/(bad agbno) (\d+)/\1 AGBNO/g;
|
|
|
|
|
s/(max =) (\d+)/\1 MAX/g;
|
|
|
|
|
# for root inos
|
|
|
|
|
s/(on inode) (\d+)/\1 INO/g;
|
|
|
|
|
s/(imap claims a free inode) (\d+)/\1 INO/;
|
2002-05-09 06:03:32 +00:00
|
|
|
s/(imap claims in-use inode) (\d+)/\1 INO/;
|
2001-01-15 05:01:19 +00:00
|
|
|
s/(cleared root inode) (\d+)/\1 INO/;
|
|
|
|
|
s/(resetting inode) (\d+)/\1 INO/;
|
|
|
|
|
s/(disconnected dir inode) (\d+)/\1 INO/;
|
2003-05-22 04:16:45 +00:00
|
|
|
# for log
|
|
|
|
|
s/internal log/<TYPEOF> log/g;
|
|
|
|
|
s/external log on \S+/<TYPEOF> log/g;
|
2004-06-25 03:09:08 +00:00
|
|
|
# realtime subvol - remove this whole line if it appears
|
|
|
|
|
s/ - generate realtime summary info and bitmap...\n//g;
|
2006-12-12 14:55:58 +00:00
|
|
|
#
|
|
|
|
|
# new xfs repair output filters
|
|
|
|
|
#
|
|
|
|
|
s/\s+- creating \d+ worker thread\(s\)\n//g;
|
|
|
|
|
s/\s+- reporting progress in intervals of \d+ minutes\n//g;
|
|
|
|
|
s/\s+- \d+:\d\d:\d\d:.*\n//g;
|
2010-05-04 16:01:47 +10:00
|
|
|
# 3.1.0 extra accounting output
|
|
|
|
|
/^agf_/ && next; # remove agf counts
|
|
|
|
|
/^agi_/ && next; # remove agi counts
|
|
|
|
|
/^sb_/ && next; # remove sb counts
|
|
|
|
|
/^agi unlinked/ && next; # remove agi unlinked bucket warning
|
2013-03-15 11:53:19 +00:00
|
|
|
# crc enabled filesystem output
|
|
|
|
|
/XFS_CORRUPTION_ERROR/ && next;
|
|
|
|
|
/^bad uuid/ && next;
|
2014-04-28 10:54:53 +10:00
|
|
|
/^Metadata corruption detected/ && next;
|
|
|
|
|
/^Metadata CRC error detected/ && next;
|
|
|
|
|
/^agfl has bad CRC/ && next;
|
2015-05-14 12:18:29 +10:00
|
|
|
/^bad CRC for inode/ && next;
|
2014-05-13 15:27:47 +10:00
|
|
|
# finobt enabled filesystem output
|
|
|
|
|
s/(inode chunk) (\d+)\/(\d+)/AGNO\/INO/;
|
2014-09-08 20:48:59 +10:00
|
|
|
# sunit/swidth reset messages
|
|
|
|
|
s/^(Note - .*) were copied.*/\1 fields have been reset./;
|
|
|
|
|
s/^(Please) reset (with .*) if necessary/\1 set \2/;
|
2020-02-27 20:50:49 -08:00
|
|
|
# remove new unlinked inode test
|
|
|
|
|
/^bad next_unlinked/ && next;
|
2016-05-19 16:19:51 -05:00
|
|
|
# And make them generic so we dont depend on geometry
|
|
|
|
|
s/(stripe unit) \(.*\) (and width) \(.*\)/\1 (SU) \2 (SW)/;
|
2015-02-12 14:12:14 +11:00
|
|
|
# corrupt sb messages
|
|
|
|
|
s/(superblock) (\d+)/\1 AGNO/;
|
|
|
|
|
s/(AG \#)(\d+)/\1AGNO/;
|
|
|
|
|
s/(reset bad sb for ag) (\d+)/\1 AGNO/;
|
2017-11-01 14:47:36 -07:00
|
|
|
s/(unknown block state, ag )(\d+)(, block )(\d+)/\1AGNO\3AGBNO/;
|
2018-07-03 21:51:31 -07:00
|
|
|
/^Note - quota info will be regenerated on next quota mount.$/ && next;
|
2001-01-15 05:01:19 +00:00
|
|
|
print;'
|
|
|
|
|
}
|
|
|
|
|
|
2017-11-01 14:47:36 -07:00
|
|
|
# Filter out unknown block state messages that appear when rmap is enabled
|
|
|
|
|
# and we erase a btree root pointer (such that repair never finds the
|
|
|
|
|
# tree and fails to reconcile the metadata reverse mappings against the
|
|
|
|
|
# metadata).
|
|
|
|
|
_filter_repair_lostblocks() {
|
|
|
|
|
_filter_repair | sed -e '/unknown block state, ag AGNO, block AGBNO/d'
|
|
|
|
|
}
|
|
|
|
|
|
2001-01-15 05:01:19 +00:00
|
|
|
_filter_dd()
|
|
|
|
|
{
|
|
|
|
|
fgrep -v records # lose records in/out lines
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# do some controlled corrupting & ensure repair recovers us
|
|
|
|
|
#
|
|
|
|
|
_check_repair()
|
|
|
|
|
{
|
|
|
|
|
value=$1
|
|
|
|
|
structure="$2"
|
2007-06-04 06:12:42 +00:00
|
|
|
|
|
|
|
|
#ensure the filesystem has been dirtied since last repair
|
|
|
|
|
_scratch_mount
|
|
|
|
|
POSIXLY_CORRECT=yes \
|
2010-04-29 09:59:24 +10:00
|
|
|
dd if=/bin/bash of=$SCRATCH_MNT/sh 2>&1 |_filter_dd
|
2007-06-04 06:12:42 +00:00
|
|
|
sync
|
|
|
|
|
rm -f $SCRATCH_MNT/sh
|
2015-12-21 18:07:43 +11:00
|
|
|
_scratch_unmount
|
2007-06-04 06:12:42 +00:00
|
|
|
|
2001-01-15 05:01:19 +00:00
|
|
|
_zero_position $value "$structure"
|
2003-05-22 04:16:45 +00:00
|
|
|
_scratch_xfs_repair 2>&1 | _filter_repair
|
2007-06-04 06:12:42 +00:00
|
|
|
|
2001-01-15 05:01:19 +00:00
|
|
|
# some basic sanity checks...
|
2003-05-22 04:16:45 +00:00
|
|
|
_check_scratch_fs
|
|
|
|
|
_scratch_mount #mount
|
2003-06-12 04:17:41 +00:00
|
|
|
POSIXLY_CORRECT=yes \
|
2010-04-29 09:59:24 +10:00
|
|
|
dd if=/bin/bash of=$SCRATCH_MNT/sh 2>&1 |_filter_dd #open,write
|
2003-06-12 04:17:41 +00:00
|
|
|
POSIXLY_CORRECT=yes \
|
2001-01-15 05:01:19 +00:00
|
|
|
dd if=$SCRATCH_MNT/sh of=/dev/null 2>&1 |_filter_dd #read
|
|
|
|
|
rm -f $SCRATCH_MNT/sh #unlink
|
2015-12-21 18:07:43 +11:00
|
|
|
_scratch_unmount #umount
|
2001-01-15 05:01:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# make sure this script returns success
|
|
|
|
|
/bin/true
|