]> git.baikalelectronics.ru Git - kernel.git/commit
xfs: debug mode log record crc error injection
authorBrian Foster <bfoster@redhat.com>
Mon, 4 Jan 2016 20:41:16 +0000 (07:41 +1100)
committerDave Chinner <david@fromorbit.com>
Mon, 4 Jan 2016 20:41:16 +0000 (07:41 +1100)
commit159f7559f5c2a5a68350d16bbe0ac0cc92a0f7e2
tree6612e2f6a7d93cfeeb806abe25def385943544d3
parentabf9e59a6eb872643c44204c1c5196bc26ae8aae
xfs: debug mode log record crc error injection

XFS now uses CRC verification over a limited section of the log to
detect torn writes prior to a crash. This is difficult to test directly
due to the timing and hardware requirements to cause a short write.

Add a mechanism to inject CRC errors into log records to facilitate
testing torn write detection during log recovery. This mechanism is
dangerous and can result in filesystem corruption. Thus, it is only
available in DEBUG mode for testing/development purposes. Set a non-zero
value to the following sysfs entry to enable error injection:

/sys/fs/xfs/<dev>/log/log_badcrc_factor

Once enabled, XFS intentionally writes an invalid CRC to a log record at
some random point in the future based on the provided frequency. The
filesystem immediately shuts down once the record has been written to
the physical log to prevent metadata writeback (e.g., AIL insertion)
once the log write completes. This helps reasonably simulate a torn
write to the log as the affected record must be safe to discard. The
next mount after the intentional shutdown requires log recovery and
should detect and recover from the torn write.

Note again that this _will_ result in data loss or worse. For testing
and development purposes only!

Signed-off-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Dave Chinner <david@fromorbit.com>
fs/xfs/xfs_log.c
fs/xfs/xfs_log_priv.h
fs/xfs/xfs_sysfs.c