summaryrefslogtreecommitdiffstats
path: root/usr/Kconfig
diff options
context:
space:
mode:
authorDave Chinner <dchinner@redhat.com>2018-10-06 03:44:19 +0200
committerDave Chinner <david@fromorbit.com>2018-10-06 03:44:19 +0200
commitdceeb47b0ed65e14de53507a8a9c32a90831cfa1 (patch)
treea7f1a07a5d322830639a3406723b118bfd3f6cd3 /usr/Kconfig
parentxfs: update ctime and remove suid before cloning files (diff)
downloadlinux-dceeb47b0ed65e14de53507a8a9c32a90831cfa1.tar.xz
linux-dceeb47b0ed65e14de53507a8a9c32a90831cfa1.zip
xfs: fix data corruption w/ unaligned dedupe ranges
A deduplication data corruption is Exposed by fstests generic/505 on XFS. It is caused by extending the block match range to include the partial EOF block, but then allowing unknown data beyond EOF to be considered a "match" to data in the destination file because the comparison is only made to the end of the source file. This corrupts the destination file when the source extent is shared with it. XFS only supports whole block dedupe, but we still need to appear to support whole file dedupe correctly. Hence if the dedupe request includes the last block of the souce file, don't include it in the actual XFS dedupe operation. If the rest of the range dedupes successfully, then report the partial last block as deduped, too, so that userspace sees it as a successful dedupe rather than return EINVAL because we can't dedupe unaligned blocks. Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com> Signed-off-by: Dave Chinner <david@fromorbit.com>
Diffstat (limited to 'usr/Kconfig')
0 files changed, 0 insertions, 0 deletions